[PATCH] arm64: perf: Allow more than one cycle counter to be used

Pratyush Anand panand at redhat.com
Sun Jul 16 20:26:10 PDT 2017


+Mark

On Saturday 01 July 2017 12:03 PM, Pratyush Anand wrote:
> Currently:
> $ perf stat -e cycles:u -e cycles:k  true
>
>  Performance counter stats for 'true':
>
>           2,24,699      cycles:u
>      <not counted>      cycles:k	(0.00%)
>
>        0.000788087 seconds time elapsed
>
> We can not count more than one cycle counter in one instance,because we
> allow to map cycle counter into PMCCNTR_EL0 only. However, if I did not
> miss anything then specification do not prohibit to use PMEVCNTR<n>_EL0
> for cycle count as well.
>
> Modify the code so that it still prefers to use PMCCNTR_EL0 for cycle
> counter, however allow to use PMEVCNTR<n>_EL0 if PMCCNTR_EL0 is already
> in use.
>
> After this patch:
>
> $ perf stat -e cycles:u -e cycles:k   true
>
>  Performance counter stats for 'true':
>
>           2,17,310      cycles:u
>           7,40,009      cycles:k
>
>        0.000764149 seconds time elapsed
>

Any comment/feedback?

> Signed-off-by: Pratyush Anand <panand at redhat.com>
> ---
>  arch/arm64/kernel/perf_event.c | 11 ++++-------
>  1 file changed, 4 insertions(+), 7 deletions(-)
>
> diff --git a/arch/arm64/kernel/perf_event.c b/arch/arm64/kernel/perf_event.c
> index 83a1b1ad189f..43c77314f345 100644
> --- a/arch/arm64/kernel/perf_event.c
> +++ b/arch/arm64/kernel/perf_event.c
> @@ -846,17 +846,14 @@ static int armv8pmu_get_event_idx(struct pmu_hw_events *cpuc,
>  	struct hw_perf_event *hwc = &event->hw;
>  	unsigned long evtype = hwc->config_base & ARMV8_PMU_EVTYPE_EVENT;
>
> -	/* Always place a cycle counter into the cycle counter. */
> +	/* Always prefer to place a cycle counter into the cycle counter. */
>  	if (evtype == ARMV8_PMUV3_PERFCTR_CPU_CYCLES) {
> -		if (test_and_set_bit(ARMV8_IDX_CYCLE_COUNTER, cpuc->used_mask))
> -			return -EAGAIN;
> -
> -		return ARMV8_IDX_CYCLE_COUNTER;
> +		if (!test_and_set_bit(ARMV8_IDX_CYCLE_COUNTER, cpuc->used_mask))
> +			return ARMV8_IDX_CYCLE_COUNTER;
>  	}
>
>  	/*
> -	 * For anything other than a cycle counter, try and use
> -	 * the events counters
> +	 * Otherwise use events counters
>  	 */
>  	for (idx = ARMV8_IDX_COUNTER0; idx < cpu_pmu->num_events; ++idx) {
>  		if (!test_and_set_bit(idx, cpuc->used_mask))
>

-- 
Pratyush



More information about the linux-arm-kernel mailing list