[PATCH v2 3/5] drm/simpledrm: Store xfrm buffer in device instance
Jocelyn Falempe
jfalempe at redhat.com
Tue Sep 26 07:31:22 UTC 2023
On 20/09/2023 16:24, Thomas Zimmermann wrote:
> Store and instance of struct drm_xfrm_buf in struct simpledrm_device
> and keep the allocated memory allocated across display updates. Avoid
> possibly reallocating temporary memory on each display update. Instead
> preallocate temporary memory during initialization. Releasing the DRM
> device also releases the xfrm buffer.
>
> v2:
> * reserve storage during probe
>
> Signed-off-by: Thomas Zimmermann <tzimmermann at suse.de>
> ---
> drivers/gpu/drm/tiny/simpledrm.c | 13 ++++++++++---
> 1 file changed, 10 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/gpu/drm/tiny/simpledrm.c b/drivers/gpu/drm/tiny/simpledrm.c
> index 8aceb7d378dea..a3d8a956a4c4e 100644
> --- a/drivers/gpu/drm/tiny/simpledrm.c
> +++ b/drivers/gpu/drm/tiny/simpledrm.c
> @@ -232,6 +232,7 @@ struct simpledrm_device {
> struct drm_display_mode mode;
> const struct drm_format_info *format;
> unsigned int pitch;
> + struct drm_xfrm_buf xfrm;
>
> /* memory management */
> struct iosys_map screen_base;
> @@ -486,7 +487,6 @@ static void simpledrm_primary_plane_helper_atomic_update(struct drm_plane *plane
> struct drm_framebuffer *fb = plane_state->fb;
> struct drm_device *dev = plane->dev;
> struct simpledrm_device *sdev = simpledrm_device_of_dev(dev);
> - struct drm_xfrm_buf xfrm = DRM_XFRM_BUF_INIT;
> struct drm_atomic_helper_damage_iter iter;
> struct drm_rect damage;
> int ret, idx;
> @@ -508,13 +508,12 @@ static void simpledrm_primary_plane_helper_atomic_update(struct drm_plane *plane
>
> iosys_map_incr(&dst, drm_fb_clip_offset(sdev->pitch, sdev->format, &dst_clip));
> drm_fb_blit(&dst, &sdev->pitch, sdev->format->format, shadow_plane_state->data,
> - fb, &damage, &xfrm);
> + fb, &damage, &sdev->xfrm);
> }
>
> drm_dev_exit(idx);
> out_drm_gem_fb_end_cpu_access:
> drm_gem_fb_end_cpu_access(fb, DMA_FROM_DEVICE);
> - drm_xfrm_buf_release(&xfrm);
> }
>
> static void simpledrm_primary_plane_helper_atomic_disable(struct drm_plane *plane,
> @@ -637,6 +636,7 @@ static struct simpledrm_device *simpledrm_device_create(struct drm_driver *drv,
> struct drm_connector *connector;
> unsigned long max_width, max_height;
> size_t nformats;
> + void *buf;
> int ret;
>
> sdev = devm_drm_dev_alloc(&pdev->dev, drv, struct simpledrm_device, dev);
> @@ -718,6 +718,13 @@ static struct simpledrm_device *simpledrm_device_create(struct drm_driver *drv,
> drm_dbg(dev, "framebuffer format=%p4cc, size=%dx%d, stride=%d byte\n",
> &format->format, width, height, stride);
>
> + ret = drmm_xfrm_buf_init(dev, &sdev->xfrm);
> + if (ret)
> + return ERR_PTR(ret);
> + buf = drm_xfrm_buf_reserve(&sdev->xfrm, sdev->pitch, GFP_KERNEL);
> + if (!buf)
> + return ERR_PTR(-ENOMEM);
> +
I think it would be nice to have a "init_and_reserve()" function, to
simplify the callers ?
> /*
> * Memory management
> */
More information about the dri-devel
mailing list