mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-06-05 06:58:56 +00:00
bluez: Enable gstreamer plugin to use autoconnect flag.
This commit is contained in:
parent
1354fcea15
commit
ff3034af81
4 changed files with 48 additions and 1 deletions
|
@ -37,10 +37,13 @@ GST_DEBUG_CATEGORY_STATIC (gst_a2dp_sink_debug);
|
||||||
#define A2DP_SBC_RTP_PAYLOAD_TYPE 1
|
#define A2DP_SBC_RTP_PAYLOAD_TYPE 1
|
||||||
#define TEMPLATE_MAX_BITPOOL_STR "64"
|
#define TEMPLATE_MAX_BITPOOL_STR "64"
|
||||||
|
|
||||||
|
#define DEFAULT_AUTOCONNECT TRUE
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
PROP_0,
|
PROP_0,
|
||||||
PROP_DEVICE
|
PROP_DEVICE,
|
||||||
|
PROP_AUTOCONNECT
|
||||||
};
|
};
|
||||||
|
|
||||||
GST_BOILERPLATE (GstA2dpSink, gst_a2dp_sink, GstBin, GST_TYPE_BIN);
|
GST_BOILERPLATE (GstA2dpSink, gst_a2dp_sink, GstBin, GST_TYPE_BIN);
|
||||||
|
@ -167,6 +170,14 @@ gst_a2dp_sink_set_property (GObject * object, guint prop_id,
|
||||||
self->device = g_value_dup_string (value);
|
self->device = g_value_dup_string (value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case PROP_AUTOCONNECT:
|
||||||
|
self->autoconnect = g_value_get_boolean (value);
|
||||||
|
|
||||||
|
if (self->sink != NULL)
|
||||||
|
g_object_set (G_OBJECT (self->sink), "auto-connect",
|
||||||
|
self->autoconnect, NULL);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -188,7 +199,13 @@ gst_a2dp_sink_get_property (GObject * object, guint prop_id,
|
||||||
g_value_take_string (value, device);
|
g_value_take_string (value, device);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case PROP_AUTOCONNECT:
|
||||||
|
if (self->sink != NULL)
|
||||||
|
g_object_get (G_OBJECT (self->sink), "auto-connect",
|
||||||
|
&self->autoconnect, NULL);
|
||||||
|
|
||||||
|
g_value_set_boolean (value, self->autoconnect);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -263,6 +280,9 @@ gst_a2dp_sink_change_state (GstElement * element, GstStateChange transition)
|
||||||
if (self->device != NULL)
|
if (self->device != NULL)
|
||||||
gst_avdtp_sink_set_device (self->sink, self->device);
|
gst_avdtp_sink_set_device (self->sink, self->device);
|
||||||
|
|
||||||
|
g_object_set (G_OBJECT (self->sink), "auto-connect",
|
||||||
|
self->autoconnect, NULL);
|
||||||
|
|
||||||
ret = gst_element_set_state (GST_ELEMENT (self->sink), GST_STATE_READY);
|
ret = gst_element_set_state (GST_ELEMENT (self->sink), GST_STATE_READY);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -328,6 +348,11 @@ gst_a2dp_sink_class_init (GstA2dpSinkClass * klass)
|
||||||
g_param_spec_string ("device", "Device",
|
g_param_spec_string ("device", "Device",
|
||||||
"Bluetooth remote device address", NULL, G_PARAM_READWRITE));
|
"Bluetooth remote device address", NULL, G_PARAM_READWRITE));
|
||||||
|
|
||||||
|
g_object_class_install_property (object_class, PROP_AUTOCONNECT,
|
||||||
|
g_param_spec_boolean ("auto-connect", "Auto-connect",
|
||||||
|
"Automatically attempt to connect to device",
|
||||||
|
DEFAULT_AUTOCONNECT, G_PARAM_READWRITE));
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_INIT (gst_a2dp_sink_debug, "a2dpsink", 0,
|
GST_DEBUG_CATEGORY_INIT (gst_a2dp_sink_debug, "a2dpsink", 0,
|
||||||
"A2DP sink element");
|
"A2DP sink element");
|
||||||
}
|
}
|
||||||
|
@ -639,6 +664,7 @@ gst_a2dp_sink_init (GstA2dpSink * self, GstA2dpSinkClass * klass)
|
||||||
self->fakesink = NULL;
|
self->fakesink = NULL;
|
||||||
self->rtp = NULL;
|
self->rtp = NULL;
|
||||||
self->device = NULL;
|
self->device = NULL;
|
||||||
|
self->autoconnect = DEFAULT_AUTOCONNECT;
|
||||||
self->capsfilter = NULL;
|
self->capsfilter = NULL;
|
||||||
self->newseg_event = NULL;
|
self->newseg_event = NULL;
|
||||||
self->taglist = NULL;
|
self->taglist = NULL;
|
||||||
|
|
|
@ -53,6 +53,7 @@ struct _GstA2dpSink {
|
||||||
GstElement *fakesink;
|
GstElement *fakesink;
|
||||||
|
|
||||||
gchar *device;
|
gchar *device;
|
||||||
|
gboolean autoconnect;
|
||||||
gboolean sink_is_in_bin;
|
gboolean sink_is_in_bin;
|
||||||
|
|
||||||
GstGhostPad *ghostpad;
|
GstGhostPad *ghostpad;
|
||||||
|
|
|
@ -51,6 +51,8 @@ GST_DEBUG_CATEGORY_STATIC (avdtp_sink_debug);
|
||||||
#define CRC_PROTECTED 1
|
#define CRC_PROTECTED 1
|
||||||
#define CRC_UNPROTECTED 0
|
#define CRC_UNPROTECTED 0
|
||||||
|
|
||||||
|
#define DEFAULT_AUTOCONNECT TRUE
|
||||||
|
|
||||||
#define GST_AVDTP_SINK_MUTEX_LOCK(s) G_STMT_START { \
|
#define GST_AVDTP_SINK_MUTEX_LOCK(s) G_STMT_START { \
|
||||||
g_mutex_lock (s->sink_lock); \
|
g_mutex_lock (s->sink_lock); \
|
||||||
} G_STMT_END
|
} G_STMT_END
|
||||||
|
@ -75,6 +77,7 @@ enum
|
||||||
{
|
{
|
||||||
PROP_0,
|
PROP_0,
|
||||||
PROP_DEVICE,
|
PROP_DEVICE,
|
||||||
|
PROP_AUTOCONNECT
|
||||||
};
|
};
|
||||||
|
|
||||||
GST_BOILERPLATE (GstAvdtpSink, gst_avdtp_sink, GstBaseSink, GST_TYPE_BASE_SINK);
|
GST_BOILERPLATE (GstAvdtpSink, gst_avdtp_sink, GstBaseSink, GST_TYPE_BASE_SINK);
|
||||||
|
@ -194,6 +197,9 @@ gst_avdtp_sink_set_property (GObject * object, guint prop_id,
|
||||||
sink->device = g_value_dup_string (value);
|
sink->device = g_value_dup_string (value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case PROP_AUTOCONNECT:
|
||||||
|
sink->autoconnect = g_value_get_boolean (value);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -211,6 +217,9 @@ gst_avdtp_sink_get_property (GObject * object, guint prop_id,
|
||||||
g_value_set_string (value, sink->device);
|
g_value_set_string (value, sink->device);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case PROP_AUTOCONNECT:
|
||||||
|
g_value_set_boolean (value, sink->autoconnect);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -758,6 +767,8 @@ gst_avdtp_sink_get_capabilities (GstAvdtpSink * self)
|
||||||
if (self->device == NULL)
|
if (self->device == NULL)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
strncpy (req->device, self->device, 18);
|
strncpy (req->device, self->device, 18);
|
||||||
|
if (self->autoconnect)
|
||||||
|
req->flags |= BT_FLAG_AUTOCONNECT;
|
||||||
|
|
||||||
io_error = gst_avdtp_sink_audioservice_send (self, &req->h);
|
io_error = gst_avdtp_sink_audioservice_send (self, &req->h);
|
||||||
if (io_error != G_IO_ERROR_NONE) {
|
if (io_error != G_IO_ERROR_NONE) {
|
||||||
|
@ -1176,6 +1187,12 @@ gst_avdtp_sink_class_init (GstAvdtpSinkClass * klass)
|
||||||
g_param_spec_string ("device", "Device",
|
g_param_spec_string ("device", "Device",
|
||||||
"Bluetooth remote device address", NULL, G_PARAM_READWRITE));
|
"Bluetooth remote device address", NULL, G_PARAM_READWRITE));
|
||||||
|
|
||||||
|
g_object_class_install_property (object_class, PROP_AUTOCONNECT,
|
||||||
|
g_param_spec_boolean ("auto-connect",
|
||||||
|
"Auto-connect",
|
||||||
|
"Automatically attempt to connect "
|
||||||
|
"to device", DEFAULT_AUTOCONNECT, G_PARAM_READWRITE));
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_INIT (avdtp_sink_debug, "avdtpsink", 0,
|
GST_DEBUG_CATEGORY_INIT (avdtp_sink_debug, "avdtpsink", 0,
|
||||||
"A2DP headset sink element");
|
"A2DP headset sink element");
|
||||||
}
|
}
|
||||||
|
@ -1190,6 +1207,8 @@ gst_avdtp_sink_init (GstAvdtpSink * self, GstAvdtpSinkClass * klass)
|
||||||
|
|
||||||
self->dev_caps = NULL;
|
self->dev_caps = NULL;
|
||||||
|
|
||||||
|
self->autoconnect = DEFAULT_AUTOCONNECT;
|
||||||
|
|
||||||
self->sink_lock = g_mutex_new ();
|
self->sink_lock = g_mutex_new ();
|
||||||
|
|
||||||
/* FIXME this is for not synchronizing with clock, should be tested
|
/* FIXME this is for not synchronizing with clock, should be tested
|
||||||
|
|
|
@ -54,6 +54,7 @@ struct _GstAvdtpSink {
|
||||||
GIOChannel *stream;
|
GIOChannel *stream;
|
||||||
|
|
||||||
struct bluetooth_data *data;
|
struct bluetooth_data *data;
|
||||||
|
gboolean autoconnect;
|
||||||
GIOChannel *server;
|
GIOChannel *server;
|
||||||
|
|
||||||
/* mp3 stream data (outside caps data)*/
|
/* mp3 stream data (outside caps data)*/
|
||||||
|
|
Loading…
Reference in a new issue