hc
2023-02-14 0cc9b7c44253c93447ddf73e206fbdbb3d9f16b1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
From d82ed073cf0bee220243e48a04cc9ddc487ecfdd Mon Sep 17 00:00:00 2001
From: Jeffy Chen <jeffy.chen@rock-chips.com>
Date: Mon, 8 Nov 2021 18:45:00 +0800
Subject: [PATCH 23/31] waylandsink: Support frame-sync mode
 
Set env "WAYLANDSINK_SYNC_FRAME" to enable frame syncing.
 
Signed-off-by: Jeffy Chen <jeffy.chen@rock-chips.com>
---
 ext/wayland/gstwaylandsink.c | 9 +++++++++
 ext/wayland/gstwaylandsink.h | 1 +
 2 files changed, 10 insertions(+)
 
diff --git a/ext/wayland/gstwaylandsink.c b/ext/wayland/gstwaylandsink.c
index 24fd7bd..07bfec0 100644
--- a/ext/wayland/gstwaylandsink.c
+++ b/ext/wayland/gstwaylandsink.c
@@ -284,6 +284,7 @@ gst_wayland_sink_init (GstWaylandSink * sink)
 {
   g_mutex_init (&sink->display_lock);
   g_mutex_init (&sink->render_lock);
+  g_cond_init (&sink->redraw_cond);
 
   sink->window_handle = 1;
   sink->layer = GST_WL_WINDOW_LAYER_NORMAL;
@@ -439,6 +440,7 @@ gst_wayland_sink_finalize (GObject * object)
 
   g_mutex_clear (&sink->display_lock);
   g_mutex_clear (&sink->render_lock);
+  g_cond_clear (&sink->redraw_cond);
 
   G_OBJECT_CLASS (parent_class)->finalize (object);
 }
@@ -783,6 +785,7 @@ frame_redraw_callback (void *data, struct wl_callback *callback, uint32_t time)
 
   g_mutex_lock (&sink->render_lock);
   sink->redraw_pending = FALSE;
+  g_cond_signal (&sink->redraw_cond);
 
   if (sink->callback) {
     wl_callback_destroy (callback);
@@ -819,6 +822,11 @@ render_last_buffer (GstWaylandSink * sink, gboolean redraw)
   }
   sink->window->fill_mode = sink->fill_mode;
   gst_wl_window_render (sink->window, wlbuffer, info);
+
+  if (g_getenv ("WAYLANDSINK_SYNC_FRAME")) {
+    while (sink->redraw_pending)
+      g_cond_wait (&sink->redraw_cond, &sink->render_lock);
+  }
 }
 
 static void
@@ -1019,6 +1027,7 @@ render:
 
   if (buffer != to_render)
     gst_buffer_unref (to_render);
+
   goto done;
 
 no_window_size:
diff --git a/ext/wayland/gstwaylandsink.h b/ext/wayland/gstwaylandsink.h
index 6fd77e8..1f70f76 100644
--- a/ext/wayland/gstwaylandsink.h
+++ b/ext/wayland/gstwaylandsink.h
@@ -71,6 +71,7 @@ struct _GstWaylandSink
   gboolean resend_info;
   gboolean redraw_pending;
   GMutex render_lock;
+  GCond redraw_cond;
   GstBuffer *last_buffer;
   GstVideoRectangle render_rectangle;
 
-- 
2.20.1