libweston: Update paint nodes in weston_output_repaint

This is when they need to be up to date. And it makes it so that
view_ensure_paint_node() only does what the function name indicates.

Also, later when we tie damage tracking to paint nodes it will make
more sense to update them just in time for the output being repainted.

Signed-off-by: Derek Foreman <derek.foreman@collabora.com>
This commit is contained in:
Derek Foreman 2023-06-21 15:35:03 -05:00
parent f7ddaa142a
commit 61cbd8f3c5

View File

@ -210,7 +210,6 @@ weston_paint_node_create(struct weston_surface *surface,
wl_list_init(&pnode->z_order_link); wl_list_init(&pnode->z_order_link);
pnode->status = PAINT_NODE_ALL_DIRTY; pnode->status = PAINT_NODE_ALL_DIRTY;
paint_node_update(pnode);
return pnode; return pnode;
} }
@ -3005,10 +3004,8 @@ view_ensure_paint_node(struct weston_view *view, struct weston_output *output)
return NULL; return NULL;
pnode = weston_view_find_paint_node(view, output); pnode = weston_view_find_paint_node(view, output);
if (pnode) { if (pnode)
paint_node_update(pnode);
return pnode; return pnode;
}
return weston_paint_node_create(view->surface, view, output); return weston_paint_node_create(view->surface, view, output);
} }
@ -3224,6 +3221,10 @@ weston_output_repaint(struct weston_output *output)
output->desired_protection = highest_requested; output->desired_protection = highest_requested;
wl_list_for_each(pnode, &output->paint_node_z_order_list,
z_order_link)
paint_node_update(pnode);
if (output->assign_planes && !output->disable_planes) { if (output->assign_planes && !output->disable_planes) {
output->assign_planes(output); output->assign_planes(output);
} else { } else {