[mutter/gbsneto/content-part2: 635/635] shaped-texture: Update mipmap counters on invalidation



commit 56e553e34241b9e584f97ebb3ab07fa80e4a3886
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date:   Fri Dec 28 02:57:26 2018 -0200

    shaped-texture: Update mipmap counters on invalidation

 src/compositor/meta-shaped-texture.c | 22 ++++++++++++++++++++++
 1 file changed, 22 insertions(+)
---
diff --git a/src/compositor/meta-shaped-texture.c b/src/compositor/meta-shaped-texture.c
index 49908ce11..76eab7b4e 100644
--- a/src/compositor/meta-shaped-texture.c
+++ b/src/compositor/meta-shaped-texture.c
@@ -672,6 +672,24 @@ do_paint_content (MetaShapedTexture *stex,
   g_clear_pointer (&blended_tex_region, cairo_region_destroy);
 }
 
+static void
+update_invalidation_counters (MetaShapedTexture *stex)
+{
+  stex->prev_invalidation = stex->last_invalidation;
+  stex->last_invalidation = g_get_monotonic_time ();
+
+  if (stex->prev_invalidation)
+    {
+      gint64 interval = stex->last_invalidation - stex->prev_invalidation;
+      gboolean fast_update = interval < MIN_MIPMAP_AGE_USEC;
+
+      if (!fast_update)
+        stex->fast_updates = 0;
+      else if (stex->fast_updates < MIN_FAST_UPDATES_BEFORE_UNMIPMAP)
+        stex->fast_updates++;
+    }
+}
+
 static CoglTexture *
 select_texture_for_paint (MetaShapedTexture *stex)
 {
@@ -770,6 +788,8 @@ meta_shaped_texture_invalidate (ClutterContent *content)
 {
   MetaShapedTexture *stex = META_SHAPED_TEXTURE (content);
 
+  update_invalidation_counters (stex);
+
   if (!stex->invalidate_func)
     return;
 
@@ -781,6 +801,8 @@ meta_shaped_texture_invalidate_size (ClutterContent *content)
 {
   MetaShapedTexture *stex = META_SHAPED_TEXTURE (content);
 
+  update_invalidation_counters (stex);
+
   if (!stex->invalidate_func)
     return;
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]