summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohan Hedberg <johan.hedberg@nokia.com>2007-10-02 15:15:58 +0000
committerJohan Hedberg <johan.hedberg@nokia.com>2007-10-02 15:15:58 +0000
commitb0a7532f6111103e4e2e21eb45d30a34c49f1f77 (patch)
treee968bb4a110b164af545ea3d634ef4d38c1aa377
parent0db61b63bb7299684ecb7d5a56a6fd35b3e8f4de (diff)
Fix audio service SDP failure handling
-rw-r--r--audio/manager.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/audio/manager.c b/audio/manager.c
index 43635578..18997556 100644
--- a/audio/manager.c
+++ b/audio/manager.c
@@ -88,6 +88,8 @@ struct audio_sdp_data {
audio_sdp_state_t state;
+ gboolean remove_on_fail;
+
create_dev_cb_t cb;
void *cb_data;
};
@@ -295,8 +297,12 @@ static void finish_sdp(struct audio_sdp_data *data, gboolean success)
device_finish_sdp_transaction(data->device);
- if (!success)
+ if (!success) {
+ error("finish_sdp: SDP failed");
+ if (data->msg)
+ err_failed(connection, data->msg, "Failed");
goto done;
+ }
if (!data->msg)
goto update;
@@ -309,6 +315,7 @@ static void finish_sdp(struct audio_sdp_data *data, gboolean success)
if (dbus_error_is_set(&derr)) {
error("Unable to get message args");
success = FALSE;
+ err_failed(connection, data->msg, derr.message);
dbus_error_free(&derr);
goto done;
}
@@ -346,7 +353,8 @@ done:
if (data->cb)
data->cb(data->device, data->cb_data);
} else {
- remove_device(data->device);
+ if (data->remove_on_fail)
+ remove_device(data->device);
if (data->cb)
data->cb(NULL, data->cb_data);
}
@@ -585,6 +593,7 @@ failed:
static DBusHandlerResult resolve_services(DBusMessage *msg,
struct device *device,
+ gboolean remove_on_fail,
create_dev_cb_t cb,
void *user_data)
{
@@ -594,6 +603,7 @@ static DBusHandlerResult resolve_services(DBusMessage *msg,
if (msg)
sdp_data->msg = dbus_message_ref(msg);
sdp_data->device = device;
+ sdp_data->remove_on_fail = remove_on_fail;
sdp_data->cb = cb;
sdp_data->cb_data = user_data;
@@ -648,7 +658,7 @@ struct device *manager_device_connected(bdaddr_t *bda, const char *uuid)
"DeviceCreated",
DBUS_TYPE_STRING, &path,
DBUS_TYPE_INVALID);
- resolve_services(NULL, device, NULL, NULL);
+ resolve_services(NULL, device, FALSE, NULL, NULL);
}
if (headset)
@@ -688,7 +698,7 @@ gboolean manager_create_device(bdaddr_t *bda, create_dev_cb_t cb,
if (!dev)
return FALSE;
- resolve_services(NULL, dev, cb, user_data);
+ resolve_services(NULL, dev, TRUE, cb, user_data);
return TRUE;
}
@@ -719,7 +729,7 @@ static DBusHandlerResult am_create_device(DBusConnection *conn,
device = manager_find_device(&bda, NULL, FALSE);
if (!device) {
device = create_device(&bda);
- return resolve_services(msg, device, NULL, NULL);
+ return resolve_services(msg, device, TRUE, NULL, NULL);
}
path = device->path;