mirror of
https://github.com/NickHu/sway
synced 2024-12-30 22:23:30 +01:00
output: Ensure that frame_done is delayed on max_render_time
max_render_time can be set on output, view, or both. However, if only applied to the output, send_frame_done_iterator would erroneously send frame_done immediately, ignoring the output max_render_time. As damage_handle_frame processed max_render_time correctly, idle frames would be blocked in anticipation of the delay that was meant to happen. Without the delay, frame events would be dispatched during the idle frame block, and some clients would never receive the frame done events they had requested, at least not until something else actively drove another render. Respecting both view and output max_render_time in send_frame_done_iterator ensures that the frame events are always correctly delayed. Fixes #4756
This commit is contained in:
parent
9979382d56
commit
4b57953628
1 changed files with 1 additions and 1 deletions
|
@ -426,7 +426,7 @@ static void send_frame_done_iterator(struct sway_output *output, struct sway_vie
|
||||||
int delay = data->msec_until_refresh - output->max_render_time
|
int delay = data->msec_until_refresh - output->max_render_time
|
||||||
- view_max_render_time;
|
- view_max_render_time;
|
||||||
|
|
||||||
if (output->max_render_time == 0 || view_max_render_time == 0 || delay < 1) {
|
if ((output->max_render_time == 0 && view_max_render_time == 0) || delay < 1) {
|
||||||
wlr_surface_send_frame_done(surface, &data->when);
|
wlr_surface_send_frame_done(surface, &data->when);
|
||||||
} else {
|
} else {
|
||||||
struct sway_surface *sway_surface = surface->data;
|
struct sway_surface *sway_surface = surface->data;
|
||||||
|
|
Loading…
Reference in a new issue