mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-24 16:18:16 +00:00
identity/clocksync: Also provide system clock if sync=false
identity should provide when sync=true. Don't provide when sync=false. Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/630 Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/697>
This commit is contained in:
parent
d1fb776782
commit
b39a06065a
2 changed files with 52 additions and 3 deletions
|
@ -171,7 +171,6 @@ gst_clock_sync_init (GstClockSync * clocksync)
|
||||||
clocksync->sync = DEFAULT_SYNC;
|
clocksync->sync = DEFAULT_SYNC;
|
||||||
g_cond_init (&clocksync->blocked_cond);
|
g_cond_init (&clocksync->blocked_cond);
|
||||||
|
|
||||||
GST_OBJECT_FLAG_SET (clocksync, GST_ELEMENT_FLAG_PROVIDE_CLOCK);
|
|
||||||
GST_OBJECT_FLAG_SET (clocksync, GST_ELEMENT_FLAG_REQUIRE_CLOCK);
|
GST_OBJECT_FLAG_SET (clocksync, GST_ELEMENT_FLAG_REQUIRE_CLOCK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -180,10 +179,31 @@ gst_clock_sync_set_property (GObject * object, guint prop_id,
|
||||||
const GValue * value, GParamSpec * pspec)
|
const GValue * value, GParamSpec * pspec)
|
||||||
{
|
{
|
||||||
GstClockSync *clocksync = GST_CLOCKSYNC (object);
|
GstClockSync *clocksync = GST_CLOCKSYNC (object);
|
||||||
|
GstMessage *clock_message = NULL;
|
||||||
|
gboolean sync;
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id) {
|
||||||
case PROP_SYNC:
|
case PROP_SYNC:
|
||||||
clocksync->sync = g_value_get_boolean (value);
|
clocksync->sync = g_value_get_boolean (value);
|
||||||
|
sync = g_value_get_boolean (value);
|
||||||
|
GST_OBJECT_LOCK (clocksync);
|
||||||
|
if (sync != clocksync->sync) {
|
||||||
|
clocksync->sync = sync;
|
||||||
|
if (sync) {
|
||||||
|
GST_OBJECT_FLAG_SET (clocksync, GST_ELEMENT_FLAG_PROVIDE_CLOCK);
|
||||||
|
clock_message =
|
||||||
|
gst_message_new_clock_provide (GST_OBJECT_CAST (clocksync),
|
||||||
|
gst_system_clock_obtain (), TRUE);
|
||||||
|
} else {
|
||||||
|
GST_OBJECT_FLAG_UNSET (clocksync, GST_ELEMENT_FLAG_PROVIDE_CLOCK);
|
||||||
|
clock_message =
|
||||||
|
gst_message_new_clock_lost (GST_OBJECT_CAST (clocksync),
|
||||||
|
gst_system_clock_obtain ());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
GST_OBJECT_UNLOCK (clocksync);
|
||||||
|
if (clock_message)
|
||||||
|
gst_element_post_message (GST_ELEMENT_CAST (clocksync), clock_message);
|
||||||
break;
|
break;
|
||||||
case PROP_TS_OFFSET:
|
case PROP_TS_OFFSET:
|
||||||
clocksync->ts_offset = g_value_get_int64 (value);
|
clocksync->ts_offset = g_value_get_int64 (value);
|
||||||
|
@ -540,5 +560,10 @@ gst_clocksync_change_state (GstElement * element, GstStateChange transition)
|
||||||
static GstClock *
|
static GstClock *
|
||||||
gst_clocksync_provide_clock (GstElement * element)
|
gst_clocksync_provide_clock (GstElement * element)
|
||||||
{
|
{
|
||||||
|
GstClockSync *clocksync = GST_CLOCKSYNC (element);
|
||||||
|
|
||||||
|
if (!clocksync->sync)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
return gst_system_clock_obtain ();
|
return gst_system_clock_obtain ();
|
||||||
}
|
}
|
||||||
|
|
|
@ -316,7 +316,6 @@ gst_identity_init (GstIdentity * identity)
|
||||||
|
|
||||||
gst_base_transform_set_gap_aware (GST_BASE_TRANSFORM_CAST (identity), TRUE);
|
gst_base_transform_set_gap_aware (GST_BASE_TRANSFORM_CAST (identity), TRUE);
|
||||||
|
|
||||||
GST_OBJECT_FLAG_SET (identity, GST_ELEMENT_FLAG_PROVIDE_CLOCK);
|
|
||||||
GST_OBJECT_FLAG_SET (identity, GST_ELEMENT_FLAG_REQUIRE_CLOCK);
|
GST_OBJECT_FLAG_SET (identity, GST_ELEMENT_FLAG_REQUIRE_CLOCK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -824,6 +823,8 @@ gst_identity_set_property (GObject * object, guint prop_id,
|
||||||
const GValue * value, GParamSpec * pspec)
|
const GValue * value, GParamSpec * pspec)
|
||||||
{
|
{
|
||||||
GstIdentity *identity;
|
GstIdentity *identity;
|
||||||
|
GstMessage *clock_message = NULL;
|
||||||
|
gboolean sync;
|
||||||
|
|
||||||
identity = GST_IDENTITY (object);
|
identity = GST_IDENTITY (object);
|
||||||
|
|
||||||
|
@ -853,7 +854,25 @@ gst_identity_set_property (GObject * object, guint prop_id,
|
||||||
identity->datarate = g_value_get_int (value);
|
identity->datarate = g_value_get_int (value);
|
||||||
break;
|
break;
|
||||||
case PROP_SYNC:
|
case PROP_SYNC:
|
||||||
identity->sync = g_value_get_boolean (value);
|
sync = g_value_get_boolean (value);
|
||||||
|
GST_OBJECT_LOCK (identity);
|
||||||
|
if (sync != identity->sync) {
|
||||||
|
identity->sync = sync;
|
||||||
|
if (sync) {
|
||||||
|
GST_OBJECT_FLAG_SET (identity, GST_ELEMENT_FLAG_PROVIDE_CLOCK);
|
||||||
|
clock_message =
|
||||||
|
gst_message_new_clock_provide (GST_OBJECT_CAST (identity),
|
||||||
|
gst_system_clock_obtain (), TRUE);
|
||||||
|
} else {
|
||||||
|
GST_OBJECT_FLAG_UNSET (identity, GST_ELEMENT_FLAG_PROVIDE_CLOCK);
|
||||||
|
clock_message =
|
||||||
|
gst_message_new_clock_lost (GST_OBJECT_CAST (identity),
|
||||||
|
gst_system_clock_obtain ());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
GST_OBJECT_UNLOCK (identity);
|
||||||
|
if (clock_message)
|
||||||
|
gst_element_post_message (GST_ELEMENT_CAST (identity), clock_message);
|
||||||
break;
|
break;
|
||||||
case PROP_TS_OFFSET:
|
case PROP_TS_OFFSET:
|
||||||
identity->ts_offset = g_value_get_int64 (value);
|
identity->ts_offset = g_value_get_int64 (value);
|
||||||
|
@ -1131,5 +1150,10 @@ gst_identity_change_state (GstElement * element, GstStateChange transition)
|
||||||
static GstClock *
|
static GstClock *
|
||||||
gst_identity_provide_clock (GstElement * element)
|
gst_identity_provide_clock (GstElement * element)
|
||||||
{
|
{
|
||||||
|
GstIdentity *identity = GST_IDENTITY (element);
|
||||||
|
|
||||||
|
if (!identity->sync)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
return gst_system_clock_obtain ();
|
return gst_system_clock_obtain ();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue