From: Anshuman Khandual <anshuman.khandual@arm.com> To: linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, peterz@infradead.org, acme@kernel.org Cc: james.clark@arm.com, suzuki.poulose@arm.com, Anshuman Khandual <anshuman.khandual@arm.com>, Ingo Molnar <mingo@redhat.com>, Mark Rutland <mark.rutland@arm.com>, Alexander Shishkin <alexander.shishkin@linux.intel.com>, Jiri Olsa <jolsa@redhat.com>, Namhyung Kim <namhyung@kernel.org>, Thomas Gleixner <tglx@linutronix.de>, Will Deacon <will@kernel.org>, linux-arm-kernel@lists.infradead.org Subject: [PATCH V2 0/8] perf: Expand perf_branch_entry Date: Wed, 9 Mar 2022 09:06:34 +0530 [thread overview] Message-ID: <20220309033642.144769-1-anshuman.khandual@arm.com> (raw) Branch Record Buffer Extension (BRBE) implementation on arm64 captures more branch type classification which cannot be accommodated in the current perf branch record format via perf_branch_entry.type element (4 bit field). Also it captures privilege information which does not have a corresponding slot in perf_branch_entry. This series expands struct perf_branch_entry, to meet both these requirements without breaking the existing user space ABI for perf tools. All architecture specific branch types added via perf_branch_entry.new_type field in [PATCH 3/4] will be used in BRBE implementation on arm64 platform later on with the following map. #ifdef CONFIG_ARM64 #define PERF_BR_FIQ PERF_BR_NEW_ARCH_1 #define PERF_BR_DEBUG_HALT PERF_BR_NEW_ARCH_2 #define PERF_BR_DEBUG_EXIT PERF_BR_NEW_ARCH_3 #define PERF_BR_DEBUG_INST PERF_BR_NEW_ARCH_4 #define PERF_BR_DEBUG_DATA PERF_BR_NEW_ARCH_5 #endif This actually combines following patches and series into a single series. - https://lore.kernel.org/all/1642998653-21377-12-git-send-email-anshuman.khandual@arm.com/ - https://lore.kernel.org/all/1643348653-24367-1-git-send-email-anshuman.khandual@arm.com/ - https://lore.kernel.org/all/1645681014-3346-1-git-send-email-anshuman.khandual@arm.com/ This series applies on v5.17-rc7 perf API The series being applied - Clean : tools/perf/check-headers.sh - Clean : diff -u tools/include/uapi/linux/perf_event.h include/uapi/linux/perf_event.h Todo - Update perf report tool to process PERF_BR_EXTEND_ABI (when available), then fetch and report branch types from perf_branch_entry.new_type field. References - BRBE captured branch record information https://developer.arm.com/documentation/ddi0601/2021-12/AArch64-Registers/BRBINF-n--EL1--Branch-Record-Buffer-Information-Register--n-?lang=en - BRBE based perf branch stack implementation on arm64 platform https://lore.kernel.org/all/1642998653-21377-1-git-send-email-anshuman.khandual@arm.com/ Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Will Deacon <will@kernel.org> Cc: linux-arm-kernel@lists.infradead.org Cc: linux-perf-users@vger.kernel.org Cc: linux-kernel@vger.kernel.org Anshuman Khandual (8): perf: Add irq and exception return branch types perf: Add system error and not in transaction branch types perf: Extend branch type classification perf: Capture branch privilege information perf/tools: Add irq and exception return branch types perf/tools: Add system error and not in transaction branch types perf/tools: Extend branch type classification perf/tools: Add branch privilege information request flag arch/x86/events/intel/lbr.c | 6 ++--- include/uapi/linux/perf_event.h | 31 +++++++++++++++++++++++- tools/include/uapi/linux/perf_event.h | 31 +++++++++++++++++++++++- tools/perf/Documentation/perf-record.txt | 1 + tools/perf/util/branch.c | 7 +++++- tools/perf/util/parse-branch-options.c | 1 + 6 files changed, 71 insertions(+), 6 deletions(-) -- 2.25.1
WARNING: multiple messages have this Message-ID (diff)
From: Anshuman Khandual <anshuman.khandual@arm.com> To: linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, peterz@infradead.org, acme@kernel.org Cc: james.clark@arm.com, suzuki.poulose@arm.com, Anshuman Khandual <anshuman.khandual@arm.com>, Ingo Molnar <mingo@redhat.com>, Mark Rutland <mark.rutland@arm.com>, Alexander Shishkin <alexander.shishkin@linux.intel.com>, Jiri Olsa <jolsa@redhat.com>, Namhyung Kim <namhyung@kernel.org>, Thomas Gleixner <tglx@linutronix.de>, Will Deacon <will@kernel.org>, linux-arm-kernel@lists.infradead.org Subject: [PATCH V2 0/8] perf: Expand perf_branch_entry Date: Wed, 9 Mar 2022 09:06:34 +0530 [thread overview] Message-ID: <20220309033642.144769-1-anshuman.khandual@arm.com> (raw) Branch Record Buffer Extension (BRBE) implementation on arm64 captures more branch type classification which cannot be accommodated in the current perf branch record format via perf_branch_entry.type element (4 bit field). Also it captures privilege information which does not have a corresponding slot in perf_branch_entry. This series expands struct perf_branch_entry, to meet both these requirements without breaking the existing user space ABI for perf tools. All architecture specific branch types added via perf_branch_entry.new_type field in [PATCH 3/4] will be used in BRBE implementation on arm64 platform later on with the following map. #ifdef CONFIG_ARM64 #define PERF_BR_FIQ PERF_BR_NEW_ARCH_1 #define PERF_BR_DEBUG_HALT PERF_BR_NEW_ARCH_2 #define PERF_BR_DEBUG_EXIT PERF_BR_NEW_ARCH_3 #define PERF_BR_DEBUG_INST PERF_BR_NEW_ARCH_4 #define PERF_BR_DEBUG_DATA PERF_BR_NEW_ARCH_5 #endif This actually combines following patches and series into a single series. - https://lore.kernel.org/all/1642998653-21377-12-git-send-email-anshuman.khandual@arm.com/ - https://lore.kernel.org/all/1643348653-24367-1-git-send-email-anshuman.khandual@arm.com/ - https://lore.kernel.org/all/1645681014-3346-1-git-send-email-anshuman.khandual@arm.com/ This series applies on v5.17-rc7 perf API The series being applied - Clean : tools/perf/check-headers.sh - Clean : diff -u tools/include/uapi/linux/perf_event.h include/uapi/linux/perf_event.h Todo - Update perf report tool to process PERF_BR_EXTEND_ABI (when available), then fetch and report branch types from perf_branch_entry.new_type field. References - BRBE captured branch record information https://developer.arm.com/documentation/ddi0601/2021-12/AArch64-Registers/BRBINF-n--EL1--Branch-Record-Buffer-Information-Register--n-?lang=en - BRBE based perf branch stack implementation on arm64 platform https://lore.kernel.org/all/1642998653-21377-1-git-send-email-anshuman.khandual@arm.com/ Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Will Deacon <will@kernel.org> Cc: linux-arm-kernel@lists.infradead.org Cc: linux-perf-users@vger.kernel.org Cc: linux-kernel@vger.kernel.org Anshuman Khandual (8): perf: Add irq and exception return branch types perf: Add system error and not in transaction branch types perf: Extend branch type classification perf: Capture branch privilege information perf/tools: Add irq and exception return branch types perf/tools: Add system error and not in transaction branch types perf/tools: Extend branch type classification perf/tools: Add branch privilege information request flag arch/x86/events/intel/lbr.c | 6 ++--- include/uapi/linux/perf_event.h | 31 +++++++++++++++++++++++- tools/include/uapi/linux/perf_event.h | 31 +++++++++++++++++++++++- tools/perf/Documentation/perf-record.txt | 1 + tools/perf/util/branch.c | 7 +++++- tools/perf/util/parse-branch-options.c | 1 + 6 files changed, 71 insertions(+), 6 deletions(-) -- 2.25.1 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
next reply other threads:[~2022-03-09 3:37 UTC|newest] Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top 2022-03-09 3:36 Anshuman Khandual [this message] 2022-03-09 3:36 ` [PATCH V2 0/8] perf: Expand perf_branch_entry Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 1/8] perf: Add irq and exception return branch types Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 2/8] perf: Add system error and not in transaction " Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 3/8] perf: Extend branch type classification Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 4/8] perf: Capture branch privilege information Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual 2022-03-10 10:21 ` James Clark 2022-03-10 10:21 ` James Clark 2022-03-11 3:25 ` Anshuman Khandual 2022-03-11 3:25 ` Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 5/8] perf/tools: Add irq and exception return branch types Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 6/8] perf/tools: Add system error and not in transaction " Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 7/8] perf/tools: Extend branch type classification Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual 2022-03-10 10:16 ` James Clark 2022-03-10 10:16 ` James Clark 2022-03-11 3:52 ` Anshuman Khandual 2022-03-11 3:52 ` Anshuman Khandual 2022-03-09 3:36 ` [PATCH V2 8/8] perf/tools: Add branch privilege information request flag Anshuman Khandual 2022-03-09 3:36 ` Anshuman Khandual
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20220309033642.144769-1-anshuman.khandual@arm.com \ --to=anshuman.khandual@arm.com \ --cc=acme@kernel.org \ --cc=alexander.shishkin@linux.intel.com \ --cc=james.clark@arm.com \ --cc=jolsa@redhat.com \ --cc=linux-arm-kernel@lists.infradead.org \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-perf-users@vger.kernel.org \ --cc=mark.rutland@arm.com \ --cc=mingo@redhat.com \ --cc=namhyung@kernel.org \ --cc=peterz@infradead.org \ --cc=suzuki.poulose@arm.com \ --cc=tglx@linutronix.de \ --cc=will@kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.