[gtk/wip/chergert/glproto] free textures back into the texture pool
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/chergert/glproto] free textures back into the texture pool
- Date: Wed, 27 Jan 2021 23:57:33 +0000 (UTC)
commit 6fcaab12fa696b9bbbd373f6d4bf762b51a0f766
Author: Christian Hergert <chergert redhat com>
Date: Wed Jan 27 16:07:15 2021 -0800
free textures back into the texture pool
gsk/next/gskgldriver.c | 13 ++++++++++++-
gsk/next/gskgltexturepool.c | 16 ++++++++++++----
2 files changed, 24 insertions(+), 5 deletions(-)
---
diff --git a/gsk/next/gskgldriver.c b/gsk/next/gskgldriver.c
index fa8845cdbf..a2db9b8855 100644
--- a/gsk/next/gskgldriver.c
+++ b/gsk/next/gskgldriver.c
@@ -95,6 +95,7 @@ remove_texture_key_for_id (GskNextDriver *self,
g_assert (GSK_IS_NEXT_DRIVER (self));
g_assert (texture_id > 0);
+ /* g_hash_table_remove() will cause @key to be freed */
if (g_hash_table_steal_extended (self->texture_id_to_key,
GUINT_TO_POINTER (texture_id),
NULL,
@@ -131,8 +132,18 @@ gsk_next_driver_collect_unused_textures (GskNextDriver *self,
if (t->last_used_in_frame < watermark)
{
+ g_hash_table_iter_steal (&iter);
+
+ g_assert (t->width_link.prev == NULL);
+ g_assert (t->width_link.next == NULL);
+ g_assert (t->width_link.data == t);
+ g_assert (t->height_link.prev == NULL);
+ g_assert (t->height_link.next == NULL);
+ g_assert (t->height_link.data == t);
+
+ /* Steal this texture and put it back into the pool */
remove_texture_key_for_id (self, t->texture_id);
- g_hash_table_iter_remove (&iter);
+ gsk_gl_texture_pool_put (&self->texture_pool, t);
}
}
diff --git a/gsk/next/gskgltexturepool.c b/gsk/next/gskgltexturepool.c
index e3a70bf91b..3df7856a05 100644
--- a/gsk/next/gskgltexturepool.c
+++ b/gsk/next/gskgltexturepool.c
@@ -71,11 +71,18 @@ void
gsk_gl_texture_pool_put (GskGLTexturePool *self,
GskGLTexture *texture)
{
- GList *sibling = NULL;
+ GList *sibling;
g_return_if_fail (self != NULL);
g_return_if_fail (texture != NULL);
-
+ g_return_if_fail (texture->width_link.prev == NULL);
+ g_return_if_fail (texture->width_link.next == NULL);
+ g_return_if_fail (texture->width_link.data == texture);
+ g_return_if_fail (texture->height_link.prev == NULL);
+ g_return_if_fail (texture->height_link.next == NULL);
+ g_return_if_fail (texture->height_link.data == texture);
+
+ sibling = NULL;
for (GList *iter = self->by_width.head;
iter != NULL;
iter = iter->next)
@@ -92,7 +99,8 @@ gsk_gl_texture_pool_put (GskGLTexturePool *self,
g_queue_insert_after_link (&self->by_width, sibling, &texture->width_link);
- for (GList *iter = self->by_width.head;
+ sibling = NULL;
+ for (GList *iter = self->by_height.head;
iter != NULL;
iter = iter->next)
{
@@ -106,7 +114,7 @@ gsk_gl_texture_pool_put (GskGLTexturePool *self,
sibling = iter;
}
- g_queue_insert_after_link (&self->by_width, sibling, &texture->width_link);
+ g_queue_insert_after_link (&self->by_height, sibling, &texture->height_link);
}
GskGLTexture *
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]