mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-01 10:42:11 +00:00
perf/arm-cmn: Permit more exhaustive groups
The group validation logic still somewhat assumes the original CMN-600 case of events counting globally, such that if one tries to group 9 events where the first 8 target a single DTC domain, the 9th will be rejected because *a* DTC domain is full, even though it might only target other non-overlapping domains and thus still be schedulable. Improve matters by only counting the DTCs that the new event actually needs (as arm_cmn_val_add_event() was already clever enough to do). Signed-off-by: Robin Murphy <robin.murphy@arm.com> Reviewed-and-tested-by: Ilkka Koskinen <ilkka@os.amperecomputing.com> Link: https://lore.kernel.org/r/bdfd1e58dac449e407c5cacfd6bf8577dc0a5899.1733943898.git.robin.murphy@arm.com Signed-off-by: Will Deacon <will@kernel.org>
This commit is contained in:
parent
b34d605d12
commit
e49ecdf79a
@ -1713,8 +1713,8 @@ static int arm_cmn_validate_group(struct arm_cmn *cmn, struct perf_event *event)
|
|||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < CMN_MAX_DTCS; i++)
|
for_each_hw_dtc_idx(hw, dtc, idx)
|
||||||
if (val->dtc_count[i] == CMN_DT_NUM_COUNTERS)
|
if (val->dtc_count[dtc] == CMN_DT_NUM_COUNTERS)
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
for_each_hw_dn(hw, dn, i) {
|
for_each_hw_dn(hw, dn, i) {
|
||||||
|
Loading…
Reference in New Issue
Block a user