[PATCH v2 5/5] perf: arm_cspmu: ampere_cspmu: Add support for Ampere SoC PMU
Robin Murphy
robin.murphy at arm.com
Thu Jun 1 08:23:57 PDT 2023
On 2023-06-01 04:01, Ilkka Koskinen wrote:
[...]
> +static bool ampere_cspmu_validate_event(struct arm_cspmu *cspmu,
> + struct perf_event *new)
> +{
> + struct perf_event *curr;
> + unsigned int idx;
> + u32 threshold = 0, rank = 0, bank = 0;
> +
> + /* We compare the global filter settings to existing events */
> + idx = find_first_bit(cspmu->hw_events.used_ctrs,
> + cspmu->cycle_counter_logical_idx);
> +
> + /* This is the first event */
> + if (idx == cspmu->cycle_counter_logical_idx)
> + return true;
> +
> + curr = cspmu->hw_events.events[idx];
> +
> + if (get_filter_enable(new)) {
> + threshold = get_threshold(new);
> + rank = get_rank(new);
> + bank = get_bank(new);
> + }
> +
> + if (get_filter_enable(new) != get_filter_enable(curr) ||
Is there any useful purpose in allowing the user to specify nonzero
rank, bank or threshold values with filter_enable=0? Assuming not, then
between this and ampere_cspmu_set_ev_filter() it appears that you don't
need filter_enable at all.
Thanks,
Robin.
> + get_threshold(curr) != threshold ||
> + get_rank(curr) != rank ||
> + get_bank(curr) != bank)
> + return false;
> +
> + return true;
> +}
More information about the linux-arm-kernel
mailing list