mirror of
https://gitlab.freedesktop.org/wlroots/wlroots.git
synced 2024-11-25 08:32:30 +00:00
scene: add explicit synchronization for rendered buffers
This commit is contained in:
parent
9e9636f675
commit
5f88635118
@ -227,6 +227,9 @@ struct wlr_scene_output {
|
|||||||
struct wl_list damage_highlight_regions;
|
struct wl_list damage_highlight_regions;
|
||||||
|
|
||||||
struct wl_array render_list;
|
struct wl_array render_list;
|
||||||
|
|
||||||
|
struct wlr_drm_syncobj_timeline *in_timeline;
|
||||||
|
uint64_t in_point;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct wlr_scene_timer {
|
struct wlr_scene_timer {
|
||||||
|
@ -1439,6 +1439,14 @@ struct wlr_scene_output *wlr_scene_output_create(struct wlr_scene *scene,
|
|||||||
prev_output_link = ¤t_output->link;
|
prev_output_link = ¤t_output->link;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int drm_fd = wlr_backend_get_drm_fd(output->backend);
|
||||||
|
if (drm_fd >= 0 && output->timeline && output->renderer != NULL && output->renderer->features.timeline) {
|
||||||
|
scene_output->in_timeline = wlr_drm_syncobj_timeline_create(drm_fd);
|
||||||
|
if (scene_output->in_timeline == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
scene_output->index = prev_output_index + 1;
|
scene_output->index = prev_output_index + 1;
|
||||||
assert(scene_output->index < 64);
|
assert(scene_output->index < 64);
|
||||||
wl_list_insert(prev_output_link, &scene_output->link);
|
wl_list_insert(prev_output_link, &scene_output->link);
|
||||||
@ -1487,7 +1495,7 @@ void wlr_scene_output_destroy(struct wlr_scene_output *scene_output) {
|
|||||||
wl_list_remove(&scene_output->output_commit.link);
|
wl_list_remove(&scene_output->output_commit.link);
|
||||||
wl_list_remove(&scene_output->output_damage.link);
|
wl_list_remove(&scene_output->output_damage.link);
|
||||||
wl_list_remove(&scene_output->output_needs_frame.link);
|
wl_list_remove(&scene_output->output_needs_frame.link);
|
||||||
|
wlr_drm_syncobj_timeline_unref(scene_output->in_timeline);
|
||||||
wl_array_release(&scene_output->render_list);
|
wl_array_release(&scene_output->render_list);
|
||||||
free(scene_output);
|
free(scene_output);
|
||||||
}
|
}
|
||||||
@ -1919,10 +1927,13 @@ bool wlr_scene_output_build_state(struct wlr_scene_output *scene_output,
|
|||||||
timer->pre_render_duration = timespec_to_nsec(&duration);
|
timer->pre_render_duration = timespec_to_nsec(&duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scene_output->in_point++;
|
||||||
struct wlr_render_pass *render_pass = wlr_renderer_begin_buffer_pass(output->renderer, buffer,
|
struct wlr_render_pass *render_pass = wlr_renderer_begin_buffer_pass(output->renderer, buffer,
|
||||||
&(struct wlr_buffer_pass_options){
|
&(struct wlr_buffer_pass_options){
|
||||||
.timer = timer ? timer->render_timer : NULL,
|
.timer = timer ? timer->render_timer : NULL,
|
||||||
.color_transform = options->color_transform,
|
.color_transform = options->color_transform,
|
||||||
|
.signal_timeline = scene_output->in_timeline,
|
||||||
|
.signal_point = scene_output->in_point,
|
||||||
});
|
});
|
||||||
if (render_pass == NULL) {
|
if (render_pass == NULL) {
|
||||||
wlr_buffer_unlock(buffer);
|
wlr_buffer_unlock(buffer);
|
||||||
@ -2029,6 +2040,11 @@ bool wlr_scene_output_build_state(struct wlr_scene_output *scene_output,
|
|||||||
wlr_output_state_set_buffer(state, buffer);
|
wlr_output_state_set_buffer(state, buffer);
|
||||||
wlr_buffer_unlock(buffer);
|
wlr_buffer_unlock(buffer);
|
||||||
|
|
||||||
|
if (scene_output->in_timeline != NULL) {
|
||||||
|
wlr_output_state_set_wait_timeline(state, scene_output->in_timeline,
|
||||||
|
scene_output->in_point);
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user