summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShifrin Dmitry <dmitry.shifrin@syntacore.com>2024-07-29 15:58:58 +0300
committerPalmer Dabbelt <palmer@rivosinc.com>2024-08-01 07:15:13 -0700
commit941a8e9b7a86763ac52d5bf6ccc9986d37fde628 (patch)
tree1068f19c1d75089108de235bb749f74a60884fb4
parent57e5c814e91577a464484cc4b1a56ff86371a713 (diff)
downloadlwn-941a8e9b7a86763ac52d5bf6ccc9986d37fde628.tar.gz
lwn-941a8e9b7a86763ac52d5bf6ccc9986d37fde628.zip
perf: riscv: Fix selecting counters in legacy mode
It is required to check event type before checking event config. Events with the different types can have the same config. This check is missed for legacy mode code For such perf usage: sysctl -w kernel.perf_user_access=2 perf stat -e cycles,L1-dcache-loads -- driver will try to force both events to CYCLE counter. This commit implements event type check before forcing events on the special counters. Signed-off-by: Shifrin Dmitry <dmitry.shifrin@syntacore.com> Reviewed-by: Atish Patra <atishp@rivosinc.com> Fixes: cc4c07c89aad ("drivers: perf: Implement perf event mmap support in the SBI backend") Link: https://lore.kernel.org/r/20240729125858.630653-1-dmitry.shifrin@syntacore.com Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
-rw-r--r--drivers/perf/riscv_pmu_sbi.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/perf/riscv_pmu_sbi.c b/drivers/perf/riscv_pmu_sbi.c
index 44d3951d009f..31a17a56eb3b 100644
--- a/drivers/perf/riscv_pmu_sbi.c
+++ b/drivers/perf/riscv_pmu_sbi.c
@@ -416,7 +416,7 @@ static int pmu_sbi_ctr_get_idx(struct perf_event *event)
* but not in the user access mode as we want to use the other counters
* that support sampling/filtering.
*/
- if (hwc->flags & PERF_EVENT_FLAG_LEGACY) {
+ if ((hwc->flags & PERF_EVENT_FLAG_LEGACY) && (event->attr.type == PERF_TYPE_HARDWARE)) {
if (event->attr.config == PERF_COUNT_HW_CPU_CYCLES) {
cflags |= SBI_PMU_CFG_FLAG_SKIP_MATCH;
cmask = 1;