[PATCH] etnaviv: perfmon: fix total and idle HI cyleces readout
Lucas Stach
l.stach at pengutronix.de
Fri Aug 9 12:11:32 UTC 2019
Am Mittwoch, den 31.07.2019, 23:30 +0200 schrieb Christian Gmeiner:
> As seen at CodeAurora's linux-imx git repo in imx_4.19.35_1.0.0
> branch.
>
> Signed-off-by: Christian Gmeiner <christian.gmeiner at gmail.com>
Thanks, applied.
Regards,
Lucas
> ---
> drivers/gpu/drm/etnaviv/etnaviv_perfmon.c | 44 +++++++++++++++++--
> ----
> 1 file changed, 33 insertions(+), 11 deletions(-)
>
> diff --git a/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
> b/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
> index 06e6d3ee1c34..3c74b1273ea9 100644
> --- a/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
> +++ b/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
> @@ -4,6 +4,7 @@
> * Copyright (C) 2017 Zodiac Inflight Innovations
> */
>
> +#include "common.xml.h"
> #include "etnaviv_gpu.h"
> #include "etnaviv_perfmon.h"
> #include "state_hi.xml.h"
> @@ -35,13 +36,6 @@ struct etnaviv_pm_domain_meta {
> u32 nr_domains;
> };
>
> -static u32 simple_reg_read(struct etnaviv_gpu *gpu,
> - const struct etnaviv_pm_domain *domain,
> - const struct etnaviv_pm_signal *signal)
> -{
> - return gpu_read(gpu, signal->data);
> -}
> -
> static u32 perf_reg_read(struct etnaviv_gpu *gpu,
> const struct etnaviv_pm_domain *domain,
> const struct etnaviv_pm_signal *signal)
> @@ -75,6 +69,34 @@ static u32 pipe_reg_read(struct etnaviv_gpu *gpu,
> return value;
> }
>
> +static u32 hi_total_cycle_read(struct etnaviv_gpu *gpu,
> + const struct etnaviv_pm_domain *domain,
> + const struct etnaviv_pm_signal *signal)
> +{
> + u32 reg = VIVS_HI_PROFILE_TOTAL_CYCLES;
> +
> + if (gpu->identity.model == chipModel_GC880 ||
> + gpu->identity.model == chipModel_GC2000 ||
> + gpu->identity.model == chipModel_GC2100)
> + reg = VIVS_MC_PROFILE_CYCLE_COUNTER;
> +
> + return gpu_read(gpu, reg);
> +}
> +
> +static u32 hi_total_idle_cycle_read(struct etnaviv_gpu *gpu,
> + const struct etnaviv_pm_domain *domain,
> + const struct etnaviv_pm_signal *signal)
> +{
> + u32 reg = VIVS_HI_PROFILE_IDLE_CYCLES;
> +
> + if (gpu->identity.model == chipModel_GC880 ||
> + gpu->identity.model == chipModel_GC2000 ||
> + gpu->identity.model == chipModel_GC2100)
> + reg = VIVS_HI_PROFILE_TOTAL_CYCLES;
> +
> + return gpu_read(gpu, reg);
> +}
> +
> static const struct etnaviv_pm_domain doms_3d[] = {
> {
> .name = "HI",
> @@ -84,13 +106,13 @@ static const struct etnaviv_pm_domain doms_3d[]
> = {
> .signal = (const struct etnaviv_pm_signal[]) {
> {
> "TOTAL_CYCLES",
> - VIVS_HI_PROFILE_TOTAL_CYCLES,
> - &simple_reg_read
> + 0,
> + &hi_total_cycle_read
> },
> {
> "IDLE_CYCLES",
> - VIVS_HI_PROFILE_IDLE_CYCLES,
> - &simple_reg_read
> + 0,
> + &hi_total_idle_cycle_read
> },
> {
> "AXI_CYCLES_READ_REQUEST_STALLED",
More information about the dri-devel
mailing list