Info is now stored for all devices and bond state depends on linkkey being stored. Based on that devices loaded from storage are put either to cache or to bonded_devices list. --- android/bluetooth.c | 27 +++++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) diff --git a/android/bluetooth.c b/android/bluetooth.c index df442a3..dfbbe1a 100644 --- a/android/bluetooth.c +++ b/android/bluetooth.c @@ -1695,7 +1695,8 @@ static void clear_uuids(void) sizeof(cp), &cp, NULL, NULL, NULL); } -static void create_device_from_info(GKeyFile *key_file, const char *peer) +static struct device *create_device_from_info(GKeyFile *key_file, + const char *peer) { struct device *dev; uint8_t type; @@ -1710,7 +1711,7 @@ static void create_device_from_info(GKeyFile *key_file, const char *peer) str2ba(peer, &bdaddr); dev = create_device(&bdaddr, type); - dev->bond_state = HAL_BOND_STATE_BONDED; + dev->bond_state = HAL_BOND_STATE_NONE; str = g_key_file_get_string(key_file, peer, "Name", NULL); if (str) { @@ -1746,6 +1747,8 @@ static void create_device_from_info(GKeyFile *key_file, const char *peer) g_strfreev(uuids); } + + return dev; } static struct mgmt_link_key_info *get_key_info(GKeyFile *key_file, const char *peer) @@ -1778,6 +1781,14 @@ failed: return info; } +static int device_timestamp_cmp(gconstpointer a, gconstpointer b) +{ + const struct device *deva = a; + const struct device *devb = b; + + return deva->timestamp < devb->timestamp; +} + static void load_devices_info(bt_bluetooth_ready cb) { GKeyFile *key_file; @@ -1794,16 +1805,24 @@ static void load_devices_info(bt_bluetooth_ready cb) for (i = 0; i < len; i++) { struct mgmt_link_key_info *key_info; + struct device *dev; - create_device_from_info(key_file, devs[i]); + dev = create_device_from_info(key_file, devs[i]); key_info = get_key_info(key_file, devs[i]); - if (key_info) + if (key_info) { keys = g_slist_prepend(keys, key_info); + bonded_devices = g_slist_prepend(bonded_devices, dev); + dev->bond_state = HAL_BOND_STATE_BONDED; + } else { + devices = g_slist_prepend(devices, dev); + } /* TODO ltk */ } + devices = g_slist_sort(devices, device_timestamp_cmp); + load_link_keys(keys, cb); g_strfreev(devs); g_slist_free_full(keys, g_free); -- 1.8.3.2 -- 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