diff options
Diffstat (limited to 'btif')
-rwxr-xr-x | btif/src/btif_hf.c | 39 | ||||
-rwxr-xr-x[-rw-r--r--] | btif/src/btif_rc.c | 22 |
2 files changed, 61 insertions, 0 deletions
diff --git a/btif/src/btif_hf.c b/btif/src/btif_hf.c index 2db01fd..5851efa 100755 --- a/btif/src/btif_hf.c +++ b/btif/src/btif_hf.c @@ -102,6 +102,8 @@ #define BTIF_HF_ID_1 0 +#define BTIF_HF_CALL_END_TIMEOUT 6 + /************************************************************************************ ** Local type definitions ************************************************************************************/ @@ -146,6 +148,7 @@ typedef struct _btif_hf_cb tBTA_AG_PEER_FEAT peer_feat; int num_active; int num_held; + struct timespec call_end_timestamp; bthf_call_state_t call_setup_state; } btif_hf_cb_t; @@ -481,6 +484,9 @@ static bt_status_t init( bthf_callbacks_t* callbacks ) * Internally, the HSP_SERVICE_ID shall also be enabled */ btif_enable_service(BTA_HFP_SERVICE_ID); + btif_hf_cb.call_end_timestamp.tv_sec = 0; + btif_hf_cb.call_end_timestamp.tv_nsec = 0; + return BT_STATUS_SUCCESS; } @@ -904,6 +910,13 @@ static bt_status_t phone_state_change(int num_active, int num_held, bthf_call_st if (num_active == 0 && num_held == 0 && call_setup_state == BTHF_CALL_STATE_IDLE) { BTIF_TRACE_DEBUG1("%s: Phone on hook", __FUNCTION__); + + /* record call termination timestamp if there was an active/held call or callsetup state > BTHF_CALL_STATE_IDLE */ + if ((btif_hf_cb.call_setup_state != BTHF_CALL_STATE_IDLE ) || (btif_hf_cb.num_active) ||(btif_hf_cb.num_held)) + { + BTIF_TRACE_DEBUG1("%s: Record call termination timestamp", __FUNCTION__); + clock_gettime(CLOCK_MONOTONIC, &btif_hf_cb.call_end_timestamp); + } BTA_AgResult (BTA_AG_HANDLE_ALL, BTA_AG_END_CALL_RES, NULL); /* if held call was present, reset that as well */ @@ -1064,6 +1077,32 @@ update_call_states: return status; } + +/******************************************************************************* +** +** Function btif_hf_call_terminated_recently +** +** Description Checks if a call has been terminated +** +** Returns bt_status_t +** +*******************************************************************************/ +BOOLEAN btif_hf_call_terminated_recently() +{ + struct timespec now; + + clock_gettime(CLOCK_MONOTONIC, &now); + if (now.tv_sec < btif_hf_cb.call_end_timestamp.tv_sec + BTIF_HF_CALL_END_TIMEOUT) + { + return TRUE; + } + else + { + btif_hf_cb.call_end_timestamp.tv_sec = 0; + return FALSE; + } +} + /******************************************************************************* ** ** Function cleanup diff --git a/btif/src/btif_rc.c b/btif/src/btif_rc.c index 7aab520..24133cc 100644..100755 --- a/btif/src/btif_rc.c +++ b/btif/src/btif_rc.c @@ -74,6 +74,10 @@ #error "AVRCP 1.3 is not supported on Bluedroid yet." #endif +/* cod value for Headsets */ +#define COD_AV_HEADSETS 0x0404 + + /***************************************************************************** ** Local type definitions ******************************************************************************/ @@ -127,6 +131,9 @@ static btif_rc_cb_t btif_rc_cb; /***************************************************************************** ** Externs ******************************************************************************/ +extern BOOLEAN btif_hf_call_terminated_recently(); +extern BOOLEAN check_cod(const bt_bdaddr_t *remote_bdaddr, uint32_t cod); + /***************************************************************************** ** Functions @@ -327,6 +334,21 @@ void handle_rc_passthrough_cmd ( tBTA_AV_REMOTE_CMD *p_remote_cmd) pressed = 1; } + /* If this is Play command (press or release) before processing, check the following + *a voice call has ended recently + * the remote device is not of type headset + * If the above conditions meet, drop the Play command + *This fix is to interop with certain carkits which sends an automatic PLAY commands right after call ends + */ + if((p_remote_cmd->rc_id == BTA_AV_RC_PLAY )&& + (btif_hf_call_terminated_recently() == TRUE) && + (check_cod( (const bt_bdaddr_t*)&(btif_rc_cb.rc_addr), COD_AV_HEADSETS) != TRUE)) + { + BTIF_TRACE_DEBUG1("%s:Dropping the play command received right after call end", + __FUNCTION__); + return; + } + for (i = 0; key_map[i].name != NULL; i++) { if (p_remote_cmd->rc_id == key_map[i].avrcp) { BTIF_TRACE_DEBUG3("%s: %s %s", __FUNCTION__, key_map[i].name, status); |