perf/x86/amd/core: Always clear status for idx
authorBreno Leitao <leitao@debian.org>
Tue, 21 Mar 2023 11:33:38 +0000 (04:33 -0700)
committerPeter Zijlstra <peterz@infradead.org>
Tue, 21 Mar 2023 13:43:05 +0000 (14:43 +0100)
commit263f5ecaf7080513efc248ec739b6d9e00f4129f
tree1f5767b26fc992f0984122f54d090087fed19de8
parente8d018dd0257f744ca50a729e3d042cf2ec9da65
perf/x86/amd/core: Always clear status for idx

The variable 'status' (which contains the unhandled overflow bits) is
not being properly masked in some cases, displaying the following
warning:

  WARNING: CPU: 156 PID: 475601 at arch/x86/events/amd/core.c:972 amd_pmu_v2_handle_irq+0x216/0x270

This seems to be happening because the loop is being continued before
the status bit being unset, in case x86_perf_event_set_period()
returns 0. This is also causing an inconsistency because the "handled"
counter is incremented, but the status bit is not cleaned.

Move the bit cleaning together above, together when the "handled"
counter is incremented.

Fixes: 7685665c390d ("perf/x86/amd/core: Add PerfMonV2 overflow handling")
Signed-off-by: Breno Leitao <leitao@debian.org>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Sandipan Das <sandipan.das@amd.com>
Link: https://lore.kernel.org/r/20230321113338.1669660-1-leitao@debian.org
arch/x86/events/amd/core.c