[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <a48864f2-ff81-4b03-9de7-3d4959a9b301@collabora.com>
Date: Wed, 16 Apr 2025 10:02:15 +0300
From: Dmitry Osipenko <dmitry.osipenko@...labora.com>
To: Ryosuke Yasuoka <ryasuoka@...hat.com>, airlied@...hat.com,
kraxel@...hat.com, gurchetansingh@...omium.org, olvaffe@...il.com,
maarten.lankhorst@...ux.intel.com, mripard@...nel.org, tzimmermann@...e.de,
simona@...ll.ch, jfalempe@...hat.com
Cc: virtualization@...ts.linux.dev, linux-kernel@...r.kernel.org,
dri-devel@...ts.freedesktop.org
Subject: Re: [PATCH] drm/virtio: Support drm_panic with non-vmapped shmem BO
On 4/12/25 16:20, Ryosuke Yasuoka wrote:
> Pass array of pages of the scanout buffer [1] to shmem BO, allowing
> drm_panic to work even if the BO is not vmapped.
>
> [1] https://lore.kernel.org/all/20250407140138.162383-3-jfalempe@redhat.com/
>
> Signed-off-by: Jocelyn Falempe <jfalempe@...hat.com>
> Signed-off-by: Ryosuke Yasuoka <ryasuoka@...hat.com>
> ---
> drivers/gpu/drm/virtio/virtgpu_plane.c | 14 +++++++++++---
> 1 file changed, 11 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/gpu/drm/virtio/virtgpu_plane.c b/drivers/gpu/drm/virtio/virtgpu_plane.c
> index a6f5a78f436a..2ff57d559c86 100644
> --- a/drivers/gpu/drm/virtio/virtgpu_plane.c
> +++ b/drivers/gpu/drm/virtio/virtgpu_plane.c
> @@ -500,11 +500,19 @@ static int virtio_drm_get_scanout_buffer(struct drm_plane *plane,
>
> bo = gem_to_virtio_gpu_obj(plane->state->fb->obj[0]);
>
> - /* Only support mapped shmem bo */
> - if (virtio_gpu_is_vram(bo) || bo->base.base.import_attach || !bo->base.vaddr)
> + if (virtio_gpu_is_vram(bo) || bo->base.base.import_attach)
> return -ENODEV;
>
> - iosys_map_set_vaddr(&sb->map[0], bo->base.vaddr);
> + if (bo->base.vaddr)
> + iosys_map_set_vaddr(&sb->map[0], bo->base.vaddr);
> + else {
> + struct drm_gem_shmem_object *shmem = &bo->base;
> +
> + if (!shmem->pages)
> + return -ENODEV;
> + /* map scanout buffer later */
> + sb->pages = shmem->pages;
> + }
>
> sb->format = plane->state->fb->format;
> sb->height = plane->state->fb->height;
>
> base-commit: e7bb7d44c3b97aea1f0e354c6499900154ac67f2
Works well!
Reviewed-by: Dmitry Osipenko <dmitry.osipenko@...labora.com>
Tested-by: Dmitry Osipenko <dmitry.osipenko@...labora.com>
--
Best regards,
Dmitry
Powered by blists - more mailing lists