Return-Path: From: Lukasz Rymanowski To: linux-bluetooth@vger.kernel.org Cc: Lukasz Rymanowski Subject: [PATCH v3 3/3] android/gatt: Add remove bond handling Date: Fri, 29 Aug 2014 11:54:00 +0200 Message-Id: <1409306040-3162-4-git-send-email-lukasz.rymanowski@tieto.com> In-Reply-To: <1409306040-3162-1-git-send-email-lukasz.rymanowski@tieto.com> References: <1409306040-3162-1-git-send-email-lukasz.rymanowski@tieto.com> Sender: linux-bluetooth-owner@vger.kernel.org List-ID: With this patch GATT is aware about unpaired devices so the local cache can be cleared --- android/gatt.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/android/gatt.c b/android/gatt.c index 89748d2..ae310f7 100644 --- a/android/gatt.c +++ b/android/gatt.c @@ -6496,10 +6496,34 @@ static bool start_listening(void) return true; } +static void gatt_unpaired_cb(const bdaddr_t *addr, uint8_t type) +{ + struct gatt_device *dev; + char address[18]; + + dev = find_device_by_addr(addr); + if (!dev) + return; + + if (dev->bdaddr_type != type) + return; + + ba2str(addr, address); + DBG("Unpaired device %s", address); + + queue_remove(gatt_devices, dev); + destroy_device(dev); +} + bool bt_gatt_register(struct ipc *ipc, const bdaddr_t *addr) { DBG(""); + if (!bt_unpaired_register(gatt_unpaired_cb)) { + error("gatt: Could not register unpaired callback"); + return false; + } + if (!start_listening()) return false; @@ -6628,6 +6652,7 @@ void bt_gatt_unregister(void) crypto = NULL; bt_le_unregister(); + bt_unpaired_unregister(gatt_unpaired_cb); } unsigned int bt_gatt_register_app(const char *uuid, gatt_type_t type, -- 1.8.4