diff --git a/audio/control.c b/audio/control.c
index 37b027b..1620128 100644
--- a/audio/control.c
+++ b/audio/control.c
struct avctp *session;
gboolean target;
DBusMessage *connect;
- DBusMessage *disconnect;
};
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;
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;
+ return dbus_message_new_method_return(msg);
}
static DBusMessage *key_pressed(DBusConnection *conn, DBusMessage *msg,
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("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) },
if (control->connect)
dbus_message_unref(control->connect);
- if (control->disconnect)
- dbus_message_unref(control->disconnect);
-
g_free(control);
dev->control = NULL;
}