[PATCH 10/27] drm/etnaviv: remove switch_context member from etnaviv_gpu
Christian Gmeiner
christian.gmeiner at gmail.com
Mon Dec 11 10:51:12 UTC 2017
2017-12-01 11:36 GMT+01:00 Lucas Stach <l.stach at pengutronix.de>:
> There is no need to store this in the gpu struct. MMU flushes are triggered
> correctly in reaction to MMU maps and unmaps, independent of the current ctx
> and required pipe switches can be infered from the current and the desired
> GPU exec state.
>
> Signed-off-by: Lucas Stach <l.stach at pengutronix.de>
Reviewed-by: Christian Gmeiner <christian.gmeiner at gmail.com>
> ---
> drivers/gpu/drm/etnaviv/etnaviv_buffer.c | 10 ++++++----
> drivers/gpu/drm/etnaviv/etnaviv_gpu.c | 8 +-------
> drivers/gpu/drm/etnaviv/etnaviv_gpu.h | 1 -
> 3 files changed, 7 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/gpu/drm/etnaviv/etnaviv_buffer.c b/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
> index 9e7098e3207f..6ad8972a59cc 100644
> --- a/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
> +++ b/drivers/gpu/drm/etnaviv/etnaviv_buffer.c
> @@ -294,6 +294,7 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
> unsigned int waitlink_offset = buffer->user_size - 16;
> u32 return_target, return_dwords;
> u32 link_target, link_dwords;
> + bool switch_context = gpu->exec_state != cmdbuf->exec_state;
>
> if (drm_debug & DRM_UT_DRIVER)
> etnaviv_buffer_dump(gpu, buffer, 0, 0x50);
> @@ -306,7 +307,7 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
> * need to append a mmu flush load state, followed by a new
> * link to this buffer - a total of four additional words.
> */
> - if (gpu->mmu->need_flush || gpu->switch_context) {
> + if (gpu->mmu->need_flush || switch_context) {
> u32 target, extra_dwords;
>
> /* link command */
> @@ -321,7 +322,7 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
> }
>
> /* pipe switch commands */
> - if (gpu->switch_context)
> + if (switch_context)
> extra_dwords += 4;
>
> target = etnaviv_buffer_reserve(gpu, buffer, extra_dwords);
> @@ -349,10 +350,9 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
> gpu->mmu->need_flush = false;
> }
>
> - if (gpu->switch_context) {
> + if (switch_context) {
> etnaviv_cmd_select_pipe(gpu, buffer, cmdbuf->exec_state);
> gpu->exec_state = cmdbuf->exec_state;
> - gpu->switch_context = false;
> }
>
> /* And the link to the submitted buffer */
> @@ -421,4 +421,6 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, unsigned int event,
>
> if (drm_debug & DRM_UT_DRIVER)
> etnaviv_buffer_dump(gpu, buffer, 0, 0x50);
> +
> + gpu->lastctx = cmdbuf->ctx;
> }
> diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
> index ae152bb78f18..65eaa8c10ba2 100644
> --- a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
> +++ b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
> @@ -1416,12 +1416,6 @@ int etnaviv_gpu_submit(struct etnaviv_gpu *gpu,
> submit->fence = dma_fence_get(fence);
> gpu->active_fence = submit->fence->seqno;
>
> - if (gpu->lastctx != cmdbuf->ctx) {
> - gpu->mmu->need_flush = true;
> - gpu->switch_context = true;
> - gpu->lastctx = cmdbuf->ctx;
> - }
> -
> if (cmdbuf->nr_pmrs) {
> gpu->event[event[1]].sync_point = &sync_point_perfmon_sample_pre;
> gpu->event[event[1]].cmdbuf = cmdbuf;
> @@ -1662,7 +1656,7 @@ static int etnaviv_gpu_hw_resume(struct etnaviv_gpu *gpu)
> etnaviv_gpu_update_clock(gpu);
> etnaviv_gpu_hw_init(gpu);
>
> - gpu->switch_context = true;
> + gpu->lastctx = NULL;
> gpu->exec_state = -1;
>
> mutex_unlock(&gpu->lock);
> diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gpu.h b/drivers/gpu/drm/etnaviv/etnaviv_gpu.h
> index 4f10f147297a..15090bb68f5a 100644
> --- a/drivers/gpu/drm/etnaviv/etnaviv_gpu.h
> +++ b/drivers/gpu/drm/etnaviv/etnaviv_gpu.h
> @@ -106,7 +106,6 @@ struct etnaviv_gpu {
> struct mutex lock;
> struct etnaviv_chip_identity identity;
> struct etnaviv_file_private *lastctx;
> - bool switch_context;
>
> /* 'ring'-buffer: */
> struct etnaviv_cmdbuf *buffer;
> --
> 2.11.0
>
> _______________________________________________
> etnaviv mailing list
> etnaviv at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/etnaviv
--
greets
--
Christian Gmeiner, MSc
https://christian-gmeiner.info
More information about the dri-devel
mailing list