summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--bta/include/bta_hh_api.h23
-rwxr-xr-x[-rw-r--r--]btif/include/btif_hh.h7
-rwxr-xr-x[-rw-r--r--]btif/src/btif_dm.c44
-rwxr-xr-x[-rw-r--r--]btif/src/btif_hh.c208
-rwxr-xr-x[-rw-r--r--]btif/src/btif_util.c2
5 files changed, 177 insertions, 107 deletions
diff --git a/bta/include/bta_hh_api.h b/bta/include/bta_hh_api.h
index 41af74c..dd9a528 100644
--- a/bta/include/bta_hh_api.h
+++ b/bta/include/bta_hh_api.h
@@ -376,6 +376,29 @@ BTA_API extern void BTA_HhSendCtrl(UINT8 dev_handle,
/*******************************************************************************
**
+** Function BTA_HhSetIdle
+**
+** Description send SET_IDLE to device.
+**
+** Returns void
+**
+*******************************************************************************/
+BTA_API extern void BTA_HhSetIdle(UINT8 dev_handle, UINT16 idle_rate);
+
+
+/*******************************************************************************
+**
+** Function BTA_HhGetIdle
+**
+** Description Send a GET_IDLE from HID device.
+**
+** Returns void
+**
+*******************************************************************************/
+BTA_API extern void BTA_HhGetIdle(UINT8 dev_handle);
+
+/*******************************************************************************
+**
** Function BTA_HhSendData
**
** Description Send DATA transaction to a HID device.
diff --git a/btif/include/btif_hh.h b/btif/include/btif_hh.h
index 0c6d866..2849d63 100644..100755
--- a/btif/include/btif_hh.h
+++ b/btif/include/btif_hh.h
@@ -92,8 +92,9 @@ typedef enum
BTIF_HH_ENABLED,
BTIF_HH_DISABLING,
BTIF_HH_DEV_UNKNOWN,
- BTIF_HH_DEV_PAIRED,
- BTIF_HH_DEV_CONNECTED
+ BTIF_HH_DEV_CONNECTING,
+ BTIF_HH_DEV_CONNECTED,
+ BTIF_HH_DEV_DISCONNECTED
} BTIF_HH_STATUS;
// BTIF-HH control block to maintain added devices and current connected hid device
@@ -111,7 +112,7 @@ extern btif_hh_cb_t btif_hh_cb;
extern btif_hh_device_t *btif_hh_find_connected_dev_by_handle(UINT8 handle);
extern void btif_hh_remove_device(bt_bdaddr_t bd_addr);
BOOLEAN btif_hh_add_added_dev(bt_bdaddr_t bda, tBTA_HH_ATTR_MASK attr_mask);
-extern void btif_hh_virtual_unpug(bt_bdaddr_t *bd_addr);
+extern bt_status_t btif_hh_virtual_unpug(bt_bdaddr_t *bd_addr);
extern void btif_hh_disconnect(bt_bdaddr_t *bd_addr);
BOOLEAN btif_hh_add_added_dev(bt_bdaddr_t bd_addr, tBTA_HH_ATTR_MASK attr_mask);
diff --git a/btif/src/btif_dm.c b/btif/src/btif_dm.c
index bd744ff..28b0bd3 100644..100755
--- a/btif/src/btif_dm.c
+++ b/btif/src/btif_dm.c
@@ -116,6 +116,7 @@ extern UINT16 bta_service_id_to_uuid_lkup_tbl [BTA_MAX_SERVICE_ID];
extern bt_status_t btif_hf_execute_service(BOOLEAN b_enable);
extern bt_status_t btif_av_execute_service(BOOLEAN b_enable);
extern bt_status_t btif_hh_execute_service(BOOLEAN b_enable);
+extern int btif_hh_connect(bt_bdaddr_t *bd_addr);
/******************************************************************************
@@ -334,13 +335,21 @@ static void btif_dm_cb_hid_remote_name(tBTM_REMOTE_DEV_NAME *p_remote_name)
if (p_remote_name->status == BTM_SUCCESS)
{
bond_state_changed(BT_STATUS_SUCCESS, &remote_bd, BT_BOND_STATE_BONDED);
- //btif_hh_mouse_pairing(remote_bd);
}
else
bond_state_changed(BT_STATUS_FAIL, &remote_bd, BT_BOND_STATE_NONE);
}
}
+int remove_hid_bond(bt_bdaddr_t *bd_addr)
+{
+ /* For HID mouse,we did connection before pairing
+ * so we need to do virtual unplug
+ */
+ bdstr_t bdstr;
+ BTIF_TRACE_DEBUG2("%s---Removing HID mouse bond--%s", __FUNCTION__,bd2str((bt_bdaddr_t *)bd_addr, &bdstr));
+ return btif_hh_virtual_unpug(bd_addr);
+}
/*******************************************************************************
**
** Function btif_dm_cb_create_bond
@@ -354,8 +363,14 @@ static void btif_dm_cb_hid_remote_name(tBTM_REMOTE_DEV_NAME *p_remote_name)
static void btif_dm_cb_create_bond(bt_bdaddr_t *bd_addr)
{
bond_state_changed(BT_STATUS_SUCCESS, bd_addr, BT_BOND_STATE_BONDING);
-
- BTA_DmBond ((UINT8 *)bd_addr->address);
+ if (check_cod(bd_addr, COD_HID_POINTING)){
+ int status;
+ status = btif_hh_connect(bd_addr);
+ if(status != BT_STATUS_SUCCESS)
+ bond_state_changed(status, bd_addr, BT_BOND_STATE_NONE);
+ }
+ else
+ BTA_DmBond ((UINT8 *)bd_addr->address);
}
@@ -372,15 +387,25 @@ static void btif_dm_cb_create_bond(bt_bdaddr_t *bd_addr)
void btif_dm_cb_remove_bond(bt_bdaddr_t *bd_addr)
{
bdstr_t bdstr;
- if (BTA_DmRemoveDevice((UINT8 *)bd_addr->address) == BTA_SUCCESS)
+ /*special handling for HID devices */
+ if (check_cod(bd_addr, COD_HID_POINTING))
{
- BTIF_TRACE_DEBUG1("Successfully removed bonding with device: %s",
- bd2str((bt_bdaddr_t *)bd_addr, &bdstr));
+ #if (defined(BTA_HH_INCLUDED) && (BTA_HH_INCLUDED == TRUE))
+ if(remove_hid_bond(bd_addr) != BTA_SUCCESS)
+ BTA_DmRemoveDevice((UINT8 *)bd_addr->address);
+ #endif
}
else
- BTIF_TRACE_DEBUG1("Removed bonding with device failed: %s",
+ {
+ if (BTA_DmRemoveDevice((UINT8 *)bd_addr->address) == BTA_SUCCESS)
+ {
+ BTIF_TRACE_DEBUG1("Successfully removed bonding with device: %s",
bd2str((bt_bdaddr_t *)bd_addr, &bdstr));
-
+ }
+ else
+ BTIF_TRACE_DEBUG1("Removed bonding with device failed: %s",
+ bd2str((bt_bdaddr_t *)bd_addr, &bdstr));
+ }
}
/*******************************************************************************
@@ -990,7 +1015,7 @@ static void btif_dm_upstreams_evt(UINT16 event, char* p_param)
/*special handling for HID devices */
#if (defined(BTA_HH_INCLUDED) && (BTA_HH_INCLUDED == TRUE))
- if (check_cod(&bd_addr, COD_HID_POINTING ) || check_cod(&bd_addr, COD_HID_KEYBOARD )|| check_cod(&bd_addr, COD_HID_COMBO)) {
+ if (check_cod(&bd_addr, COD_HID_KEYBOARD )|| check_cod(&bd_addr, COD_HID_COMBO) || check_cod(&bd_addr, COD_HID_POINTING)) {
btif_hh_remove_device(bd_addr);
}
#endif
@@ -1260,7 +1285,6 @@ bt_status_t btif_dm_create_bond(const bt_bdaddr_t *bd_addr)
bdstr_t bdstr;
BTIF_TRACE_EVENT2("%s: bd_addr=%s", __FUNCTION__, bd2str((bt_bdaddr_t *) bd_addr, &bdstr));
-
if (pairing_cb.state != BT_BOND_STATE_NONE)
return BT_STATUS_BUSY;
diff --git a/btif/src/btif_hh.c b/btif/src/btif_hh.c
index 0b945a0..2b4454d 100644..100755
--- a/btif/src/btif_hh.c
+++ b/btif/src/btif_hh.c
@@ -167,8 +167,6 @@ extern void bta_hh_co_send_hid_info(btif_hh_device_t *p_dev, char *dev_name, UIN
int dscp_len, UINT8 *p_dscp);
extern BOOLEAN check_cod(const bt_bdaddr_t *remote_bdaddr, uint32_t cod);
extern void btif_dm_cb_remove_bond(bt_bdaddr_t *bd_addr);
-
-
extern int scru_ascii_2_hex(char *p_ascii, int len, UINT8 *p_hex);
/************************************************************************************
@@ -390,7 +388,7 @@ BOOLEAN btif_hh_copy_hid_info(tBTA_HH_DEV_DSCP_INFO* dest , tBTA_HH_DEV_DSCP_INF
**
*******************************************************************************/
-void btif_hh_virtual_unpug(bt_bdaddr_t *bd_addr)
+bt_status_t btif_hh_virtual_unpug(bt_bdaddr_t *bd_addr)
{
BTIF_TRACE_DEBUG1("%s", __FUNCTION__);
btif_hh_device_t *p_dev;
@@ -401,29 +399,88 @@ void btif_hh_virtual_unpug(bt_bdaddr_t *bd_addr)
p_dev = btif_hh_find_dev_by_bda(bd_addr);
if (p_dev != NULL)
{
- BTIF_TRACE_DEBUG1("%s Sending BTA_HH_CTRL_VIRTUAL_CABLE_UNPLUG", __FUNCTION__);
- BTA_HhSendCtrl(p_dev->dev_handle, BTA_HH_CTRL_VIRTUAL_CABLE_UNPLUG);
+ BTIF_TRACE_DEBUG1("%s Sending BTA_HH_CTRL_VIRTUAL_CABLE_UNPLUG", __FUNCTION__);
+ BTA_HhSendCtrl(p_dev->dev_handle, BTA_HH_CTRL_VIRTUAL_CABLE_UNPLUG);
+ return BT_STATUS_SUCCESS;
}
else
+ {
BTIF_TRACE_ERROR2("%s: Error, device %s not opened.", __FUNCTION__, bd_str);
- return ;
+ return BT_STATUS_FAIL;
+ }
}
/*******************************************************************************
**
-** Function btif_btif_hh_connect
+** Function btif_hh_connect
**
** Description connection initiated from the BTIF thread context
**
-** Returns void
+** Returns int status
**
*******************************************************************************/
-void btif_hh_connect(bt_bdaddr_t *bd_addr)
+bt_status_t btif_hh_connect(bt_bdaddr_t *bd_addr)
{
- tBTA_SEC sec_mask = BTUI_HH_SECURITY;
+ btif_hh_device_t *dev;
+ btif_hh_added_device_t *added_dev = NULL;
+ char bda_str[20];
+ int i;
BD_ADDR *bda = (BD_ADDR*)bd_addr;
- BTA_HhOpen(*bda, BTA_HH_PROTO_RPT_MODE, sec_mask);
+ tBTA_HH_CONN conn;
+ CHECK_BTHH_INIT();
+ dev = btif_hh_find_dev_by_bda(bd_addr);
+ BTIF_TRACE_DEBUG0("Connect _hh");
+ sprintf(bda_str, "%02X:%02X:%02X:%02X:%02X:%02X",
+ (*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
+ if (dev == NULL && btif_hh_cb.device_num >= BTIF_HH_MAX_HID) {
+ // No space for more HID device now.
+ BTIF_TRACE_WARNING2("%s: Error, exceeded the maximum supported HID device number %d",
+ __FUNCTION__, BTIF_HH_MAX_HID);
+ return BT_STATUS_FAIL;
+ }
+
+ for (i = 0; i < BTIF_HH_MAX_ADDED_DEV; i++) {
+ if (memcmp(&(btif_hh_cb.added_devices[i].bd_addr), bd_addr, BD_ADDR_LEN) == 0) {
+ added_dev = &btif_hh_cb.added_devices[i];
+ BTIF_TRACE_WARNING3("%s: Device %s already added, attr_mask = 0x%x",
+ __FUNCTION__, bda_str, added_dev->attr_mask);
+ }
+ }
+
+ if (added_dev != NULL) {
+ if (added_dev->dev_handle == BTA_HH_INVALID_HANDLE) {
+ // No space for more HID device now.
+ BTIF_TRACE_ERROR2("%s: Error, device %s added but addition failed", __FUNCTION__, bda_str);
+ memset(&(added_dev->bd_addr), 0, 6);
+ added_dev->dev_handle = BTA_HH_INVALID_HANDLE;
+ return BT_STATUS_FAIL;
+ }
+ }
+ if (added_dev == NULL ||
+ (added_dev->attr_mask & HID_NORMALLY_CONNECTABLE) != 0 ||
+ (added_dev->attr_mask & HID_RECONN_INIT) == 0)
+ {
+ tBTA_SEC sec_mask = BTUI_HH_SECURITY;
+ btif_hh_cb.status = BTIF_HH_DEV_CONNECTING;
+ BD_ADDR *bda = (BD_ADDR*)bd_addr;
+ BTA_HhOpen(*bda, BTA_HH_PROTO_RPT_MODE, sec_mask);
+ }
+ else {
+ // This device shall be connected from the host side.
+ BTIF_TRACE_ERROR2("%s: Error, device %s can only be reconnected from device side",
+ __FUNCTION__, bda_str);
+ //TODO
+ /* if ((remote_class & BT_DEV_CLASS_MASK) == BT_DEV_CLASS_HID_POINTING) {
+ //SIG_HH_CONNECTION, *bda, HH_CONN_STATUS_FAILED_MOUSE_FROM_HOST);
+ }
+ else {
+ // SIG_HH_CONNECTION, *bda, HH_CONN_STATUS_FAILED_KBD_FROM_HOST);
+ }*/
+ return BT_STATUS_FAIL;
+
+ }
+ return BT_STATUS_SUCCESS;
}
/*******************************************************************************
@@ -514,7 +571,7 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
p_dev = btif_hh_find_connected_dev_by_handle(p_data->conn.handle);
if (p_dev == NULL) {
BTIF_TRACE_WARNING1("BTA_HH_OPEN_EVT: Error, cannot find device with handle %d", p_data->conn.handle);
-
+ btif_hh_cb.status = BTIF_HH_DEV_DISCONNECTED;
// The connect request must come from device side and exceeded the connected
// HID device number.
BTA_HhClose(p_data->conn.handle);
@@ -522,14 +579,17 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
}
else if (p_dev->fd < 0) {
BTIF_TRACE_WARNING0("BTA_HH_OPEN_EVT: Error, failed to find the bthid driver...");
+ memcpy(&(p_dev->bd_addr), p_data->conn.bda, BD_ADDR_LEN);
+ //remove the connection and then try again to reconnect from the mouse side to recover
+ //p_dev->dev_status = BTHH_CONN_STATE_FAILED_NO_BTHID_DRIVER;
+ btif_hh_cb.status = BTIF_HH_DEV_DISCONNECTED;
BTA_HhClose(p_data->conn.handle);
- p_dev->dev_status = BTHH_CONN_STATE_FAILED_NO_BTHID_DRIVER;
- HAL_CBACK(bt_hh_callbacks, connection_state_cb,&(p_dev->bd_addr), p_dev->dev_status);
}
else {
BTIF_TRACE_WARNING1("BTA_HH_OPEN_EVT: Found device...Getting dscp info for handle ... %d",p_data->conn.handle);
memcpy(&(p_dev->bd_addr), p_data->conn.bda, BD_ADDR_LEN);
- //BTA_HhSetIdle(p_data->conn.handle, 0);
+ btif_hh_cb.status = BTIF_HH_DEV_CONNECTED;
+ BTA_HhSetIdle(p_data->conn.handle, 0);
btif_hh_cb.p_curr_dev = btif_hh_find_connected_dev_by_handle(p_data->conn.handle);
BTA_HhGetDscpInfo(p_data->conn.handle);
p_dev->dev_status = BTHH_CONN_STATE_CONNECTED;
@@ -539,6 +599,7 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
else {
bt_bdaddr_t *bdaddr = (bt_bdaddr_t*)p_data->conn.bda;
HAL_CBACK(bt_hh_callbacks, connection_state_cb, (bt_bdaddr_t*) &p_data->conn.bda,BTHH_CONN_STATE_DISCONNECTED);
+ btif_hh_cb.status = BTIF_HH_DEV_DISCONNECTED;
}
break;
case BTA_HH_CLOSE_EVT:
@@ -553,6 +614,7 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
hidreport[0]=1;
write(p_dev->fd, hidreport, 9);
}
+ btif_hh_cb.status = BTIF_HH_DEV_DISCONNECTED;
p_dev->dev_status = BTHH_CONN_STATE_DISCONNECTED;
HAL_CBACK(bt_hh_callbacks, connection_state_cb,&(p_dev->bd_addr), p_dev->dev_status);
BTIF_TRACE_DEBUG2("%s: Closing bthid.ko fd = %d", __FUNCTION__, p_dev->fd);
@@ -597,7 +659,7 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
BTIF_TRACE_DEBUG2("BTA_HH_SET_PROTO_EVT: status = %d, handle = %d",
p_data->dev_status.status, p_data->dev_status.handle);
break;
-/*
+
case BTA_HH_GET_IDLE_EVT:
BTIF_TRACE_DEBUG3("BTA_HH_GET_IDLE_EVT: handle = %d, status = %d, rate = %d",
p_data->hs_data.handle, p_data->hs_data.status,
@@ -607,11 +669,8 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
case BTA_HH_SET_IDLE_EVT:
BTIF_TRACE_DEBUG2("BTA_HH_SET_IDLE_EVT: status = %d, handle = %d",
p_data->dev_status.status, p_data->dev_status.handle);
- btif_hh_cb.p_curr_dev = btif_hh_find_connected_dev_by_handle(p_data->dev_status.handle);
- BTA_HhGetDscpInfo(p_data->dev_status.handle);
break;
-*/
case BTA_HH_GET_DSCP_EVT:
BTIF_TRACE_WARNING2("BTA_HH_GET_DSCP_EVT: status = %d, handle = %d",
p_data->dev_status.status, p_data->dev_status.handle);
@@ -649,10 +708,6 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
BTIF_TRACE_DEBUG6("BTA_HH_GET_DSCP_EVT:bda = %02x:%02x:%02x:%02x:%02x:%02x",
p_dev->bd_addr.address[0], p_dev->bd_addr.address[1], p_dev->bd_addr.address[2],
p_dev->bd_addr.address[3], p_dev->bd_addr.address[4], p_dev->bd_addr.address[5]);
-
- BTIF_TRACE_DEBUG6("BTA_HH_GET_DSCP_EVT:bda2 = %02x:%02x:%02x:%02x:%02x:%02x",
- bda[0], bda[1], bda[2],
- bda[3], bda[4], bda[5]);
BTA_HhAddDev(bda, p_dev->attr_mask,p_dev->sub_class,p_dev->app_id, dscp_info);
// write hid info to nvram
ret = btif_storage_add_hid_device_info(&(p_dev->bd_addr), p_dev->attr_mask,p_dev->sub_class,p_dev->app_id,
@@ -702,14 +757,21 @@ static void btif_hh_upstreams_evt(UINT16 event, char* p_param)
p_data->dev_info.bda[3], p_data->dev_info.bda[4], p_data->dev_info.bda[5]);
break;
+
case BTA_HH_VC_UNPLUG_EVT:
- LOGI("BTA_HH_VC_UNPLUG_EVT: status = %d, handle = %d",
+ BTIF_TRACE_DEBUG2("BTA_HH_VC_UNPLUG_EVT: status = %d, handle = %d",
p_data->dev_status.status, p_data->dev_status.handle);
p_dev = btif_hh_find_connected_dev_by_handle(p_data->dev_status.handle);
+ btif_hh_cb.status = BTIF_HH_DEV_DISCONNECTED;
if (p_dev != NULL) {
+ BTIF_TRACE_DEBUG6("BTA_HH_VC_UNPLUG_EVT:bda = %02x:%02x:%02x:%02x:%02x:%02x",
+ p_dev->bd_addr.address[0], p_dev->bd_addr.address[1], p_dev->bd_addr.address[2],
+ p_dev->bd_addr.address[3], p_dev->bd_addr.address[4], p_dev->bd_addr.address[5]);
p_dev->dev_status = BTHH_CONN_STATE_DISCONNECTED;
+ BTIF_TRACE_DEBUG1("%s---Sending connection state change", __FUNCTION__);
HAL_CBACK(bt_hh_callbacks, connection_state_cb,&(p_dev->bd_addr), p_dev->dev_status);
- btif_dm_cb_remove_bond(&(p_dev->bd_addr));
+ BTIF_TRACE_DEBUG1("%s---Removing HID mouse bond", __FUNCTION__);
+ BTA_DmRemoveDevice((UINT8 *)p_dev->bd_addr.address);
HAL_CBACK(bt_hh_callbacks, virtual_unplug_cb,&(p_dev->bd_addr),p_data->dev_status.status);
}
break;
@@ -751,9 +813,9 @@ static void bte_hh_evt(tBTA_HH_EVT event, tBTA_HH *p_data)
param_len = sizeof(tBTA_HH_CBDATA);
else if (BTA_HH_GET_DSCP_EVT == event)
param_len = sizeof(tBTA_HH_DEV_DSCP_INFO);
- else if ((BTA_HH_GET_PROTO_EVT == event) || (BTA_HH_GET_RPT_EVT == event) )//|| (BTA_HH_GET_IDLE_EVT == event))
+ else if ((BTA_HH_GET_PROTO_EVT == event) || (BTA_HH_GET_RPT_EVT == event)|| (BTA_HH_GET_IDLE_EVT == event))
param_len = sizeof(tBTA_HH_HSDATA);
- else if ((BTA_HH_SET_PROTO_EVT == event) || (BTA_HH_SET_RPT_EVT == event) || (BTA_HH_VC_UNPLUG_EVT == event)) //|| (BTA_HH_SET_IDLE_EVT == event))
+ else if ((BTA_HH_SET_PROTO_EVT == event) || (BTA_HH_SET_RPT_EVT == event) || (BTA_HH_VC_UNPLUG_EVT == event) || (BTA_HH_SET_IDLE_EVT == event))
param_len = sizeof(tBTA_HH_CBDATA);
else if ((BTA_HH_ADD_DEV_EVT == event) || (BTA_HH_RMV_DEV_EVT == event) )
param_len = sizeof(tBTA_HH_DEV_INFO);
@@ -780,12 +842,18 @@ static void btif_hh_handle_evt(UINT16 event, char *p_param)
{
bt_bdaddr_t *bd_addr = (bt_bdaddr_t*)p_param;
BTIF_TRACE_EVENT2("%s: event=%d", __FUNCTION__, event);
+ int ret;
switch(event)
{
case BTIF_HH_CONNECT_REQ_EVT:
{
- btif_hh_connect(bd_addr);
- HAL_CBACK(bt_hh_callbacks, connection_state_cb,bd_addr,BTHH_CONN_STATE_CONNECTING);
+ ret = btif_hh_connect(bd_addr);
+ if(ret == BT_STATUS_SUCCESS)
+ {
+ HAL_CBACK(bt_hh_callbacks, connection_state_cb,bd_addr,BTHH_CONN_STATE_CONNECTING);
+ }
+ else
+ HAL_CBACK(bt_hh_callbacks, connection_state_cb,bd_addr,BTHH_CONN_STATE_DISCONNECTED);
}
break;
@@ -800,7 +868,7 @@ static void btif_hh_handle_evt(UINT16 event, char *p_param)
case BTIF_HH_VUP_REQ_EVT:
{
BTIF_TRACE_EVENT2("%s: event=%d", __FUNCTION__, event);
- btif_hh_virtual_unpug(bd_addr);
+ ret = btif_hh_virtual_unpug(bd_addr);
}
break;
@@ -848,62 +916,14 @@ static bt_status_t init( bthh_callbacks_t* callbacks )
*******************************************************************************/
static bt_status_t connect( bt_bdaddr_t *bd_addr)
{
- btif_hh_device_t *dev;
- btif_hh_added_device_t *added_dev = NULL;
- char bda_str[20];
- int i;
- BD_ADDR *bda = (BD_ADDR*)bd_addr;
- tBTA_HH_CONN conn;
- CHECK_BTHH_INIT();
- dev = btif_hh_find_dev_by_bda(bd_addr);
- sprintf(bda_str, "%02X:%02X:%02X:%02X:%02X:%02X",
- (*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (dev == NULL && btif_hh_cb.device_num >= BTIF_HH_MAX_HID) {
- // No space for more HID device now.
- BTIF_TRACE_WARNING2("%s: Error, exceeded the maximum supported HID device number %d",
- __FUNCTION__, BTIF_HH_MAX_HID);
- return BT_STATUS_FAIL;
- }
-
- for (i = 0; i < BTIF_HH_MAX_ADDED_DEV; i++) {
- if (memcmp(&(btif_hh_cb.added_devices[i].bd_addr), bd_addr, BD_ADDR_LEN) == 0) {
- added_dev = &btif_hh_cb.added_devices[i];
- BTIF_TRACE_WARNING3("%s: Device %s already added, attr_mask = 0x%x",
- __FUNCTION__, bda_str, added_dev->attr_mask);
- }
- }
-
- if (added_dev != NULL) {
- if (added_dev->dev_handle == BTA_HH_INVALID_HANDLE) {
- // No space for more HID device now.
- LOGE("%s: Error, device %s added but addition failed", __FUNCTION__, bda_str);
- memset(&(added_dev->bd_addr), 0, 6);
- added_dev->dev_handle = BTA_HH_INVALID_HANDLE;
- return BT_STATUS_FAIL;
- }
- }
- if (added_dev == NULL ||
- (added_dev->attr_mask & HID_NORMALLY_CONNECTABLE) != 0 ||
- (added_dev->attr_mask & HID_RECONN_INIT) == 0)
+ if(btif_hh_cb.status != BTIF_HH_DEV_CONNECTING)
{
- return btif_transfer_context(btif_hh_handle_evt, BTIF_HH_CONNECT_REQ_EVT,
+ btif_transfer_context(btif_hh_handle_evt, BTIF_HH_CONNECT_REQ_EVT,
(char*)bd_addr, sizeof(bt_bdaddr_t), NULL);
+ return BT_STATUS_SUCCESS;
}
- else {
- // This device shall be connected from the host side.
- LOGI("%s: Error, device %s can only be reconnected from device side",
- __FUNCTION__, bda_str);
- //TODO
- /* if ((remote_class & BT_DEV_CLASS_MASK) == BT_DEV_CLASS_HID_POINTING) {
- //SIG_HH_CONNECTION, *bda, HH_CONN_STATUS_FAILED_MOUSE_FROM_HOST);
- }
- else {
- // SIG_HH_CONNECTION, *bda, HH_CONN_STATUS_FAILED_KBD_FROM_HOST);
- }*/
- return BT_STATUS_FAIL;
- }
-
- return BT_STATUS_BUSY;
+ else
+ return BT_STATUS_BUSY;
}
/*******************************************************************************
@@ -920,7 +940,7 @@ static bt_status_t disconnect( bt_bdaddr_t *bd_addr )
CHECK_BTHH_INIT();
btif_hh_device_t *p_dev;
- if (btif_hh_cb.status != BTIF_HH_ENABLED)
+ if (btif_hh_cb.status == BTIF_HH_DISABLED)
{
BTIF_TRACE_WARNING2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
@@ -955,7 +975,7 @@ static bt_status_t virtual_unplug (bt_bdaddr_t *bd_addr)
sprintf(bd_str, "%02X:%02X:%02X:%02X:%02X:%02X",
bd_addr->address[0], bd_addr->address[1], bd_addr->address[2], bd_addr->address[3],
bd_addr->address[4], bd_addr->address[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED)
+ if (btif_hh_cb.status == BTIF_HH_DISABLED)
{
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
@@ -995,7 +1015,7 @@ static bt_status_t set_info (bt_bdaddr_t *bd_addr, bthh_hid_info_t hid_info )
hid_info.app_id, hid_info.vendor_id, hid_info.product_id,
hid_info.version);
- if (btif_hh_cb.status != BTIF_HH_ENABLED)
+ if (btif_hh_cb.status == BTIF_HH_DISABLED)
{
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
@@ -1043,7 +1063,7 @@ static bt_status_t get_idle_time(bt_bdaddr_t *bd_addr)
BTIF_TRACE_DEBUG6(" addr = %02X:%02X:%02X:%02X:%02X:%02X",
(*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
}
@@ -1076,7 +1096,7 @@ static bt_status_t set_idle_time (bt_bdaddr_t *bd_addr, uint8_t idle_time)
BTIF_TRACE_DEBUG6("addr = %02X:%02X:%02X:%02X:%02X:%02X",
(*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
}
@@ -1111,7 +1131,7 @@ static bt_status_t get_protocol (bt_bdaddr_t *bd_addr, bthh_protocol_mode_t prot
BTIF_TRACE_DEBUG6(" addr = %02X:%02X:%02X:%02X:%02X:%02X",
(*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
}
@@ -1147,7 +1167,7 @@ static bt_status_t set_protocol (bt_bdaddr_t *bd_addr, bthh_protocol_mode_t prot
BTIF_TRACE_DEBUG6("addr = %02X:%02X:%02X:%02X:%02X:%02X",
(*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
}
@@ -1191,7 +1211,7 @@ static bt_status_t get_report (bt_bdaddr_t *bd_addr, bthh_report_type_t reportTy
BTIF_TRACE_DEBUG6("addr = %02X:%02X:%02X:%02X:%02X:%02X",
(*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
}
@@ -1237,7 +1257,7 @@ static bt_status_t set_report (bt_bdaddr_t *bd_addr, bthh_report_type_t reportTy
(*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
}
@@ -1308,7 +1328,7 @@ static bt_status_t send_data (bt_bdaddr_t *bd_addr, char* data)
BTIF_TRACE_DEBUG6("addr = %02X:%02X:%02X:%02X:%02X:%02X",
(*bda)[0], (*bda)[1], (*bda)[2], (*bda)[3], (*bda)[4], (*bda)[5]);
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_ERROR2("%s: Error, HH status = %d", __FUNCTION__, btif_hh_cb.status);
return BT_STATUS_FAIL;
}
@@ -1369,7 +1389,7 @@ static void cleanup( void )
BTIF_TRACE_EVENT1("%s", __FUNCTION__);
btif_hh_device_t *p_dev;
int i;
- if (btif_hh_cb.status != BTIF_HH_ENABLED) {
+ if (btif_hh_cb.status == BTIF_HH_DISABLED) {
BTIF_TRACE_WARNING2("%s: HH disabling or disabled already, status = %d", __FUNCTION__, btif_hh_cb.status);
return;
}
diff --git a/btif/src/btif_util.c b/btif/src/btif_util.c
index a9eb0b4..9ed2cb8 100644..100755
--- a/btif/src/btif_util.c
+++ b/btif/src/btif_util.c
@@ -322,8 +322,10 @@ const char* dump_hh_event(UINT16 event)
CASE_RETURN_STR(BTA_HH_GET_DSCP_EVT)
CASE_RETURN_STR(BTA_HH_GET_PROTO_EVT)
CASE_RETURN_STR(BTA_HH_GET_RPT_EVT)
+ CASE_RETURN_STR(BTA_HH_GET_IDLE_EVT)
CASE_RETURN_STR(BTA_HH_SET_PROTO_EVT)
CASE_RETURN_STR(BTA_HH_SET_RPT_EVT)
+ CASE_RETURN_STR(BTA_HH_SET_IDLE_EVT)
CASE_RETURN_STR(BTA_HH_VC_UNPLUG_EVT)
CASE_RETURN_STR(BTA_HH_ADD_DEV_EVT)
CASE_RETURN_STR(BTA_HH_RMV_DEV_EVT)