[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <8bfce982-b22a-4ef3-b79e-5e22a3364c5a@redhat.com>
Date: Tue, 27 May 2025 10:11:49 +0200
From: Jocelyn Falempe <jfalempe@...hat.com>
To: Ryosuke Yasuoka <ryasuoka@...hat.com>, drawat.floss@...il.com,
maarten.lankhorst@...ux.intel.com, mripard@...nel.org, tzimmermann@...e.de,
airlied@...il.com, simona@...ll.ch
Cc: linux-hyperv@...r.kernel.org, linux-kernel@...r.kernel.org,
dri-devel@...ts.freedesktop.org
Subject: Re: [PATCH RFC drm-misc-next v2 1/1] drm/hyperv: Add support for
drm_panic
On 26/05/2025 11:01, Ryosuke Yasuoka wrote:
> Add drm_panic module for hyperv drm so that panic screen can be
> displayed on panic.
Thanks, it looks good to me.
Reviewed-by: Jocelyn Falempe <jfalempe@...hat.com>
>
> Signed-off-by: Ryosuke Yasuoka <ryasuoka@...hat.com>
> ---
> drivers/gpu/drm/hyperv/hyperv_drm_modeset.c | 36 +++++++++++++++++++++
> 1 file changed, 36 insertions(+)
>
> diff --git a/drivers/gpu/drm/hyperv/hyperv_drm_modeset.c b/drivers/gpu/drm/hyperv/hyperv_drm_modeset.c
> index f7d2e973f79e..945b9482bcb3 100644
> --- a/drivers/gpu/drm/hyperv/hyperv_drm_modeset.c
> +++ b/drivers/gpu/drm/hyperv/hyperv_drm_modeset.c
> @@ -17,6 +17,7 @@
> #include <drm/drm_gem_framebuffer_helper.h>
> #include <drm/drm_gem_shmem_helper.h>
> #include <drm/drm_probe_helper.h>
> +#include <drm/drm_panic.h>
> #include <drm/drm_plane.h>
>
> #include "hyperv_drm.h"
> @@ -181,10 +182,45 @@ static void hyperv_plane_atomic_update(struct drm_plane *plane,
> }
> }
>
> +static int hyperv_plane_get_scanout_buffer(struct drm_plane *plane,
> + struct drm_scanout_buffer *sb)
> +{
> + struct hyperv_drm_device *hv = to_hv(plane->dev);
> + struct iosys_map map = IOSYS_MAP_INIT_VADDR_IOMEM(hv->vram);
> +
> + if (plane->state && plane->state->fb) {
> + sb->format = plane->state->fb->format;
> + sb->width = plane->state->fb->width;
> + sb->height = plane->state->fb->height;
> + sb->pitch[0] = plane->state->fb->pitches[0];
> + sb->map[0] = map;
> + return 0;
> + }
> + return -ENODEV;
> +}
> +
> +static void hyperv_plane_panic_flush(struct drm_plane *plane)
> +{
> + struct hyperv_drm_device *hv = to_hv(plane->dev);
> + struct drm_rect rect;
> +
> + if (!plane->state || !plane->state->fb)
> + return;
> +
> + rect.x1 = 0;
> + rect.y1 = 0;
> + rect.x2 = plane->state->fb->width;
> + rect.y2 = plane->state->fb->height;
> +
> + hyperv_update_dirt(hv->hdev, &rect);
> +}
> +
> static const struct drm_plane_helper_funcs hyperv_plane_helper_funcs = {
> DRM_GEM_SHADOW_PLANE_HELPER_FUNCS,
> .atomic_check = hyperv_plane_atomic_check,
> .atomic_update = hyperv_plane_atomic_update,
> + .get_scanout_buffer = hyperv_plane_get_scanout_buffer,
> + .panic_flush = hyperv_plane_panic_flush,
> };
>
> static const struct drm_plane_funcs hyperv_plane_funcs = {
Powered by blists - more mailing lists