From 6f338a8f6ab1b79aa9e7066054bec7b4668cfa23 Mon Sep 17 00:00:00 2001 From: Claudio Takahasi Date: Fri, 1 Jun 2012 14:48:38 -0300 Subject: [PATCH] core: Fix connected callback not being called ATTIO callbacks are not being added in the list when there is a connection attempt pending. --- src/device.c | 21 +++++++++------------ 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/src/device.c b/src/device.c index fc8c31add..de2f0102e 100644 --- a/src/device.c +++ b/src/device.c @@ -3092,23 +3092,20 @@ guint btd_device_add_attio_callback(struct btd_device *device, attio->dcfunc = dcfunc; attio->user_data = user_data; - if (device->attrib) { - if (cfunc) { - device->attios_offline = - g_slist_append(device->attios_offline, attio); + if (device->attrib && cfunc) { + device->attios_offline = g_slist_append(device->attios_offline, + attio); + g_idle_add(notify_attios, device); + return attio->id; + } - g_idle_add(notify_attios, device); - } else { - device->attios = g_slist_append(device->attios, attio); - } - } else if (device->auto_id == 0) { + device->attios = g_slist_append(device->attios, attio); + + if (device->auto_id == 0) device->auto_id = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, att_connect, device, att_connect_dispatched); - device->attios = g_slist_append(device->attios, attio); - } - return attio->id; } -- 2.47.3