mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-06-07 07:58:51 +00:00
rtsp-media: Add API to directly configure a clock on the media pipelines
This commit is contained in:
parent
cbf3f3888f
commit
7a41d396ae
4 changed files with 122 additions and 0 deletions
|
@ -69,6 +69,8 @@ struct _GstRTSPMediaFactoryPrivate
|
||||||
GHashTable *medias; /* protected by medias_lock */
|
GHashTable *medias; /* protected by medias_lock */
|
||||||
|
|
||||||
GType media_gtype;
|
GType media_gtype;
|
||||||
|
|
||||||
|
GstClock *clock;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define DEFAULT_LAUNCH NULL
|
#define DEFAULT_LAUNCH NULL
|
||||||
|
@ -96,6 +98,7 @@ enum
|
||||||
PROP_LATENCY,
|
PROP_LATENCY,
|
||||||
PROP_TRANSPORT_MODE,
|
PROP_TRANSPORT_MODE,
|
||||||
PROP_STOP_ON_DISCONNECT,
|
PROP_STOP_ON_DISCONNECT,
|
||||||
|
PROP_CLOCK,
|
||||||
PROP_LAST
|
PROP_LAST
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -212,6 +215,12 @@ gst_rtsp_media_factory_class_init (GstRTSPMediaFactoryClass * klass)
|
||||||
DEFAULT_STOP_ON_DISCONNECT,
|
DEFAULT_STOP_ON_DISCONNECT,
|
||||||
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
||||||
|
|
||||||
|
g_object_class_install_property (gobject_class, PROP_CLOCK,
|
||||||
|
g_param_spec_object ("clock", "Clock",
|
||||||
|
"Clock to be used by the pipelines created for all "
|
||||||
|
"medias of this factory", GST_TYPE_CLOCK,
|
||||||
|
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
||||||
|
|
||||||
gst_rtsp_media_factory_signals[SIGNAL_MEDIA_CONSTRUCTED] =
|
gst_rtsp_media_factory_signals[SIGNAL_MEDIA_CONSTRUCTED] =
|
||||||
g_signal_new ("media-constructed", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("media-constructed", G_TYPE_FROM_CLASS (klass),
|
||||||
G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (GstRTSPMediaFactoryClass,
|
G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (GstRTSPMediaFactoryClass,
|
||||||
|
@ -319,6 +328,9 @@ gst_rtsp_media_factory_get_property (GObject * object, guint propid,
|
||||||
g_value_set_boolean (value,
|
g_value_set_boolean (value,
|
||||||
gst_rtsp_media_factory_is_stop_on_disonnect (factory));
|
gst_rtsp_media_factory_is_stop_on_disonnect (factory));
|
||||||
break;
|
break;
|
||||||
|
case PROP_CLOCK:
|
||||||
|
g_value_take_object (value, gst_rtsp_media_factory_get_clock (factory));
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
||||||
}
|
}
|
||||||
|
@ -366,6 +378,8 @@ gst_rtsp_media_factory_set_property (GObject * object, guint propid,
|
||||||
gst_rtsp_media_factory_set_stop_on_disconnect (factory,
|
gst_rtsp_media_factory_set_stop_on_disconnect (factory,
|
||||||
g_value_get_boolean (value));
|
g_value_get_boolean (value));
|
||||||
break;
|
break;
|
||||||
|
case PROP_CLOCK:
|
||||||
|
gst_rtsp_media_factory_set_clock (factory, g_value_get_object (value));
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
||||||
}
|
}
|
||||||
|
@ -1211,6 +1225,55 @@ gst_rtsp_media_factory_get_media_gtype (GstRTSPMediaFactory * factory)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_rtsp_media_factory_set_clock:
|
||||||
|
* @factory: a #GstRTSPMediaFactory
|
||||||
|
* @clockd: the clock to be used by the media factory
|
||||||
|
*
|
||||||
|
* Configures a specific clock to be used by the pipelines
|
||||||
|
* of all medias created from this factory.
|
||||||
|
*
|
||||||
|
* Since: 1.8
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
gst_rtsp_media_factory_set_clock (GstRTSPMediaFactory * factory,
|
||||||
|
GstClock * clock)
|
||||||
|
{
|
||||||
|
GstRTSPMediaFactoryPrivate *priv;
|
||||||
|
|
||||||
|
g_return_if_fail (GST_IS_CLOCK (clock) || clock == NULL);
|
||||||
|
|
||||||
|
GST_RTSP_MEDIA_FACTORY_LOCK (factory);
|
||||||
|
priv = factory->priv;
|
||||||
|
priv->clock = clock ? gst_object_ref (clock) : NULL;
|
||||||
|
GST_RTSP_MEDIA_FACTORY_UNLOCK (factory);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_rtsp_media_factory_get_clock:
|
||||||
|
* @factory: a #GstRTSPMediaFactory
|
||||||
|
*
|
||||||
|
* Returns the clock that is going to be used by the pipelines
|
||||||
|
* of all medias created from this factory.
|
||||||
|
*
|
||||||
|
* Returns: (transfer full): The GstClock
|
||||||
|
*
|
||||||
|
* Since: 1.8
|
||||||
|
*/
|
||||||
|
GstClock *
|
||||||
|
gst_rtsp_media_factory_get_clock (GstRTSPMediaFactory * factory)
|
||||||
|
{
|
||||||
|
GstRTSPMediaFactoryPrivate *priv;
|
||||||
|
GstClock *ret;
|
||||||
|
|
||||||
|
GST_RTSP_MEDIA_FACTORY_LOCK (factory);
|
||||||
|
priv = factory->priv;
|
||||||
|
ret = priv->clock ? gst_object_ref (priv->clock) : NULL;
|
||||||
|
GST_RTSP_MEDIA_FACTORY_UNLOCK (factory);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static gchar *
|
static gchar *
|
||||||
default_gen_key (GstRTSPMediaFactory * factory, const GstRTSPUrl * url)
|
default_gen_key (GstRTSPMediaFactory * factory, const GstRTSPUrl * url)
|
||||||
{
|
{
|
||||||
|
@ -1354,6 +1417,7 @@ default_configure (GstRTSPMediaFactory * factory, GstRTSPMedia * media)
|
||||||
GstClockTime rtx_time;
|
GstClockTime rtx_time;
|
||||||
guint latency;
|
guint latency;
|
||||||
GstRTSPTransportMode transport_mode;
|
GstRTSPTransportMode transport_mode;
|
||||||
|
GstClock *clock;
|
||||||
|
|
||||||
/* configure the sharedness */
|
/* configure the sharedness */
|
||||||
GST_RTSP_MEDIA_FACTORY_LOCK (factory);
|
GST_RTSP_MEDIA_FACTORY_LOCK (factory);
|
||||||
|
@ -1367,6 +1431,7 @@ default_configure (GstRTSPMediaFactory * factory, GstRTSPMedia * media)
|
||||||
latency = priv->latency;
|
latency = priv->latency;
|
||||||
transport_mode = priv->transport_mode;
|
transport_mode = priv->transport_mode;
|
||||||
stop_on_disconnect = priv->stop_on_disconnect;
|
stop_on_disconnect = priv->stop_on_disconnect;
|
||||||
|
clock = priv->clock ? gst_object_ref (priv->clock) : NULL;
|
||||||
GST_RTSP_MEDIA_FACTORY_UNLOCK (factory);
|
GST_RTSP_MEDIA_FACTORY_UNLOCK (factory);
|
||||||
|
|
||||||
gst_rtsp_media_set_suspend_mode (media, suspend_mode);
|
gst_rtsp_media_set_suspend_mode (media, suspend_mode);
|
||||||
|
@ -1380,6 +1445,11 @@ default_configure (GstRTSPMediaFactory * factory, GstRTSPMedia * media)
|
||||||
gst_rtsp_media_set_transport_mode (media, transport_mode);
|
gst_rtsp_media_set_transport_mode (media, transport_mode);
|
||||||
gst_rtsp_media_set_stop_on_disconnect (media, stop_on_disconnect);
|
gst_rtsp_media_set_stop_on_disconnect (media, stop_on_disconnect);
|
||||||
|
|
||||||
|
if (clock) {
|
||||||
|
gst_rtsp_media_set_clock (media, clock);
|
||||||
|
gst_object_unref (clock);
|
||||||
|
}
|
||||||
|
|
||||||
if ((pool = gst_rtsp_media_factory_get_address_pool (factory))) {
|
if ((pool = gst_rtsp_media_factory_get_address_pool (factory))) {
|
||||||
gst_rtsp_media_set_address_pool (media, pool);
|
gst_rtsp_media_set_address_pool (media, pool);
|
||||||
g_object_unref (pool);
|
g_object_unref (pool);
|
||||||
|
|
|
@ -161,6 +161,10 @@ void gst_rtsp_media_factory_set_media_gtype (GstRTSPMediaFacto
|
||||||
GType media_gtype);
|
GType media_gtype);
|
||||||
GType gst_rtsp_media_factory_get_media_gtype (GstRTSPMediaFactory * factory);
|
GType gst_rtsp_media_factory_get_media_gtype (GstRTSPMediaFactory * factory);
|
||||||
|
|
||||||
|
void gst_rtsp_media_factory_set_clock (GstRTSPMediaFactory *factory,
|
||||||
|
GstClock * clock);
|
||||||
|
GstClock * gst_rtsp_media_factory_get_clock (GstRTSPMediaFactory *factory);
|
||||||
|
|
||||||
/* creating the media from the factory and a url */
|
/* creating the media from the factory and a url */
|
||||||
GstRTSPMedia * gst_rtsp_media_factory_construct (GstRTSPMediaFactory *factory,
|
GstRTSPMedia * gst_rtsp_media_factory_construct (GstRTSPMediaFactory *factory,
|
||||||
const GstRTSPUrl *url);
|
const GstRTSPUrl *url);
|
||||||
|
|
|
@ -139,6 +139,7 @@ struct _GstRTSPMediaPrivate
|
||||||
GList *payloads; /* protected by lock */
|
GList *payloads; /* protected by lock */
|
||||||
GstClockTime rtx_time; /* protected by lock */
|
GstClockTime rtx_time; /* protected by lock */
|
||||||
guint latency; /* protected by lock */
|
guint latency; /* protected by lock */
|
||||||
|
GstClock *clock; /* protected by lock */
|
||||||
};
|
};
|
||||||
|
|
||||||
#define DEFAULT_SHARED FALSE
|
#define DEFAULT_SHARED FALSE
|
||||||
|
@ -172,6 +173,7 @@ enum
|
||||||
PROP_LATENCY,
|
PROP_LATENCY,
|
||||||
PROP_TRANSPORT_MODE,
|
PROP_TRANSPORT_MODE,
|
||||||
PROP_STOP_ON_DISCONNECT,
|
PROP_STOP_ON_DISCONNECT,
|
||||||
|
PROP_CLOCK,
|
||||||
PROP_LAST
|
PROP_LAST
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -339,6 +341,11 @@ gst_rtsp_media_class_init (GstRTSPMediaClass * klass)
|
||||||
DEFAULT_STOP_ON_DISCONNECT,
|
DEFAULT_STOP_ON_DISCONNECT,
|
||||||
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
||||||
|
|
||||||
|
g_object_class_install_property (gobject_class, PROP_CLOCK,
|
||||||
|
g_param_spec_object ("clock", "Clock",
|
||||||
|
"Clock to be used by the media pipeline",
|
||||||
|
GST_TYPE_CLOCK, G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
||||||
|
|
||||||
gst_rtsp_media_signals[SIGNAL_NEW_STREAM] =
|
gst_rtsp_media_signals[SIGNAL_NEW_STREAM] =
|
||||||
g_signal_new ("new-stream", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
|
g_signal_new ("new-stream", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
|
||||||
G_STRUCT_OFFSET (GstRTSPMediaClass, new_stream), NULL, NULL,
|
G_STRUCT_OFFSET (GstRTSPMediaClass, new_stream), NULL, NULL,
|
||||||
|
@ -486,6 +493,9 @@ gst_rtsp_media_get_property (GObject * object, guint propid,
|
||||||
case PROP_STOP_ON_DISCONNECT:
|
case PROP_STOP_ON_DISCONNECT:
|
||||||
g_value_set_boolean (value, gst_rtsp_media_is_stop_on_disconnect (media));
|
g_value_set_boolean (value, gst_rtsp_media_is_stop_on_disconnect (media));
|
||||||
break;
|
break;
|
||||||
|
case PROP_CLOCK:
|
||||||
|
g_value_take_object (value, gst_rtsp_media_get_clock (media));
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
||||||
}
|
}
|
||||||
|
@ -536,6 +546,9 @@ gst_rtsp_media_set_property (GObject * object, guint propid,
|
||||||
gst_rtsp_media_set_stop_on_disconnect (media,
|
gst_rtsp_media_set_stop_on_disconnect (media,
|
||||||
g_value_get_boolean (value));
|
g_value_get_boolean (value));
|
||||||
break;
|
break;
|
||||||
|
case PROP_CLOCK:
|
||||||
|
gst_rtsp_media_set_clock (media, g_value_get_object (value));
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, propid, pspec);
|
||||||
}
|
}
|
||||||
|
@ -1390,6 +1403,39 @@ gst_rtsp_media_is_time_provider (GstRTSPMedia * media)
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_rtsp_media_set_clock:
|
||||||
|
* @media: a #GstRTSPMedia
|
||||||
|
* @clock: #GstClock to be used
|
||||||
|
*
|
||||||
|
* Configure the clock used for the media.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
gst_rtsp_media_set_clock (GstRTSPMedia * media, GstClock * clock)
|
||||||
|
{
|
||||||
|
GstRTSPMediaPrivate *priv;
|
||||||
|
|
||||||
|
g_return_if_fail (GST_IS_RTSP_MEDIA (media));
|
||||||
|
g_return_if_fail (GST_IS_CLOCK (clock) || clock == NULL);
|
||||||
|
|
||||||
|
GST_LOG_OBJECT (media, "setting clock %" GST_PTR_FORMAT, clock);
|
||||||
|
|
||||||
|
priv = media->priv;
|
||||||
|
|
||||||
|
g_mutex_lock (&priv->lock);
|
||||||
|
if (priv->clock)
|
||||||
|
gst_object_unref (priv->clock);
|
||||||
|
priv->clock = clock ? gst_object_ref (clock) : NULL;
|
||||||
|
if (priv->pipeline) {
|
||||||
|
if (clock)
|
||||||
|
gst_pipeline_use_clock (GST_PIPELINE_CAST (priv->pipeline), clock);
|
||||||
|
else
|
||||||
|
gst_pipeline_auto_clock (GST_PIPELINE_CAST (priv->pipeline));
|
||||||
|
}
|
||||||
|
|
||||||
|
g_mutex_unlock (&priv->lock);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gst_rtsp_media_set_address_pool:
|
* gst_rtsp_media_set_address_pool:
|
||||||
* @media: a #GstRTSPMedia
|
* @media: a #GstRTSPMedia
|
||||||
|
|
|
@ -221,6 +221,8 @@ gboolean gst_rtsp_media_is_time_provider (GstRTSPMedia *media);
|
||||||
GstNetTimeProvider * gst_rtsp_media_get_time_provider (GstRTSPMedia *media,
|
GstNetTimeProvider * gst_rtsp_media_get_time_provider (GstRTSPMedia *media,
|
||||||
const gchar *address, guint16 port);
|
const gchar *address, guint16 port);
|
||||||
|
|
||||||
|
void gst_rtsp_media_set_clock (GstRTSPMedia *media, GstClock * clock);
|
||||||
|
|
||||||
/* prepare the media for playback */
|
/* prepare the media for playback */
|
||||||
gboolean gst_rtsp_media_prepare (GstRTSPMedia *media, GstRTSPThread *thread);
|
gboolean gst_rtsp_media_prepare (GstRTSPMedia *media, GstRTSPThread *thread);
|
||||||
gboolean gst_rtsp_media_unprepare (GstRTSPMedia *media);
|
gboolean gst_rtsp_media_unprepare (GstRTSPMedia *media);
|
||||||
|
|
Loading…
Reference in a new issue