diff options
author | emersion <contact@emersion.fr> | 2018-04-18 00:15:25 +0100 |
---|---|---|
committer | emersion <contact@emersion.fr> | 2018-04-18 00:15:25 +0100 |
commit | 94fa6c88f4eb956c75fce6c65acb335f4f9a4a07 (patch) | |
tree | b0f9b29ccd0aa4b6dba625436872e9d79fb67bed /backend/drm | |
parent | 63763d327969a17af43ccaf8fe4c6da941f8efcb (diff) |
output: don't emit the mode event if it hasn't changed
This also fixes #535.
Diffstat (limited to 'backend/drm')
-rw-r--r-- | backend/drm/drm.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/backend/drm/drm.c b/backend/drm/drm.c index 187db368..fcc435e6 100644 --- a/backend/drm/drm.c +++ b/backend/drm/drm.c @@ -496,11 +496,15 @@ static bool wlr_drm_connector_set_mode(struct wlr_output *output, conn->state = WLR_DRM_CONN_CONNECTED; wlr_output_update_mode(&conn->output, mode); + // When switching VTs, the mode is not updated but the buffers become + // invalid, so we need to manually damage the output here + wlr_output_damage_whole(&conn->output); + // Since realloc_crtcs can deallocate planes on OTHER outputs, - // we actually need to reinitialize any than has changed + // we actually need to reinitialize any that has changed ssize_t output_index = -1; wl_list_for_each(conn, &drm->outputs, link) { - output_index += 1; + output_index++; struct wlr_output_mode *mode = conn->output.current_mode; struct wlr_drm_crtc *crtc = conn->crtc; |