drm/etnaviv: add performance monitor request processing
authorChristian Gmeiner <christian.gmeiner@gmail.com>
Sun, 24 Sep 2017 13:15:27 +0000 (15:15 +0200)
committerLucas Stach <l.stach@pengutronix.de>
Tue, 10 Oct 2017 09:45:45 +0000 (11:45 +0200)
Changes v4 -> v5
- make use of doms_meta array

Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com>
Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
drivers/gpu/drm/etnaviv/etnaviv_perfmon.h

index 09fbd33764e8dd4be49235fa9168d9dfe45327fe..ba60cb9192c7bcf6f8124ca7ab37f331f5da81df 100644 (file)
@@ -16,6 +16,7 @@
  */
 
 #include "etnaviv_gpu.h"
+#include "etnaviv_perfmon.h"
 
 struct etnaviv_pm_domain;
 
@@ -128,3 +129,19 @@ int etnaviv_pm_req_validate(const struct drm_etnaviv_gem_submit_pmr *r,
 
        return 0;
 }
+
+void etnaviv_perfmon_process(struct etnaviv_gpu *gpu,
+       const struct etnaviv_perfmon_request *pmr)
+{
+       const struct etnaviv_pm_domain_meta *meta = &doms_meta[gpu->exec_state];
+       const struct etnaviv_pm_domain *dom;
+       const struct etnaviv_pm_signal *sig;
+       u32 *bo = pmr->bo_vma;
+       u32 val;
+
+       dom = meta->domains + pmr->domain;
+       sig = &dom->signal[pmr->signal];
+       val = sig->sample(gpu, dom, sig);
+
+       *(bo + pmr->offset) = val;
+}
index 9fcd1fb2e4829746404a333f246423ef139626cc..35dce194cb0042eff1349ba06ae3237515a638bb 100644 (file)
@@ -43,4 +43,7 @@ int etnaviv_pm_query_sig(struct etnaviv_gpu *gpu,
 int etnaviv_pm_req_validate(const struct drm_etnaviv_gem_submit_pmr *r,
        u32 exec_state);
 
+void etnaviv_perfmon_process(struct etnaviv_gpu *gpu,
+       const struct etnaviv_perfmon_request *pmr);
+
 #endif /* __ETNAVIV_PERFMON_H__ */