aboutsummaryrefslogtreecommitdiff
path: root/render
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2021-04-21 12:02:42 +0200
committerSimon Ser <contact@emersion.fr>2021-04-22 15:44:49 +0200
commit8ca2b4cf49055eabcd2499bf3811d356d769bded (patch)
tree063b909507ab173eb88f947327e286cf971a5953 /render
parent661ba495640069b3484441be1631f70187066656 (diff)
render/pixman: destroy textures on renderer teardown
Diffstat (limited to 'render')
-rw-r--r--render/pixman/renderer.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/render/pixman/renderer.c b/render/pixman/renderer.c
index 586af99c..688af9be 100644
--- a/render/pixman/renderer.c
+++ b/render/pixman/renderer.c
@@ -48,6 +48,7 @@ static void texture_destroy(struct wlr_texture *wlr_texture) {
}
struct wlr_pixman_texture *texture = get_texture(wlr_texture);
+ wl_list_remove(&texture->link);
pixman_image_unref(texture->image);
free(texture->data);
free(texture);
@@ -249,7 +250,7 @@ static void pixman_render_quad_with_matrix(struct wlr_renderer *wlr_renderer,
height, NULL, 0);
// TODO find a way to fill the image without allocating 2 images
- pixman_image_composite32 (PIXMAN_OP_SRC, fill, NULL, image,
+ pixman_image_composite32(PIXMAN_OP_SRC, fill, NULL, image,
0, 0, 0, 0, 0, 0, width, height);
pixman_image_unref(fill);
@@ -322,6 +323,8 @@ static struct wlr_texture *pixman_texture_from_pixels(
return NULL;
}
+ wl_list_insert(&renderer->textures, &texture->link);
+
return &texture->wlr_texture;
}
@@ -360,6 +363,11 @@ static void pixman_destroy(struct wlr_renderer *wlr_renderer) {
destroy_buffer(buffer);
}
+ struct wlr_pixman_texture *tex, *tex_tmp;
+ wl_list_for_each_safe(tex, tex_tmp, &renderer->textures, link) {
+ wlr_texture_destroy(&tex->wlr_texture);
+ }
+
wlr_drm_format_set_finish(&renderer->drm_formats);
free(renderer);
@@ -388,6 +396,7 @@ struct wlr_renderer *wlr_pixman_renderer_create(void) {
wlr_log(WLR_INFO, "Creating pixman renderer");
wlr_renderer_init(&renderer->wlr_renderer, &renderer_impl);
wl_list_init(&renderer->buffers);
+ wl_list_init(&renderer->textures);
size_t len = 0;
const uint32_t *formats = get_pixman_drm_formats(&len);