drm/virtio: Fix handling CONFIG_DRM_VIRTIO_GPU_KMS option
authorDmitry Osipenko <dmitry.osipenko@collabora.com>
Mon, 6 Mar 2023 16:39:16 +0000 (19:39 +0300)
committerDmitry Osipenko <dmitry.osipenko@collabora.com>
Mon, 6 Mar 2023 17:32:17 +0000 (20:32 +0300)
commitaad9729ec0e009440ac8c1a4be2204e4d3c08977
treef4f82bbd6e2ac1a5cf4f14b1570978c3d0e2a6e1
parentbf458e5b139894234444e4f88500616a8398b719
drm/virtio: Fix handling CONFIG_DRM_VIRTIO_GPU_KMS option

VirtIO-GPU got a new config option for disabling KMS. There were two
problems left unnoticed during review when the new option was added:

1. The IS_ENABLED(CONFIG_DRM_VIRTIO_GPU_KMS) check in the code was
inverted, hence KMS was disabled when it should be enabled and vice versa.

2. The disabled KMS crashed kernel with a NULL dereference in
drm_kms_helper_hotplug_event(), which shall not be invoked with a
disabled KMS.

Fix the inverted config option check in the code and skip handling the
VIRTIO_GPU_EVENT_DISPLAY sent by host when KMS is disabled in guest to fix
the crash.

Acked-by: Gerd Hoffmann <kraxel@redhat.com>
Reviewed-by: Emil Velikov <emil.velikov@collabora.com>
Fixes: 72122c69d717 ("drm/virtio: Add option to disable KMS support")
Signed-off-by: Dmitry Osipenko <dmitry.osipenko@collabora.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230306163916.1595961-1-dmitry.osipenko@collabora.com
drivers/gpu/drm/virtio/virtgpu_kms.c