summaryrefslogtreecommitdiffstats
path: root/btif/src
diff options
context:
space:
mode:
authorSen-Der Huang <sdhuang@broadcom.com>2012-05-04 16:50:23 -0700
committerMatthew Xie <mattx@google.com>2012-07-14 11:19:20 -0700
commita858acd87bb1cb8f584b66a50e16b1adcfd6a42f (patch)
tree0aeee0882bbcb6152d924a7487ee76c04fc67616 /btif/src
parent32f0db60f911ed0b7f3bca0210a4568621b99074 (diff)
downloadexternal_bluetooth_bluedroid-a858acd87bb1cb8f584b66a50e16b1adcfd6a42f.zip
external_bluetooth_bluedroid-a858acd87bb1cb8f584b66a50e16b1adcfd6a42f.tar.gz
external_bluetooth_bluedroid-a858acd87bb1cb8f584b66a50e16b1adcfd6a42f.tar.bz2
Added OOB test
Change-Id: I7a494866eec45724e03a145394e032eb0930fceb
Diffstat (limited to 'btif/src')
-rwxr-xr-xbtif/src/btif_core.c6
-rwxr-xr-xbtif/src/btif_dm.c145
2 files changed, 150 insertions, 1 deletions
diff --git a/btif/src/btif_core.c b/btif/src/btif_core.c
index aa755ef..c8b0c8f 100755
--- a/btif/src/btif_core.c
+++ b/btif/src/btif_core.c
@@ -158,6 +158,9 @@ void bte_main_enable_lpm(BOOLEAN enable);
#endif
void bte_main_postload_cfg(void);
void btif_dm_execute_service_request(UINT16 event, char *p_param);
+#ifdef BTIF_DM_OOB_TEST
+void btif_dm_load_local_oob(void);
+#endif
/************************************************************************************
** Functions
@@ -538,6 +541,9 @@ void btif_enable_bluetooth_evt(tBTA_STATUS status, BD_ADDR local_bd)
/* load did configuration */
bte_load_did_conf(BTE_DID_CONF_FILE);
+#ifdef BTIF_DM_OOB_TEST
+ btif_dm_load_local_oob();
+#endif
/* now fully enabled, update state */
btif_core_state = BTIF_CORE_STATE_ENABLED;
diff --git a/btif/src/btif_dm.c b/btif/src/btif_dm.c
index ba63613..da37db5 100755
--- a/btif/src/btif_dm.c
+++ b/btif/src/btif_dm.c
@@ -60,7 +60,7 @@
#include <hardware/bluetooth.h>
#include <utils/Log.h>
-
+#include <cutils/properties.h>
#include "gki.h"
#include "btu.h"
#include "bd.h"
@@ -103,6 +103,12 @@ typedef struct {
BD_NAME bd_name;
} btif_dm_remote_name_t;
+typedef struct
+{
+ BT_OCTET16 sp_c;
+ BT_OCTET16 sp_r;
+ BD_ADDR oob_bdaddr; /* peer bdaddr*/
+} btif_dm_oob_cb_t;
#define BTA_SERVICE_ID_TO_SERVICE_MASK(id) (1 << (id))
/* This flag will be true if HCI_Inquiry is in progress */
@@ -112,6 +118,7 @@ static BOOLEAN btif_dm_inquiry_in_progress = FALSE;
** Static functions
******************************************************************************/
static btif_dm_pairing_cb_t pairing_cb;
+static btif_dm_oob_cb_t oob_cb;
static void btif_dm_generic_evt(UINT16 event, char* p_param);
static void btif_dm_cb_create_bond(bt_bdaddr_t *bd_addr);
static void btif_dm_cb_hid_remote_name(tBTM_REMOTE_DEV_NAME *p_remote_name);
@@ -1257,6 +1264,11 @@ static void btif_dm_generic_evt(UINT16 event, char* p_param)
}
break;
+ case BTIF_DM_CB_BOND_STATE_BONDING:
+ {
+ bond_state_changed(BT_STATUS_SUCCESS, (bt_bdaddr_t *)p_param, BT_BOND_STATE_BONDING);
+ }
+ break;
default:
{
BTIF_TRACE_WARNING2("%s : Unknown event 0x%x", __FUNCTION__, event);
@@ -1686,3 +1698,134 @@ void btif_dm_execute_service_request(UINT16 event, char *p_param)
}
return;
}
+
+#if (BTM_OOB_INCLUDED == TRUE)
+void btif_dm_set_oob_for_io_req(tBTA_OOB_DATA *p_oob_data)
+{
+ if (oob_cb.sp_c[0] == 0 && oob_cb.sp_c[1] == 0 &&
+ oob_cb.sp_c[2] == 0 && oob_cb.sp_c[3] == 0 )
+ {
+ *p_oob_data = FALSE;
+ }
+ else
+ {
+ *p_oob_data = TRUE;
+ }
+ BTIF_TRACE_DEBUG1("btif_dm_set_oob_for_io_req *p_oob_data=%d", *p_oob_data);
+}
+#endif /* BTM_OOB_INCLUDED */
+
+#ifdef BTIF_DM_OOB_TEST
+void btif_dm_load_local_oob(void)
+{
+ char prop_oob[32];
+ property_get("service.brcm.bt.oob", prop_oob, "3");
+ BTIF_TRACE_DEBUG1("btif_dm_load_local_oob prop_oob = %s",prop_oob);
+ if (prop_oob[0] != '3')
+ {
+#if (BTM_OOB_INCLUDED == TRUE)
+ if (oob_cb.sp_c[0] == 0 && oob_cb.sp_c[1] == 0 &&
+ oob_cb.sp_c[2] == 0 && oob_cb.sp_c[3] == 0 )
+ {
+ BTIF_TRACE_DEBUG0("btif_dm_load_local_oob: read OOB, call BTA_DmLocalOob()");
+ BTA_DmLocalOob();
+ }
+#else
+ BTIF_TRACE_ERROR0("BTM_OOB_INCLUDED is FALSE!!(btif_dm_load_local_oob)");
+#endif
+ }
+}
+
+void btif_dm_proc_loc_oob(BOOLEAN valid, BT_OCTET16 c, BT_OCTET16 r)
+{
+ FILE *fp;
+ char *path_a = "/data/misc/bluedroid/LOCAL/a.key";
+ char *path_b = "/data/misc/bluedroid/LOCAL/b.key";
+ char *path = NULL;
+ char prop_oob[32];
+ BTIF_TRACE_DEBUG1("btif_dm_proc_loc_oob: valid=%d", valid);
+ if (oob_cb.sp_c[0] == 0 && oob_cb.sp_c[1] == 0 &&
+ oob_cb.sp_c[2] == 0 && oob_cb.sp_c[3] == 0 &&
+ valid)
+ {
+ BTIF_TRACE_DEBUG0("save local OOB data in memory");
+ memcpy(oob_cb.sp_c, c, BT_OCTET16_LEN);
+ memcpy(oob_cb.sp_r, r, BT_OCTET16_LEN);
+ property_get("service.brcm.bt.oob", prop_oob, "3");
+ BTIF_TRACE_DEBUG1("btif_dm_proc_loc_oob prop_oob = %s",prop_oob);
+ if (prop_oob[0] == '1')
+ path = path_a;
+ else if (prop_oob[0] == '2')
+ path = path_b;
+ if (path)
+ {
+ fp = fopen(path, "wb+");
+ if (fp == NULL)
+ {
+ BTIF_TRACE_DEBUG1("btif_dm_proc_loc_oob: failed to save local OOB data to %s", path);
+ }
+ else
+ {
+ BTIF_TRACE_DEBUG1("btif_dm_proc_loc_oob: save local OOB data into file %s",path);
+ fwrite (c , 1 , BT_OCTET16_LEN , fp );
+ fwrite (r , 1 , BT_OCTET16_LEN , fp );
+ fclose(fp);
+ }
+ }
+ }
+}
+BOOLEAN btif_dm_proc_rmt_oob(BD_ADDR bd_addr, BT_OCTET16 p_c, BT_OCTET16 p_r)
+{
+ char t[128];
+ FILE *fp;
+ char *path_a = "/data/misc/bluedroid/LOCAL/a.key";
+ char *path_b = "/data/misc/bluedroid/LOCAL/b.key";
+ char *path = NULL;
+ char prop_oob[32];
+ BOOLEAN result = FALSE;
+ bt_bdaddr_t bt_bd_addr;
+ bdcpy(oob_cb.oob_bdaddr, bd_addr);
+ property_get("service.brcm.bt.oob", prop_oob, "3");
+ BTIF_TRACE_DEBUG1("btif_dm_proc_rmt_oob prop_oob = %s",prop_oob);
+ if (prop_oob[0] == '1')
+ path = path_b;
+ else if (prop_oob[0] == '2')
+ path = path_a;
+ if (path)
+ {
+ fp = fopen(path, "rb");
+ if (fp == NULL)
+ {
+ BTIF_TRACE_DEBUG1("btapp_dm_rmt_oob_reply: failed to read OOB keys from %s",path);
+ return FALSE;
+ }
+ else
+ {
+ BTIF_TRACE_DEBUG1("btif_dm_proc_rmt_oob: read OOB data from %s",path);
+ fread (p_c , 1 , BT_OCTET16_LEN , fp );
+ fread (p_r , 1 , BT_OCTET16_LEN , fp );
+ fclose(fp);
+ }
+ BTIF_TRACE_DEBUG0("----btif_dm_proc_rmt_oob: TRUE");
+ sprintf(t, "%02x:%02x:%02x:%02x:%02x:%02x",
+ oob_cb.oob_bdaddr[0], oob_cb.oob_bdaddr[1], oob_cb.oob_bdaddr[2],
+ oob_cb.oob_bdaddr[3], oob_cb.oob_bdaddr[4], oob_cb.oob_bdaddr[5]);
+ BTIF_TRACE_DEBUG1("----btif_dm_proc_rmt_oob: peer_bdaddr = %s", t);
+ sprintf(t, "%02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x",
+ p_c[0], p_c[1], p_c[2], p_c[3], p_c[4], p_c[5], p_c[6], p_c[7],
+ p_c[8], p_c[9], p_c[10], p_c[11], p_c[12], p_c[13], p_c[14], p_c[15]);
+ BTIF_TRACE_DEBUG1("----btif_dm_proc_rmt_oob: c = %s",t);
+ sprintf(t, "%02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x",
+ p_r[0], p_r[1], p_r[2], p_r[3], p_r[4], p_r[5], p_r[6], p_r[7],
+ p_r[8], p_r[9], p_r[10], p_r[11], p_r[12], p_r[13], p_r[14], p_r[15]);
+ BTIF_TRACE_DEBUG1("----btif_dm_proc_rmt_oob: r = %s",t);
+ bdcpy(bt_bd_addr.address, bd_addr);
+ btif_transfer_context(btif_dm_generic_evt, BTIF_DM_CB_BOND_STATE_BONDING,
+ (char *)&bt_bd_addr, sizeof(bt_bdaddr_t), NULL);
+ result = TRUE;
+ }
+ BTIF_TRACE_DEBUG1("btif_dm_proc_rmt_oob result=%d",result);
+ return result;
+}
+#endif /* BTIF_DM_OOB_TEST */
+