diff options
| author | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
| commit | 1ac731c529cd4d6adbce134754b51ff7d822b145 (patch) | |
| tree | 143ab3f35ca5f3b69f583c84e6964b17139c2ec1 /drivers/gpu/drm/virtio/virtgpu_kms.c | |
| parent | 07b4c950f27bef0362dc6ad7ee713aab61d58149 (diff) | |
| parent | 54116d442e001e1b6bd482122043b1870998a1f3 (diff) | |
Merge branch 'next' into for-linus
Prepare input updates for 6.6 merge window.
Diffstat (limited to 'drivers/gpu/drm/virtio/virtgpu_kms.c')
| -rw-r--r-- | drivers/gpu/drm/virtio/virtgpu_kms.c | 39 | 
1 files changed, 23 insertions, 16 deletions
diff --git a/drivers/gpu/drm/virtio/virtgpu_kms.c b/drivers/gpu/drm/virtio/virtgpu_kms.c index 27b7f14dae89..5a3b5aaed1f3 100644 --- a/drivers/gpu/drm/virtio/virtgpu_kms.c +++ b/drivers/gpu/drm/virtio/virtgpu_kms.c @@ -43,11 +43,13 @@ static void virtio_gpu_config_changed_work_func(struct work_struct *work)  	virtio_cread_le(vgdev->vdev, struct virtio_gpu_config,  			events_read, &events_read);  	if (events_read & VIRTIO_GPU_EVENT_DISPLAY) { -		if (vgdev->has_edid) -			virtio_gpu_cmd_get_edids(vgdev); -		virtio_gpu_cmd_get_display_info(vgdev); -		virtio_gpu_notify(vgdev); -		drm_helper_hpd_irq_event(vgdev->ddev); +		if (vgdev->num_scanouts) { +			if (vgdev->has_edid) +				virtio_gpu_cmd_get_edids(vgdev); +			virtio_gpu_cmd_get_display_info(vgdev); +			virtio_gpu_notify(vgdev); +			drm_helper_hpd_irq_event(vgdev->ddev); +		}  		events_clear |= VIRTIO_GPU_EVENT_DISPLAY;  	}  	virtio_cwrite_le(vgdev->vdev, struct virtio_gpu_config, @@ -223,12 +225,15 @@ int virtio_gpu_init(struct virtio_device *vdev, struct drm_device *dev)  			num_scanouts, &num_scanouts);  	vgdev->num_scanouts = min_t(uint32_t, num_scanouts,  				    VIRTIO_GPU_MAX_SCANOUTS); -	if (!vgdev->num_scanouts) { -		DRM_ERROR("num_scanouts is zero\n"); -		ret = -EINVAL; -		goto err_scanouts; + +	if (!IS_ENABLED(CONFIG_DRM_VIRTIO_GPU_KMS) || !vgdev->num_scanouts) { +		DRM_INFO("KMS disabled\n"); +		vgdev->num_scanouts = 0; +		vgdev->has_edid = false; +		dev->driver_features &= ~(DRIVER_MODESET | DRIVER_ATOMIC); +	} else { +		DRM_INFO("number of scanouts: %d\n", num_scanouts);  	} -	DRM_INFO("number of scanouts: %d\n", num_scanouts);  	virtio_cread_le(vgdev->vdev, struct virtio_gpu_config,  			num_capsets, &num_capsets); @@ -244,12 +249,14 @@ int virtio_gpu_init(struct virtio_device *vdev, struct drm_device *dev)  	if (num_capsets)  		virtio_gpu_get_capsets(vgdev, num_capsets); -	if (vgdev->has_edid) -		virtio_gpu_cmd_get_edids(vgdev); -	virtio_gpu_cmd_get_display_info(vgdev); -	virtio_gpu_notify(vgdev); -	wait_event_timeout(vgdev->resp_wq, !vgdev->display_info_pending, -			   5 * HZ); +	if (vgdev->num_scanouts) { +		if (vgdev->has_edid) +			virtio_gpu_cmd_get_edids(vgdev); +		virtio_gpu_cmd_get_display_info(vgdev); +		virtio_gpu_notify(vgdev); +		wait_event_timeout(vgdev->resp_wq, !vgdev->display_info_pending, +				   5 * HZ); +	}  	return 0;  err_scanouts:  |