--- android/gatt.c | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/android/gatt.c b/android/gatt.c index dea253e..542c9b4 100644 --- a/android/gatt.c +++ b/android/gatt.c @@ -1877,6 +1877,16 @@ static bool trigger_connection(struct app_connection *connection) return ret; } +static void remove_autoconnect_device(struct gatt_device *dev) +{ + bt_auto_connect_remove(&dev->bdaddr); + + if (dev->state == DEVICE_CONNECT_INIT) + device_set_state(dev, DEVICE_DISCONNECTED); + + device_unref(dev); +} + static void clear_autoconnect_devices(int app_id) { struct gatt_device *dev; @@ -1889,14 +1899,10 @@ static void clear_autoconnect_devices(int app_id) while (dev) { queue_remove(dev->autoconnect_apps, INT_TO_PTR(app_id)); - if (queue_isempty(dev->autoconnect_apps)) { - bt_auto_connect_remove(&dev->bdaddr); - - if (dev->state == DEVICE_CONNECT_INIT) - device_set_state(dev, DEVICE_DISCONNECTED); + if (queue_isempty(dev->autoconnect_apps)) + remove_autoconnect_device(dev); device_unref(dev); - } dev = find_device_by_autoconnect_app_id(app_id); }; @@ -6826,12 +6832,8 @@ void bt_gatt_remove_autoconnect(unsigned int id, const bdaddr_t *addr) queue_remove(dev->autoconnect_apps, INT_TO_PTR(id)); - if (queue_isempty(dev->autoconnect_apps)) { - bt_auto_connect_remove(addr); - - if (dev->state == DEVICE_CONNECT_INIT) - device_set_state(dev, DEVICE_DISCONNECTED); + if (queue_isempty(dev->autoconnect_apps)) + remove_autoconnect_device(dev); device_unref(dev); - } } -- 1.8.4 -- 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