提交 846c7dfc 编写于 作者: M Maarten Lankhorst 提交者: Maarten Lankhorst

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: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Cc: Sean Paul <seanpaul@chromium.org>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: NMaarten Lankhorst <maarten.lankhorst@ubuntu.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171101150433.10777-1-maarten.lankhorst@linux.intel.comReviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
上级 79436a1c
...@@ -765,14 +765,18 @@ static int atomic_remove_fb(struct drm_framebuffer *fb) ...@@ -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;
state = drm_atomic_state_alloc(dev); retry_disable:
if (!state)
return -ENOMEM;
drm_modeset_acquire_init(&ctx, 0); drm_modeset_acquire_init(&ctx, 0);
state = drm_atomic_state_alloc(dev);
if (!state) {
ret = -ENOMEM;
goto out;
}
state->acquire_ctx = &ctx; state->acquire_ctx = &ctx;
retry: retry:
...@@ -793,7 +797,7 @@ static int atomic_remove_fb(struct drm_framebuffer *fb) ...@@ -793,7 +797,7 @@ static int atomic_remove_fb(struct drm_framebuffer *fb)
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 @@ static int atomic_remove_fb(struct drm_framebuffer *fb) ...@@ -818,6 +822,7 @@ static int atomic_remove_fb(struct drm_framebuffer *fb)
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 @@ static int atomic_remove_fb(struct drm_framebuffer *fb) ...@@ -840,9 +845,15 @@ static int atomic_remove_fb(struct drm_framebuffer *fb)
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;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册