diff options
author | Andrzej Kaczmarek <andrzej.kaczmarek@tieto.com> | 2014-05-16 20:22:48 +0200 |
---|---|---|
committer | Szymon Janc <szymon.janc@tieto.com> | 2014-05-19 10:10:33 +0200 |
commit | c3364dee4a0b4eccc549de14f0adb2cd4d5a8fdc (patch) | |
tree | 304e4b9865a547001dfe356d358bd8fd3830980a /android/bluetooth.c | |
parent | 3afaef7655f50e58473927060acae9831cd4f6d3 (diff) | |
download | bluez-c3364dee4a0b4eccc549de14f0adb2cd4d5a8fdc.tar.gz |
android/bluetooth: Add support to read connection RSSI
Diffstat (limited to 'android/bluetooth.c')
-rw-r--r-- | android/bluetooth.c | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/android/bluetooth.c b/android/bluetooth.c index 1e760d4af..e1dc96586 100644 --- a/android/bluetooth.c +++ b/android/bluetooth.c @@ -3033,6 +3033,62 @@ bool bt_le_discovery_start(bt_le_device_found cb) return false; } +struct read_rssi_user_data { + bt_read_device_rssi_done cb; + void *user_data; +}; + +static void read_device_rssi_cb(uint8_t status, uint16_t length, + const void *param, void *user_data) +{ + const struct mgmt_rp_get_conn_info *rp = param; + struct read_rssi_user_data *data = user_data; + + DBG(""); + + if (status) + error("Failed to get conn info: %s (0x%02x))", + mgmt_errstr(status), status); + + if (length < sizeof(*rp)) { + error("Wrong size of get conn info response"); + return; + } + + data->cb(status, &rp->addr.bdaddr, rp->rssi, data->user_data); +} + +bool bt_read_device_rssi(const bdaddr_t *addr, bt_read_device_rssi_done cb, + void *user_data) +{ + struct device *dev; + struct read_rssi_user_data *data; + struct mgmt_cp_get_conn_info cp; + + dev = find_device(addr); + if (!dev) + return false; + + memcpy(&cp.addr.bdaddr, addr, sizeof(cp.addr.bdaddr)); + cp.addr.type = dev->bredr ? BDADDR_BREDR : dev->bdaddr_type; + + data = new0(struct read_rssi_user_data, 1); + if (!data) + return false; + + data->cb = cb; + data->user_data = user_data; + + if (!mgmt_send(mgmt_if, MGMT_OP_GET_CONN_INFO, adapter.index, + sizeof(cp), &cp, read_device_rssi_cb, data, free)) { + free(data); + error("Failed to get conn info"); + return false; + } + + return true; +} + static uint8_t set_adapter_scan_mode(const void *buf, uint16_t len) { const uint8_t *mode = buf; |