Message ID | 20171212212750.5372-4-christian.gmeiner@gmail.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Am Dienstag, den 12.12.2017, 22:27 +0100 schrieb Christian Gmeiner: > Add etna_cmd_stream_perf(..) to submit perform requests. > Userspace can submit pmrs via submit ioctl to sample perfmon > signals. > > Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com> > --- > etnaviv/etnaviv-symbol-check | 1 + > etnaviv/etnaviv_cmd_stream.c | 20 ++++++++++++++++++++ > etnaviv/etnaviv_drmif.h | 12 ++++++++++++ > etnaviv/etnaviv_priv.h | 4 ++++ > 4 files changed, 37 insertions(+) > > diff --git a/etnaviv/etnaviv-symbol-check b/etnaviv/etnaviv-symbol- > check > index bd95b459..bc509615 100755 > --- a/etnaviv/etnaviv-symbol-check > +++ b/etnaviv/etnaviv-symbol-check > @@ -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 > diff --git a/etnaviv/etnaviv_cmd_stream.c > b/etnaviv/etnaviv_cmd_stream.c > index 8d0e8135..d6f26a88 100644 > --- a/etnaviv/etnaviv_cmd_stream.c > +++ b/etnaviv/etnaviv_cmd_stream.c > @@ -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); This should be BO R/W. While it's not strictly the GPU writing to the buffer, the GPU submit will alter the BO. > + pmr->domain = p->signal->domain->id; > + pmr->signal = p->signal->signal; > +} > diff --git a/etnaviv/etnaviv_drmif.h b/etnaviv/etnaviv_drmif.h > index 949b9b62..5a6bef8d 100644 > --- a/etnaviv/etnaviv_drmif.h > +++ b/etnaviv/etnaviv_drmif.h > @@ -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_ */ > diff --git a/etnaviv/etnaviv_priv.h b/etnaviv/etnaviv_priv.h > index 7b289b61..e45d364c 100644 > --- a/etnaviv/etnaviv_priv.h > +++ b/etnaviv/etnaviv_priv.h > @@ -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; max_pmrs isn't used anywhere AFAICS. > } submit; > > /* should have matching entries in submit.bos: */
Hi Lucas, thanks for review. 2017-12-14 12:48 GMT+01:00 Lucas Stach <l.stach@pengutronix.de>: > Am Dienstag, den 12.12.2017, 22:27 +0100 schrieb Christian Gmeiner: >> Add etna_cmd_stream_perf(..) to submit perform requests. >> Userspace can submit pmrs via submit ioctl to sample perfmon >> signals. >> >> Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com> >> --- >> etnaviv/etnaviv-symbol-check | 1 + >> etnaviv/etnaviv_cmd_stream.c | 20 ++++++++++++++++++++ >> etnaviv/etnaviv_drmif.h | 12 ++++++++++++ >> etnaviv/etnaviv_priv.h | 4 ++++ >> 4 files changed, 37 insertions(+) >> >> diff --git a/etnaviv/etnaviv-symbol-check b/etnaviv/etnaviv-symbol- >> check >> index bd95b459..bc509615 100755 >> --- a/etnaviv/etnaviv-symbol-check >> +++ b/etnaviv/etnaviv-symbol-check >> @@ -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 >> diff --git a/etnaviv/etnaviv_cmd_stream.c >> b/etnaviv/etnaviv_cmd_stream.c >> index 8d0e8135..d6f26a88 100644 >> --- a/etnaviv/etnaviv_cmd_stream.c >> +++ b/etnaviv/etnaviv_cmd_stream.c >> @@ -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); > > This should be BO R/W. While it's not strictly the GPU writing to the > buffer, the GPU submit will alter the BO. > Makes sense - will be changed in v3. >> + pmr->domain = p->signal->domain->id; >> + pmr->signal = p->signal->signal; >> +} >> diff --git a/etnaviv/etnaviv_drmif.h b/etnaviv/etnaviv_drmif.h >> index 949b9b62..5a6bef8d 100644 >> --- a/etnaviv/etnaviv_drmif.h >> +++ b/etnaviv/etnaviv_drmif.h >> @@ -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_ */ >> diff --git a/etnaviv/etnaviv_priv.h b/etnaviv/etnaviv_priv.h >> index 7b289b61..e45d364c 100644 >> --- a/etnaviv/etnaviv_priv.h >> +++ b/etnaviv/etnaviv_priv.h >> @@ -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; > > max_pmrs isn't used anywhere AFAICS. There is a macro used called APPEND: #define APPEND(x, name) ({ \ (x)->name = grow((x)->name, (x)->nr_ ## name, &(x)->max_ ## name, sizeof((x)->name[0])); \ (x)->nr_ ## name ++; \ }) And here you will find the usage of max_pmrs :) > >> } submit; >> >> /* should have matching entries in submit.bos: */
diff --git a/etnaviv/etnaviv-symbol-check b/etnaviv/etnaviv-symbol-check index bd95b459..bc509615 100755 --- a/etnaviv/etnaviv-symbol-check +++ b/etnaviv/etnaviv-symbol-check @@ -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 diff --git a/etnaviv/etnaviv_cmd_stream.c b/etnaviv/etnaviv_cmd_stream.c index 8d0e8135..d6f26a88 100644 --- a/etnaviv/etnaviv_cmd_stream.c +++ b/etnaviv/etnaviv_cmd_stream.c @@ -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); + pmr->domain = p->signal->domain->id; + pmr->signal = p->signal->signal; +} diff --git a/etnaviv/etnaviv_drmif.h b/etnaviv/etnaviv_drmif.h index 949b9b62..5a6bef8d 100644 --- a/etnaviv/etnaviv_drmif.h +++ b/etnaviv/etnaviv_drmif.h @@ -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_ */ diff --git a/etnaviv/etnaviv_priv.h b/etnaviv/etnaviv_priv.h index 7b289b61..e45d364c 100644 --- a/etnaviv/etnaviv_priv.h +++ b/etnaviv/etnaviv_priv.h @@ -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: */
Add etna_cmd_stream_perf(..) to submit perform requests. Userspace can submit pmrs via submit ioctl to sample perfmon signals. Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com> --- etnaviv/etnaviv-symbol-check | 1 + etnaviv/etnaviv_cmd_stream.c | 20 ++++++++++++++++++++ etnaviv/etnaviv_drmif.h | 12 ++++++++++++ etnaviv/etnaviv_priv.h | 4 ++++ 4 files changed, 37 insertions(+)