Diff between 31951cc6c03ca7d3c2e4a4ca4fb0b1561b7ea2e5 and 03fdd8bc7627f887b915e70b4714e085242a2afb

Changed Files

File Additions Deletions Status
audio/control.c +31 -0 modified
doc/control-api.txt +4 -0 modified

Full Patch

diff --git a/audio/control.c b/audio/control.c
index e15e9ba..8bb085a 100644
--- a/audio/control.c
+++ b/audio/control.c
@@ -62,6 +62,7 @@ struct control {
 	struct avctp *session;
 	gboolean target;
 	DBusMessage *connect;
+	DBusMessage *disconnect;
 };
 
 static void state_changed(struct audio_device *dev, avctp_state_t old_state,
@@ -83,6 +84,13 @@ static void state_changed(struct audio_device *dev, avctp_state_t old_state,
 			control->connect = NULL;
 		}
 
+		if (control->disconnect) {
+			g_dbus_send_reply(conn, control->disconnect,
+							DBUS_TYPE_INVALID);
+			dbus_message_unref(control->disconnect);
+			control->disconnect = NULL;
+		}
+
 		if (old_state != AVCTP_STATE_CONNECTED)
 			break;
 
@@ -164,6 +172,25 @@ static DBusMessage *control_connect(DBusConnection *conn, DBusMessage *msg,
 	return NULL;
 }
 
+static DBusMessage *control_disconnect(DBusConnection *conn, DBusMessage *msg,
+								void *data)
+{
+	struct audio_device *device = data;
+	struct control *control = device->control;
+
+	if (!control->session)
+		return btd_error_not_connected(msg);
+
+	if (control->disconnect)
+		return btd_error_in_progress(msg);
+
+	avctp_disconnect(control->session);
+
+	control->disconnect = dbus_message_ref(msg);
+
+	return NULL;
+}
+
 static DBusMessage *key_pressed(DBusConnection *conn, DBusMessage *msg,
 						uint8_t op, void *data)
 {
@@ -243,6 +270,7 @@ static const GDBusMethodTable control_methods[] = {
 				NULL, GDBUS_ARGS({ "connected", "b" }),
 				control_is_connected) },
 	{ GDBUS_ASYNC_METHOD("Connect", NULL, NULL, control_connect) },
+	{ GDBUS_ASYNC_METHOD("Disconnect", NULL, NULL, control_disconnect) },
 	{ GDBUS_METHOD("Play", NULL, NULL, control_play) },
 	{ GDBUS_METHOD("Pause", NULL, NULL, control_pause) },
 	{ GDBUS_METHOD("Stop", NULL, NULL, control_stop) },
@@ -278,6 +306,9 @@ static void path_unregister(void *data)
 	if (control->connect)
 		dbus_message_unref(control->connect);
 
+	if (control->disconnect)
+		dbus_message_unref(control->disconnect);
+
 	g_free(control);
 	dev->control = NULL;
 }
diff --git a/doc/control-api.txt b/doc/control-api.txt
index 61069ea..5391a8a 100644
--- a/doc/control-api.txt
+++ b/doc/control-api.txt
@@ -25,6 +25,10 @@ Methods		boolean IsConnected() {deprecated}
 
 			Connect to remote device.
 
+		void Disconnect()
+
+			Disconnect from remote device.
+
 		void Play()
 
 			Resume playback.