From: Mikel Astiz <mikel.astiz@xxxxxxxxxxxx> Refactor code to drop the device authorizing flag by replacing it with a private authorization pointer in btd_adapter. After all, no more than one authorization can be ongoing, so the code is easier to follow if this is made explicit. --- src/adapter.c | 55 +++++++++++++++++++++++++++++++++++++------------------ src/device.c | 11 ----------- src/device.h | 2 -- 3 files changed, 37 insertions(+), 31 deletions(-) diff --git a/src/adapter.c b/src/adapter.c index f9acbd5..366a99f 100644 --- a/src/adapter.c +++ b/src/adapter.c @@ -127,7 +127,8 @@ struct btd_adapter { GSList *found_devices; GSList *oor_devices; /* out of range device list */ struct agent *agent; /* For the new API */ - guint auth_idle_id; /* Ongoing authorization */ + guint auth_idle_id; /* Ongoing authorization (trusted) */ + struct service_auth *auth; /* Ongoing authorization */ GSList *connections; /* Connected devices */ GSList *devices; /* Devices structure pointers */ GSList *mode_sessions; /* Request Mode sessions */ @@ -967,8 +968,11 @@ void adapter_remove_device(struct btd_adapter *adapter, agent = device_get_agent(device); - if (agent && device_is_authorizing(device)) + if (agent && adapter->auth && adapter->auth->device == device) { + g_free(adapter->auth); + adapter->auth = NULL; agent_cancel(agent); + } device_remove(device, remove_storage); } @@ -2408,6 +2412,9 @@ static void adapter_free(gpointer user_data) if (adapter->auth_idle_id) g_source_remove(adapter->auth_idle_id); + if (adapter->auth) + g_free(adapter->auth); + if (adapter->off_timer) off_timer_remove(adapter); @@ -3142,22 +3149,28 @@ void btd_unregister_adapter_driver(struct btd_adapter_driver *driver) static void agent_auth_cb(struct agent *agent, DBusError *derr, void *user_data) { - struct service_auth *auth = user_data; + struct btd_adapter *adapter = user_data; + struct service_auth *auth = adapter->auth; - device_set_authorizing(auth->device, FALSE); + adapter->auth = NULL; auth->cb(derr, auth->user_data); + + g_free(auth); } static gboolean auth_idle_cb(gpointer user_data) { - struct service_auth *auth = user_data; - struct btd_adapter *adapter = auth->adapter; + struct btd_adapter *adapter = user_data; + struct service_auth *auth = adapter->auth; + adapter->auth = NULL; adapter->auth_idle_id = 0; auth->cb(NULL, auth->user_data); + g_free(auth); + return FALSE; } @@ -3181,7 +3194,7 @@ static int adapter_authorize(struct btd_adapter *adapter, const bdaddr_t *dst, if (!g_slist_find(adapter->connections, device)) error("Authorization request for non-connected device!?"); - if (adapter->auth_idle_id) + if (adapter->auth != NULL) return -EBUSY; auth = g_try_new0(struct service_auth, 1); @@ -3194,10 +3207,8 @@ static int adapter_authorize(struct btd_adapter *adapter, const bdaddr_t *dst, auth->adapter = adapter; if (device_is_trusted(device) == TRUE) { - adapter->auth_idle_id = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, - auth_idle_cb, auth, - g_free); - return 0; + adapter->auth_idle_id = g_idle_add(auth_idle_cb, adapter); + goto done; } agent = device_get_agent(device); @@ -3209,13 +3220,16 @@ static int adapter_authorize(struct btd_adapter *adapter, const bdaddr_t *dst, dev_path = device_get_path(device); - err = agent_authorize(agent, dev_path, uuid, agent_auth_cb, auth, g_free); - if (err < 0) + err = agent_authorize(agent, dev_path, uuid, agent_auth_cb, adapter, + NULL); + if (err < 0) { g_free(auth); - else - device_set_authorizing(device, TRUE); + return err; + } - return err; +done: + adapter->auth = auth; + return 0; } int btd_request_authorization(const bdaddr_t *src, const bdaddr_t *dst, @@ -3268,6 +3282,9 @@ int btd_cancel_authorization(const bdaddr_t *src, const bdaddr_t *dst) return 0; } + if (!adapter->auth || adapter->auth->device != device) + return -EPERM; + /* * FIXME: Cancel fails if authorization is requested to adapter's * agent and in the meanwhile CreatePairedDevice is called. @@ -3279,8 +3296,10 @@ int btd_cancel_authorization(const bdaddr_t *src, const bdaddr_t *dst) err = agent_cancel(agent); - if (err == 0) - device_set_authorizing(device, FALSE); + if (err == 0) { + g_free(adapter->auth); + adapter->auth = NULL; + } return err; } diff --git a/src/device.c b/src/device.c index aa3a607..a19e98d 100644 --- a/src/device.c +++ b/src/device.c @@ -161,7 +161,6 @@ struct btd_device { gboolean bonded; gboolean auto_connect; - gboolean authorizing; gint ref; GIOChannel *att_io; @@ -2916,16 +2915,6 @@ gboolean device_is_authenticating(struct btd_device *device) return (device->authr != NULL); } -gboolean device_is_authorizing(struct btd_device *device) -{ - return device->authorizing; -} - -void device_set_authorizing(struct btd_device *device, gboolean auth) -{ - device->authorizing = auth; -} - void device_register_services(struct btd_device *device, GSList *prim_list, int psm) { diff --git a/src/device.h b/src/device.h index aee6d13..b704a4c 100644 --- a/src/device.h +++ b/src/device.h @@ -98,8 +98,6 @@ int device_notify_pincode(struct btd_device *device, gboolean secure, const char *pincode, void *cb); void device_cancel_authentication(struct btd_device *device, gboolean aborted); gboolean device_is_authenticating(struct btd_device *device); -gboolean device_is_authorizing(struct btd_device *device); -void device_set_authorizing(struct btd_device *device, gboolean auth); void device_add_connection(struct btd_device *device); void device_remove_connection(struct btd_device *device); void device_request_disconnect(struct btd_device *device, DBusMessage *msg); -- 1.7.7.6 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html