From f4cf0a8d866be532693e1f8c660ae9a1c2560187 Mon Sep 17 00:00:00 2001 From: Simon Ser Date: Mon, 3 Oct 2022 12:21:36 +0200 Subject: backend/drm: nuke wlr_drm_connector.desired_enabled This field becomes stale too easily: for instance, see 6adca4089cf4 ("backend/drm: don't unconditionally set desired_enabled"). Additionally, drm_connector_alloc_crtc() needs to do some weird dance, restoring its previous value. Instead, add a connector arg to realloc_crtcs() to indicate a new connector we want to enable. --- backend/drm/drm.c | 43 ++++++++++++++++++------------------------- include/backend/drm/drm.h | 1 - 2 files changed, 18 insertions(+), 26 deletions(-) diff --git a/backend/drm/drm.c b/backend/drm/drm.c index 5f9ed8bc..5e614d86 100644 --- a/backend/drm/drm.c +++ b/backend/drm/drm.c @@ -663,18 +663,13 @@ struct wlr_drm_fb *plane_get_next_fb(struct wlr_drm_plane *plane) { return plane->current_fb; } -static void realloc_crtcs(struct wlr_drm_backend *drm); +static void realloc_crtcs(struct wlr_drm_backend *drm, + struct wlr_drm_connector *want_conn); static bool drm_connector_alloc_crtc(struct wlr_drm_connector *conn) { - if (conn->crtc != NULL) { - return true; + if (conn->crtc == NULL) { + realloc_crtcs(conn->backend, conn); } - - bool prev_desired_enabled = conn->desired_enabled; - conn->desired_enabled = true; - realloc_crtcs(conn->backend); - conn->desired_enabled = prev_desired_enabled; - return conn->crtc != NULL; } @@ -699,8 +694,6 @@ static bool drm_connector_set_mode(struct wlr_drm_connector *conn, } } - conn->desired_enabled = wlr_mode != NULL; - if (wlr_mode == NULL) { if (conn->crtc != NULL) { if (!drm_crtc_commit(conn, state, 0, false)) { @@ -740,7 +733,6 @@ static bool drm_connector_set_mode(struct wlr_drm_connector *conn, wlr_output_update_mode(&conn->output, wlr_mode); wlr_output_update_enabled(&conn->output, true); - conn->desired_enabled = true; // When switching VTs, the mode is not updated but the buffers become // invalid, so we need to manually damage the output here @@ -924,7 +916,6 @@ static void drm_connector_destroy_output(struct wlr_output *output) { dealloc_crtc(conn); conn->status = DRM_MODE_DISCONNECTED; - conn->desired_enabled = false; conn->possible_crtcs = 0; conn->pending_page_flip_crtc = 0; @@ -1068,7 +1059,8 @@ static void dealloc_crtc(struct wlr_drm_connector *conn) { conn->crtc = NULL; } -static void realloc_crtcs(struct wlr_drm_backend *drm) { +static void realloc_crtcs(struct wlr_drm_backend *drm, + struct wlr_drm_connector *want_conn) { assert(drm->num_crtcs > 0); size_t num_outputs = wl_list_length(&drm->outputs); @@ -1093,17 +1085,19 @@ static void realloc_crtcs(struct wlr_drm_backend *drm) { wl_list_for_each(conn, &drm->outputs, link) { connectors[i] = conn; - wlr_log(WLR_DEBUG, " '%s' crtc=%d status=%d desired_enabled=%d", - conn->name, conn->crtc ? (int)(conn->crtc - drm->crtcs) : -1, - conn->status, conn->desired_enabled); - if (conn->crtc) { previous_match[conn->crtc - drm->crtcs] = i; } - // Only search CRTCs for user-enabled outputs (that are already - // connected or in need of a modeset) - if (conn->status == DRM_MODE_CONNECTED && conn->desired_enabled) { + // Only request a CRTC if the connected is currently enabled or it's the + // connector the user wants to enable + bool want_crtc = conn == want_conn || conn->output.enabled; + + wlr_log(WLR_DEBUG, " '%s' crtc=%d status=%d want_crtc=%d", + conn->name, conn->crtc ? (int)(conn->crtc - drm->crtcs) : -1, + conn->status, want_crtc); + + if (conn->status == DRM_MODE_CONNECTED && want_crtc) { connector_constraints[i] = conn->possible_crtcs; } else { // Will always fail to match anything @@ -1148,8 +1142,8 @@ static void realloc_crtcs(struct wlr_drm_backend *drm) { struct wlr_drm_connector *conn = connectors[i]; bool prev_enabled = conn->crtc; - wlr_log(WLR_DEBUG, " '%s' crtc=%zd status=%d desired_enabled=%d", - conn->name, connector_match[i], conn->status, conn->desired_enabled); + wlr_log(WLR_DEBUG, " '%s' crtc=%zd status=%d", + conn->name, connector_match[i], conn->status); // We don't need to change anything. if (prev_enabled && connector_match[i] == conn->crtc - drm->crtcs) { @@ -1422,7 +1416,6 @@ void scan_drm_connectors(struct wlr_drm_backend *drm, } wlr_output_update_enabled(&wlr_conn->output, wlr_conn->crtc != NULL); - wlr_conn->desired_enabled = wlr_conn->crtc != NULL; wlr_conn->status = DRM_MODE_CONNECTED; new_outputs[new_outputs_len++] = wlr_conn; @@ -1452,7 +1445,7 @@ void scan_drm_connectors(struct wlr_drm_backend *drm, destroy_drm_connector(conn); } - realloc_crtcs(drm); + realloc_crtcs(drm, NULL); for (size_t i = 0; i < new_outputs_len; ++i) { struct wlr_drm_connector *conn = new_outputs[i]; diff --git a/include/backend/drm/drm.h b/include/backend/drm/drm.h index f362f18a..27c131de 100644 --- a/include/backend/drm/drm.h +++ b/include/backend/drm/drm.h @@ -108,7 +108,6 @@ struct wlr_drm_connector { struct wlr_drm_backend *backend; char name[24]; drmModeConnection status; - bool desired_enabled; uint32_t id; uint64_t max_bpc; struct wlr_drm_lease *lease; -- cgit v1.2.3