OSDN Git Service

etnaviv: support performance monitor requests
authorChristian Gmeiner <christian.gmeiner@gmail.com>
Fri, 15 Dec 2017 07:43:40 +0000 (08:43 +0100)
committerChristian Gmeiner <christian.gmeiner@gmail.com>
Fri, 15 Dec 2017 18:10:01 +0000 (19:10 +0100)
Add etna_cmd_stream_perf(..) to submit perform requests.
Userspace can submit pmrs via submit ioctl to sample perfmon
signals.

v3:
 - mark perfmon bos as RW

Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com>
Reviewed-by: Lucas Stach <l.stach@pengutronix.de>
etnaviv/etnaviv-symbol-check
etnaviv/etnaviv_cmd_stream.c
etnaviv/etnaviv_drmif.h
etnaviv/etnaviv_priv.h

index bd95b45..bc50961 100755 (executable)
@@ -41,6 +41,7 @@ etna_cmd_stream_timestamp
 etna_cmd_stream_flush
 etna_cmd_stream_flush2
 etna_cmd_stream_finish
+etna_cmd_stream_perf
 etna_cmd_stream_reloc
 etna_perfmon_create
 etna_perfmon_del
index 8d0e813..e8c58cd 100644 (file)
@@ -105,6 +105,7 @@ void etna_cmd_stream_del(struct etna_cmd_stream *stream)
 
        free(stream->buffer);
        free(priv->submit.relocs);
+       free(priv->submit.pmrs);
        free(priv);
 }
 
@@ -115,6 +116,7 @@ static void reset_buffer(struct etna_cmd_stream *stream)
        stream->offset = 0;
        priv->submit.nr_bos = 0;
        priv->submit.nr_relocs = 0;
+       priv->submit.nr_pmrs = 0;
        priv->nr_bos = 0;
 
        if (priv->reset_notify)
@@ -191,6 +193,8 @@ static void flush(struct etna_cmd_stream *stream, int in_fence_fd,
                .nr_bos = priv->submit.nr_bos,
                .relocs = VOID2U64(priv->submit.relocs),
                .nr_relocs = priv->submit.nr_relocs,
+               .pmrs = VOID2U64(priv->submit.pmrs),
+               .nr_pmrs = priv->submit.nr_pmrs,
                .stream = VOID2U64(stream->buffer),
                .stream_size = stream->offset * 4, /* in bytes */
        };
@@ -260,3 +264,19 @@ void etna_cmd_stream_reloc(struct etna_cmd_stream *stream, const struct etna_rel
 
        etna_cmd_stream_emit(stream, addr);
 }
+
+void etna_cmd_stream_perf(struct etna_cmd_stream *stream, const struct etna_perf *p)
+{
+       struct etna_cmd_stream_priv *priv = etna_cmd_stream_priv(stream);
+       struct drm_etnaviv_gem_submit_pmr *pmr;
+       uint32_t idx = APPEND(&priv->submit, pmrs);
+
+       pmr = &priv->submit.pmrs[idx];
+
+       pmr->flags = p->flags;
+       pmr->sequence = p->sequence;
+       pmr->read_offset = p->offset;
+       pmr->read_idx = bo2idx(stream, p->bo, ETNA_SUBMIT_BO_READ | ETNA_SUBMIT_BO_WRITE);
+       pmr->domain = p->signal->domain->id;
+       pmr->signal = p->signal->signal;
+}
index 949b9b6..5a6bef8 100644 (file)
@@ -201,4 +201,16 @@ void etna_perfmon_del(struct etna_perfmon *perfmon);
 struct etna_perfmon_domain *etna_perfmon_get_dom_by_name(struct etna_perfmon *pm, const char *name);
 struct etna_perfmon_signal *etna_perfmon_get_sig_by_name(struct etna_perfmon_domain *dom, const char *name);
 
+struct etna_perf {
+#define ETNA_PM_PROCESS_PRE             0x0001
+#define ETNA_PM_PROCESS_POST            0x0002
+       uint32_t flags;
+       uint32_t sequence;
+       struct etna_perfmon_signal *signal;
+       struct etna_bo *bo;
+       uint32_t offset;
+};
+
+void etna_cmd_stream_perf(struct etna_cmd_stream *stream, const struct etna_perf *p);
+
 #endif /* ETNAVIV_DRMIF_H_ */
index 7b289b6..e45d364 100644 (file)
@@ -140,6 +140,10 @@ struct etna_cmd_stream_priv {
                /* reloc's table: */
                struct drm_etnaviv_gem_submit_reloc *relocs;
                uint32_t nr_relocs, max_relocs;
+
+               /* perf's table: */
+               struct drm_etnaviv_gem_submit_pmr *pmrs;
+               uint32_t nr_pmrs, max_pmrs;
        } submit;
 
        /* should have matching entries in submit.bos: */