From 8ca2b4cf49055eabcd2499bf3811d356d769bded Mon Sep 17 00:00:00 2001 From: Simon Ser Date: Wed, 21 Apr 2021 12:02:42 +0200 Subject: [PATCH] render/pixman: destroy textures on renderer teardown --- include/render/pixman.h | 2 ++ render/pixman/renderer.c | 11 ++++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/include/render/pixman.h b/include/render/pixman.h index f4cab45e..dd2d768b 100644 --- a/include/render/pixman.h +++ b/include/render/pixman.h @@ -17,6 +17,7 @@ struct wlr_pixman_renderer { struct wlr_renderer wlr_renderer; struct wl_list buffers; // wlr_pixman_buffer.link + struct wl_list textures; // wlr_pixman_texture.link struct wlr_pixman_buffer *current_buffer; int32_t width, height; @@ -37,6 +38,7 @@ struct wlr_pixman_buffer { struct wlr_pixman_texture { struct wlr_texture wlr_texture; struct wlr_pixman_renderer *renderer; + struct wl_list link; // wlr_pixman_renderer.textures void *data; pixman_image_t *image; 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);