summaryrefslogtreecommitdiffstats
path: root/drivers/perf
diff options
context:
space:
mode:
authorSamuel Holland <samuel.holland@sifive.com>2024-06-28 00:51:42 -0700
committerPalmer Dabbelt <palmer@rivosinc.com>2024-07-03 12:56:21 -0700
commit7dd646cf745c34d31e7ed2a52265e9ca8308f58f (patch)
tree4ca22c89fd9dbf46dbb2dd96b5b1ac7b4217b786 /drivers/perf
parenta3f24e83d11d7ceb4743416c803332e9c5749298 (diff)
downloadlinux-stable-7dd646cf745c34d31e7ed2a52265e9ca8308f58f.tar.gz
linux-stable-7dd646cf745c34d31e7ed2a52265e9ca8308f58f.tar.bz2
linux-stable-7dd646cf745c34d31e7ed2a52265e9ca8308f58f.zip
drivers/perf: riscv: Reset the counter to hpmevent mapping while starting cpus
Currently, we stop all the counters while a new cpu is brought online. However, the hpmevent to counter mappings are not reset. The firmware may have some stale encoding in their mapping structure which may lead to undesirable results. We have not encountered such scenario though. Signed-off-by: Samuel Holland <samuel.holland@sifive.com> Signed-off-by: Atish Patra <atishp@rivosinc.com> Link: https://lore.kernel.org/r/20240628-misc_perf_fixes-v4-2-e01cfddcf035@rivosinc.com Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
Diffstat (limited to 'drivers/perf')
-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 a2e4005e1fd0..94bc369a3454 100644
--- a/drivers/perf/riscv_pmu_sbi.c
+++ b/drivers/perf/riscv_pmu_sbi.c
@@ -762,7 +762,7 @@ static inline void pmu_sbi_stop_all(struct riscv_pmu *pmu)
* which may include counters that are not enabled yet.
*/
sbi_ecall(SBI_EXT_PMU, SBI_EXT_PMU_COUNTER_STOP,
- 0, pmu->cmask, 0, 0, 0, 0);
+ 0, pmu->cmask, SBI_PMU_STOP_FLAG_RESET, 0, 0, 0);
}
static inline void pmu_sbi_stop_hw_ctrs(struct riscv_pmu *pmu)