aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/virtio/virtgpu_kms.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/virtio/virtgpu_kms.c')
-rw-r--r--drivers/gpu/drm/virtio/virtgpu_kms.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/gpu/drm/virtio/virtgpu_kms.c b/drivers/gpu/drm/virtio/virtgpu_kms.c
index 691b842d5f3a..3af6181c05a8 100644
--- a/drivers/gpu/drm/virtio/virtgpu_kms.c
+++ b/drivers/gpu/drm/virtio/virtgpu_kms.c
@@ -44,6 +44,8 @@ static void virtio_gpu_config_changed_work_func(struct work_struct *work)
44 virtio_cread(vgdev->vdev, struct virtio_gpu_config, 44 virtio_cread(vgdev->vdev, struct virtio_gpu_config,
45 events_read, &events_read); 45 events_read, &events_read);
46 if (events_read & VIRTIO_GPU_EVENT_DISPLAY) { 46 if (events_read & VIRTIO_GPU_EVENT_DISPLAY) {
47 if (vgdev->has_edid)
48 virtio_gpu_cmd_get_edids(vgdev);
47 virtio_gpu_cmd_get_display_info(vgdev); 49 virtio_gpu_cmd_get_display_info(vgdev);
48 drm_helper_hpd_irq_event(vgdev->ddev); 50 drm_helper_hpd_irq_event(vgdev->ddev);
49 events_clear |= VIRTIO_GPU_EVENT_DISPLAY; 51 events_clear |= VIRTIO_GPU_EVENT_DISPLAY;
@@ -156,6 +158,10 @@ int virtio_gpu_driver_load(struct drm_device *dev, unsigned long flags)
156#else 158#else
157 DRM_INFO("virgl 3d acceleration not supported by guest\n"); 159 DRM_INFO("virgl 3d acceleration not supported by guest\n");
158#endif 160#endif
161 if (virtio_has_feature(vgdev->vdev, VIRTIO_GPU_F_EDID)) {
162 vgdev->has_edid = true;
163 DRM_INFO("EDID support available.\n");
164 }
159 165
160 ret = virtio_find_vqs(vgdev->vdev, 2, vqs, callbacks, names, NULL); 166 ret = virtio_find_vqs(vgdev->vdev, 2, vqs, callbacks, names, NULL);
161 if (ret) { 167 if (ret) {
@@ -201,6 +207,8 @@ int virtio_gpu_driver_load(struct drm_device *dev, unsigned long flags)
201 207
202 if (num_capsets) 208 if (num_capsets)
203 virtio_gpu_get_capsets(vgdev, num_capsets); 209 virtio_gpu_get_capsets(vgdev, num_capsets);
210 if (vgdev->has_edid)
211 virtio_gpu_cmd_get_edids(vgdev);
204 virtio_gpu_cmd_get_display_info(vgdev); 212 virtio_gpu_cmd_get_display_info(vgdev);
205 wait_event_timeout(vgdev->resp_wq, !vgdev->display_info_pending, 213 wait_event_timeout(vgdev->resp_wq, !vgdev->display_info_pending,
206 5 * HZ); 214 5 * HZ);