Diff between 08228cf45a5af660577312ebaee996ee212ccca9 and a5ee41a24f65e53f4398b90a5cb8cb819843860b

Changed Files

File Additions Deletions Status
android/bluetooth.c +11 -0 modified

Full Patch

diff --git a/android/bluetooth.c b/android/bluetooth.c
index aee0c56..041f922 100644
--- a/android/bluetooth.c
+++ b/android/bluetooth.c
@@ -2470,6 +2470,14 @@ static bool start_discovery(void)
 	return false;
 }
 
+static void cancel_pending_confirm_name(gpointer data, gpointer user_data)
+{
+	struct device *dev = data;
+
+	mgmt_cancel(mgmt_if, dev->confirm_id);
+	dev->confirm_id = 0;
+}
+
 static bool stop_discovery(void)
 {
 	struct mgmt_cp_stop_discovery cp;
@@ -2484,6 +2492,9 @@ static bool stop_discovery(void)
 
 	DBG("type=0x%x", cp.type);
 
+	/* Lets drop all confirm name request as we don't need it anymore */
+	g_slist_foreach(cached_devices, cancel_pending_confirm_name, NULL);
+
 	if (mgmt_send(mgmt_if, MGMT_OP_STOP_DISCOVERY, adapter.index,
 					sizeof(cp), &cp, NULL, NULL, NULL) > 0)
 		return true;