mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	drm/atomic: Try to preserve the crtc enabled state in drm_atomic_remove_fb, v2.
This introduces a slight behavioral change to rmfb. Instead of disabling a crtc when the primary plane is disabled, we try to preserve it. Apart from old versions of the vmwgfx xorg driver, there is nothing depending on rmfb disabling a crtc. Vmwgfx' and simple kms helper atomic implementation rejects CRTC enabled without plane, so we can do this safely. If the atomic commit is rejected by the driver then we will still fall back to the old behavior and turn off the crtc. Changes since v1: - Restart completely when rmfb with crtc on fails (Sean Paul). Signed-off-by: Maarten Lankhorst <maarten.lankhorst@linux.intel.com> Cc: Sean Paul <seanpaul@chromium.org> Cc: Daniel Vetter <daniel.vetter@ffwll.ch> Signed-off-by: Maarten Lankhorst <maarten.lankhorst@ubuntu.com> Link: https://patchwork.freedesktop.org/patch/msgid/20171101150433.10777-1-maarten.lankhorst@linux.intel.com Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
		
							parent
							
								
									79436a1c9b
								
							
						
					
					
						commit
						846c7dfc11
					
				| @ -765,14 +765,18 @@ static int atomic_remove_fb(struct drm_framebuffer *fb) | |||||||
| 	struct drm_plane *plane; | 	struct drm_plane *plane; | ||||||
| 	struct drm_connector *conn; | 	struct drm_connector *conn; | ||||||
| 	struct drm_connector_state *conn_state; | 	struct drm_connector_state *conn_state; | ||||||
| 	int i, ret = 0; | 	int i, ret; | ||||||
| 	unsigned plane_mask; | 	unsigned plane_mask; | ||||||
|  | 	bool disable_crtcs = false; | ||||||
|  | 
 | ||||||
|  | retry_disable: | ||||||
|  | 	drm_modeset_acquire_init(&ctx, 0); | ||||||
| 
 | 
 | ||||||
| 	state = drm_atomic_state_alloc(dev); | 	state = drm_atomic_state_alloc(dev); | ||||||
| 	if (!state) | 	if (!state) { | ||||||
| 		return -ENOMEM; | 		ret = -ENOMEM; | ||||||
| 
 | 		goto out; | ||||||
| 	drm_modeset_acquire_init(&ctx, 0); | 	} | ||||||
| 	state->acquire_ctx = &ctx; | 	state->acquire_ctx = &ctx; | ||||||
| 
 | 
 | ||||||
| retry: | retry: | ||||||
| @ -793,7 +797,7 @@ retry: | |||||||
| 			goto unlock; | 			goto unlock; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (plane_state->crtc->primary == plane) { | 		if (disable_crtcs && plane_state->crtc->primary == plane) { | ||||||
| 			struct drm_crtc_state *crtc_state; | 			struct drm_crtc_state *crtc_state; | ||||||
| 
 | 
 | ||||||
| 			crtc_state = drm_atomic_get_existing_crtc_state(state, plane_state->crtc); | 			crtc_state = drm_atomic_get_existing_crtc_state(state, plane_state->crtc); | ||||||
| @ -818,6 +822,7 @@ retry: | |||||||
| 		plane->old_fb = plane->fb; | 		plane->old_fb = plane->fb; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	/* This list is only filled when disable_crtcs is set. */ | ||||||
| 	for_each_new_connector_in_state(state, conn, conn_state, i) { | 	for_each_new_connector_in_state(state, conn, conn_state, i) { | ||||||
| 		ret = drm_atomic_set_crtc_for_connector(conn_state, NULL); | 		ret = drm_atomic_set_crtc_for_connector(conn_state, NULL); | ||||||
| 
 | 
 | ||||||
| @ -840,9 +845,15 @@ unlock: | |||||||
| 
 | 
 | ||||||
| 	drm_atomic_state_put(state); | 	drm_atomic_state_put(state); | ||||||
| 
 | 
 | ||||||
|  | out: | ||||||
| 	drm_modeset_drop_locks(&ctx); | 	drm_modeset_drop_locks(&ctx); | ||||||
| 	drm_modeset_acquire_fini(&ctx); | 	drm_modeset_acquire_fini(&ctx); | ||||||
| 
 | 
 | ||||||
|  | 	if (ret == -EINVAL && !disable_crtcs) { | ||||||
|  | 		disable_crtcs = true; | ||||||
|  | 		goto retry_disable; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	return ret; | 	return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Maarten Lankhorst
						Maarten Lankhorst