mirror of
https://github.com/swaywm/sway.git
synced 2024-11-29 11:21:28 +00:00
desktop/output: Stop repaint loop when not needed
1e0031781f
refactored repaint to accumulate all changes in a single wlr_output_state and commit them at the end of the repaint loop, replacing a call to wlr_scene_output_commit. wlr_scene_output_commit contains an early bail-out when no frame has been requested and no damage has accumulated, which was not replicated as part of this refactor, causing the repaint loop to never pause. Replicate the logic to stop the repaint loop as needed. Fixes:1e0031781f
("desktop/output: unify page-flip codepath") (cherry picked from commit3f327b3db0
)
This commit is contained in:
parent
6320aef295
commit
19ca790a9f
|
@ -247,6 +247,13 @@ static int output_repaint_timer_handler(void *data) {
|
||||||
.color_transform = output->color_transform,
|
.color_transform = output->color_transform,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct wlr_output *wlr_output = output->wlr_output;
|
||||||
|
struct wlr_scene_output *scene_output = output->scene_output;
|
||||||
|
if (!wlr_output->needs_frame && !output->gamma_lut_changed &&
|
||||||
|
!pixman_region32_not_empty(&scene_output->pending_commit_damage)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
struct wlr_output_state pending;
|
struct wlr_output_state pending;
|
||||||
wlr_output_state_init(&pending);
|
wlr_output_state_init(&pending);
|
||||||
if (!wlr_scene_output_build_state(output->scene_output, &pending, &opts)) {
|
if (!wlr_scene_output_build_state(output->scene_output, &pending, &opts)) {
|
||||||
|
|
Loading…
Reference in a new issue