summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
diff options
context:
space:
mode:
authorChristian Gmeiner2017-09-24 15:15:27 +0200
committerLucas Stach2017-10-10 11:45:45 +0200
commit249300c740e5bf2b48425e6f0cccc63964a35892 (patch)
tree002f0cc07f98c9ea69ec3836a5b7c8937ee881f9 /drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
parentdrm/etnaviv: copy pmrs from userspace (diff)
downloadkernel-qcow2-linux-249300c740e5bf2b48425e6f0cccc63964a35892.tar.gz
kernel-qcow2-linux-249300c740e5bf2b48425e6f0cccc63964a35892.tar.xz
kernel-qcow2-linux-249300c740e5bf2b48425e6f0cccc63964a35892.zip
drm/etnaviv: add performance monitor request processing
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>
Diffstat (limited to 'drivers/gpu/drm/etnaviv/etnaviv_perfmon.c')
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_perfmon.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c b/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
index 09fbd33764e8..ba60cb9192c7 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_perfmon.c
@@ -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;
+}