From 9180d1f8e8485b065f4a72c0f1dd05af9c662576 Mon Sep 17 00:00:00 2001 From: Lukasz Rymanowski Date: Wed, 17 Dec 2014 16:49:02 +0100 Subject: [PATCH] android/gatt: Add paired cb to gatt.c This will be required in order to register for Service Changed on remote device --- android/gatt.c | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/android/gatt.c b/android/gatt.c index 0258d9125..00efb40e4 100644 --- a/android/gatt.c +++ b/android/gatt.c @@ -7046,6 +7046,24 @@ static bool start_listening(void) return true; } +static void gatt_paired_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("Paired device %s", address); + + /* Find Service Changed and register for it.*/ +} + static void gatt_unpaired_cb(const bdaddr_t *addr, uint8_t type) { struct gatt_device *dev; @@ -7069,6 +7087,11 @@ bool bt_gatt_register(struct ipc *ipc, const bdaddr_t *addr) { DBG(""); + if (!bt_paired_register(gatt_paired_cb)) { + error("gatt: Could not register paired callback"); + return false; + } + if (!bt_unpaired_register(gatt_unpaired_cb)) { error("gatt: Could not register unpaired callback"); return false; @@ -7118,6 +7141,10 @@ bool bt_gatt_register(struct ipc *ipc, const bdaddr_t *addr) return true; failed: + + bt_paired_unregister(gatt_paired_cb); + bt_unpaired_unregister(gatt_unpaired_cb); + queue_destroy(gatt_apps, NULL); gatt_apps = NULL; -- 2.47.3