summaryrefslogtreecommitdiff
path: root/android/hal-utils.c
diff options
context:
space:
mode:
authorLukasz Rymanowski <lukasz.rymanowski@tieto.com>2014-11-27 10:29:00 +0100
committerSzymon Janc <szymon.janc@tieto.com>2014-11-27 12:12:24 +0100
commit32da6e18ea36aeb01b9f82d74689fb1e061f3313 (patch)
tree41fa609abbdfbc19fac04469930b15a041d901d2 /android/hal-utils.c
parentacdbfb307a47f25c1280c2987ceecf24511f0767 (diff)
downloadbluez-32da6e18ea36aeb01b9f82d74689fb1e061f3313.tar.gz
android/client: Add support to read local le features
Diffstat (limited to 'android/hal-utils.c')
-rw-r--r--android/hal-utils.c68
1 files changed, 68 insertions, 0 deletions
diff --git a/android/hal-utils.c b/android/hal-utils.c
index 05e8920fb..f18a82c5f 100644
--- a/android/hal-utils.c
+++ b/android/hal-utils.c
@@ -22,6 +22,7 @@
#include <cutils/properties.h>
+#include "hal.h"
#include "hal-utils.h"
/*
@@ -116,6 +117,7 @@ INTMAP(bt_ssp_variant_t, -1, "(unknown)")
DELEMENT(BT_SSP_VARIANT_PASSKEY_NOTIFICATION),
ENDMAP
+#if ANDROID_VERSION >= PLATFORM_VER(5, 0, 0)
INTMAP(bt_property_type_t, -1, "(unknown)")
DELEMENT(BT_PROPERTY_BDNAME),
DELEMENT(BT_PROPERTY_BDADDR),
@@ -129,8 +131,26 @@ INTMAP(bt_property_type_t, -1, "(unknown)")
DELEMENT(BT_PROPERTY_REMOTE_FRIENDLY_NAME),
DELEMENT(BT_PROPERTY_REMOTE_RSSI),
DELEMENT(BT_PROPERTY_REMOTE_VERSION_INFO),
+ DELEMENT(BT_PROPERTY_LOCAL_LE_FEATURES),
DELEMENT(BT_PROPERTY_REMOTE_DEVICE_TIMESTAMP),
ENDMAP
+#else
+INTMAP(bt_property_type_t, -1, "(unknown)")
+ DELEMENT(BT_PROPERTY_BDNAME),
+ DELEMENT(BT_PROPERTY_BDADDR),
+ DELEMENT(BT_PROPERTY_UUIDS),
+ DELEMENT(BT_PROPERTY_CLASS_OF_DEVICE),
+ DELEMENT(BT_PROPERTY_TYPE_OF_DEVICE),
+ DELEMENT(BT_PROPERTY_SERVICE_RECORD),
+ DELEMENT(BT_PROPERTY_ADAPTER_SCAN_MODE),
+ DELEMENT(BT_PROPERTY_ADAPTER_BONDED_DEVICES),
+ DELEMENT(BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT),
+ DELEMENT(BT_PROPERTY_REMOTE_FRIENDLY_NAME),
+ DELEMENT(BT_PROPERTY_REMOTE_RSSI),
+ DELEMENT(BT_PROPERTY_REMOTE_VERSION_INFO),
+ DELEMENT(BT_PROPERTY_REMOTE_DEVICE_TIMESTAMP),
+ENDMAP
+#endif
INTMAP(bt_cb_thread_evt, -1, "(unknown)")
DELEMENT(ASSOCIATE_JVM),
@@ -326,7 +346,55 @@ const char *btproperty2str(const bt_property_t *property)
rec->channel, rec->name);
}
break;
+#if ANDROID_VERSION >= PLATFORM_VER(5, 0, 0)
+ case BT_PROPERTY_LOCAL_LE_FEATURES:
+ {
+ bt_local_le_features_t *f = property->val;
+ int l;
+ uint16_t s;
+
+ l = sprintf(p, "{\n");
+ p += l;
+
+ l = sprintf(p, "Privacy supported: %s,\n",
+ f->local_privacy_enabled ?
+ "TRUE" : "FALSE");
+ p += l;
+
+ l = sprintf(p, "Num of advertising instances: %u,\n",
+ f->max_adv_instance);
+ p += l;
+
+ l = sprintf(p, "PRA offloading support: %s,\n",
+ f->rpa_offload_supported ?
+ "TRUE" : "FALSE");
+
+ p += l;
+ l = sprintf(p, "Num of offloaded IRKs: %u,\n",
+ f->max_irk_list_size);
+ p += l;
+
+ l = sprintf(p, "Num of offloaded scan filters: %u,\n",
+ f->max_adv_filter_supported);
+ p += l;
+
+ s = (f->scan_result_storage_size_hibyte << 8) +
+ f->scan_result_storage_size_lobyte;
+
+ l = sprintf(p, "Num of offloaded scan results: %u,\n",
+ s);
+ p += l;
+
+ l = sprintf(p, "Activity & energy report support: %s\n",
+ f->activity_energy_info_supported ?
+ "TRUE" : "FALSE");
+ p += l;
+
+ sprintf(p, "}");
+ }
+ break;
+#endif
default:
sprintf(p, "%p", property->val);
}