Home | History | Annotate | Download | only in btu
      1 /******************************************************************************
      2  *
      3  *  Copyright (C) 1999-2012 Broadcom Corporation
      4  *
      5  *  Licensed under the Apache License, Version 2.0 (the "License");
      6  *  you may not use this file except in compliance with the License.
      7  *  You may obtain a copy of the License at:
      8  *
      9  *  http://www.apache.org/licenses/LICENSE-2.0
     10  *
     11  *  Unless required by applicable law or agreed to in writing, software
     12  *  distributed under the License is distributed on an "AS IS" BASIS,
     13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     14  *  See the License for the specific language governing permissions and
     15  *  limitations under the License.
     16  *
     17  ******************************************************************************/
     18 
     19 /******************************************************************************
     20  *
     21  *  This file contains functions that interface with the HCI transport. On
     22  *  the receive side, it routes events to the appropriate handler, e.g.
     23  *  L2CAP, ScoMgr. On the transmit side, it manages the command
     24  *  transmission.
     25  *
     26  ******************************************************************************/
     27 
     28 #include <stdlib.h>
     29 #include <string.h>
     30 #include <stdio.h>
     31 
     32 #include "gki.h"
     33 #include "bt_types.h"
     34 #include "hcimsgs.h"
     35 #include "btu.h"
     36 #include "l2c_int.h"
     37 #include "btm_api.h"
     38 #include "btm_int.h"
     39 
     40 // btla-specific ++
     41 #define LOG_TAG "BTLD"
     42 #if (defined(ANDROID_APP_INCLUDED) && (ANDROID_APP_INCLUDED == TRUE) && (!defined(LINUX_NATIVE)) )
     43 #include <cutils/log.h>
     44 #else
     45 #define LOGV(format, ...)  fprintf (stdout, LOG_TAG format"\n", ## __VA_ARGS__)
     46 #define LOGE(format, ...)  fprintf (stderr, LOG_TAG format"\n", ## __VA_ARGS__)
     47 #define LOGI(format, ...)  fprintf (stdout, LOG_TAG format"\n", ## __VA_ARGS__)
     48 #endif
     49 
     50 // btla-specific ++
     51 /* BTE application task */
     52 #if APPL_INCLUDED == TRUE
     53 #include "bte_appl.h"
     54 #endif
     55 // btla-specific --
     56 
     57 //Counter to track number of HCI command timeout
     58 static int num_hci_cmds_timed_out;
     59 
     60 /********************************************************************************/
     61 /*              L O C A L    F U N C T I O N     P R O T O T Y P E S            */
     62 /********************************************************************************/
     63 static void btu_hcif_inquiry_comp_evt (UINT8 *p, UINT16 evt_len);
     64 static void btu_hcif_inquiry_result_evt (UINT8 *p, UINT16 evt_len);
     65 static void btu_hcif_inquiry_rssi_result_evt (UINT8 *p, UINT16 evt_len);
     66 #if (BTM_EIR_CLIENT_INCLUDED == TRUE)
     67 static void btu_hcif_extended_inquiry_result_evt (UINT8 *p, UINT16 evt_len);
     68 #endif
     69 
     70 static void btu_hcif_connection_comp_evt (UINT8 *p, UINT16 evt_len);
     71 static void btu_hcif_connection_request_evt (UINT8 *p, UINT16 evt_len);
     72 static void btu_hcif_disconnection_comp_evt (UINT8 *p, UINT16 evt_len);
     73 static void btu_hcif_authentication_comp_evt (UINT8 *p, UINT16 evt_len);
     74 static void btu_hcif_rmt_name_request_comp_evt (UINT8 *p, UINT16 evt_len);
     75 static void btu_hcif_encryption_change_evt (UINT8 *p, UINT16 evt_len);
     76 static void btu_hcif_change_conn_link_key_evt (UINT8 *p, UINT16 evt_len);
     77 static void btu_hcif_master_link_key_comp_evt (UINT8 *p, UINT16 evt_len);
     78 static void btu_hcif_read_rmt_features_comp_evt (UINT8 *p, UINT16 evt_len);
     79 static void btu_hcif_read_rmt_ext_features_comp_evt (UINT8 *p, UINT16 evt_len);
     80 static void btu_hcif_read_rmt_version_comp_evt (UINT8 *p, UINT16 evt_len);
     81 static void btu_hcif_qos_setup_comp_evt (UINT8 *p, UINT16 evt_len);
     82 static void btu_hcif_command_complete_evt (UINT8 controller_id, UINT8 *p, UINT16 evt_len);
     83 static void btu_hcif_command_status_evt (UINT8 controller_id, UINT8 *p, UINT16 evt_len);
     84 static void btu_hcif_hardware_error_evt (UINT8 *p, UINT16 evt_len);
     85 static void btu_hcif_flush_occured_evt (UINT8 *p, UINT16 evt_len);
     86 static void btu_hcif_role_change_evt (UINT8 *p, UINT16 evt_len);
     87 static void btu_hcif_num_compl_data_pkts_evt (UINT8 *p, UINT16 evt_len);
     88 static void btu_hcif_mode_change_evt (UINT8 *p, UINT16 evt_len);
     89 static void btu_hcif_return_link_keys_evt (UINT8 *p, UINT16 evt_len);
     90 static void btu_hcif_pin_code_request_evt (UINT8 *p, UINT16 evt_len);
     91 static void btu_hcif_link_key_request_evt (UINT8 *p, UINT16 evt_len);
     92 static void btu_hcif_link_key_notification_evt (UINT8 *p, UINT16 evt_len);
     93 static void btu_hcif_loopback_command_evt (UINT8 *p, UINT16 evt_len);
     94 static void btu_hcif_data_buf_overflow_evt (UINT8 *p, UINT16 evt_len);
     95 static void btu_hcif_max_slots_changed_evt (UINT8 *p, UINT16 evt_len);
     96 static void btu_hcif_read_clock_off_comp_evt (UINT8 *p, UINT16 evt_len);
     97 static void btu_hcif_conn_pkt_type_change_evt (UINT8 *p, UINT16 evt_len);
     98 static void btu_hcif_qos_violation_evt (UINT8 *p, UINT16 evt_len);
     99 static void btu_hcif_page_scan_mode_change_evt (UINT8 *p, UINT16 evt_len);
    100 static void btu_hcif_page_scan_rep_mode_chng_evt (UINT8 *p, UINT16 evt_len);
    101 static void btu_hcif_esco_connection_comp_evt(UINT8 *p, UINT16 evt_len);
    102 static void btu_hcif_esco_connection_chg_evt(UINT8 *p, UINT16 evt_len);
    103 
    104 /* Simple Pairing Events */
    105 static void btu_hcif_host_support_evt (UINT8 *p, UINT16 evt_len);
    106 static void btu_hcif_io_cap_request_evt (UINT8 *p, UINT16 evt_len);
    107 static void btu_hcif_io_cap_response_evt (UINT8 *p, UINT16 evt_len);
    108 static void btu_hcif_user_conf_request_evt (UINT8 *p, UINT16 evt_len);
    109 static void btu_hcif_user_passkey_request_evt (UINT8 *p, UINT16 evt_len);
    110 static void btu_hcif_user_passkey_notif_evt (UINT8 *p, UINT16 evt_len);
    111 static void btu_hcif_keypress_notif_evt (UINT8 *p, UINT16 evt_len);
    112 static void btu_hcif_link_super_tout_evt (UINT8 *p, UINT16 evt_len);
    113 
    114     #if BTM_OOB_INCLUDED == TRUE
    115 static void btu_hcif_rem_oob_request_evt (UINT8 *p, UINT16 evt_len);
    116     #endif
    117 
    118 static void btu_hcif_simple_pair_complete_evt (UINT8 *p, UINT16 evt_len);
    119     #if L2CAP_NON_FLUSHABLE_PB_INCLUDED == TRUE
    120 static void btu_hcif_enhanced_flush_complete_evt (UINT8 *p, UINT16 evt_len);
    121     #endif
    122 
    123     #if (BTM_SSR_INCLUDED == TRUE)
    124 static void btu_hcif_ssr_evt (UINT8 *p, UINT16 evt_len);
    125     #endif /* BTM_SSR_INCLUDED == TRUE */
    126 
    127     #if (HID_DEV_INCLUDED == TRUE) && (HID_DEV_PM_INCLUDED == TRUE)
    128 extern void hidd_pm_proc_mode_change( UINT8 hci_status, UINT8 mode, UINT16 interval );
    129     #endif
    130 
    131 
    132     #if BLE_INCLUDED == TRUE
    133 static void btu_ble_ll_conn_complete_evt (UINT8 *p, UINT16 evt_len);
    134 static void btu_ble_process_adv_pkt (UINT8 *p, UINT16 evt_len);
    135 static void btu_ble_read_remote_feat_evt (UINT8 *p, UINT16 evt_len);
    136 static void btu_ble_ll_conn_param_upd_evt (UINT8 *p, UINT16 evt_len);
    137 static void btu_ble_proc_ltk_req (UINT8 *p, UINT16 evt_len);
    138 static void btu_hcif_encyption_key_refresh_cmpl_evt (UINT8 *p, UINT16 evt_len);
    139     #endif
    140 /*******************************************************************************
    141 **
    142 ** Function         btu_hcif_store_cmd
    143 **
    144 ** Description      This function stores a copy of an outgoing command and
    145 **                  and sets a timer waiting for a event in response to the
    146 **                  command.
    147 **
    148 ** Returns          void
    149 **
    150 *******************************************************************************/
    151 static void btu_hcif_store_cmd (UINT8 controller_id, BT_HDR *p_buf)
    152 {
    153     tHCI_CMD_CB *p_hci_cmd_cb;
    154     UINT16  opcode;
    155     BT_HDR  *p_cmd;
    156     UINT8   *p;
    157 
    158     /* Validate controller ID */
    159     if (controller_id >= BTU_MAX_LOCAL_CTRLS)
    160         return;
    161 
    162     p_hci_cmd_cb = &(btu_cb.hci_cmd_cb[controller_id]);
    163     p = (UINT8 *)(p_buf + 1) + p_buf->offset;
    164 
    165     /* get command opcode */
    166     STREAM_TO_UINT16 (opcode, p);
    167 
    168     /* don't do anything for certain commands */
    169     if ((opcode == HCI_RESET) || (opcode == HCI_HOST_NUM_PACKETS_DONE))
    170     {
    171         return;
    172     }
    173 
    174     /* allocate buffer (HCI_GET_CMD_BUF will either get a buffer from HCI_CMD_POOL or from 'best-fit' pool) */
    175     if ((p_cmd = HCI_GET_CMD_BUF(p_buf->len + p_buf->offset - HCIC_PREAMBLE_SIZE)) == NULL)
    176     {
    177         return;
    178     }
    179 
    180     /* copy buffer */
    181     memcpy (p_cmd, p_buf, sizeof(BT_HDR));
    182 
    183     /* If vendor specific save the callback function */
    184     if ((opcode & HCI_GRP_VENDOR_SPECIFIC) == HCI_GRP_VENDOR_SPECIFIC
    185 #if BLE_INCLUDED == TRUE
    186         || (opcode == HCI_BLE_RAND )
    187         || (opcode == HCI_BLE_ENCRYPT)
    188 #endif
    189        )
    190     {
    191 #if 0
    192         BT_TRACE_2 (TRACE_LAYER_HCI, TRACE_TYPE_DEBUG,
    193                     "Storing VSC callback opcode=0x%04x, Callback function=0x%07x",
    194                     opcode, *(UINT32 *)(p_buf + 1));
    195 #endif
    196         memcpy ((UINT8 *)(p_cmd + 1), (UINT8 *)(p_buf + 1), sizeof(void *));
    197     }
    198 
    199     memcpy ((UINT8 *)(p_cmd + 1) + p_cmd->offset,
    200             (UINT8 *)(p_buf + 1) + p_buf->offset, p_buf->len);
    201 
    202     /* queue copy of cmd */
    203     GKI_enqueue(&(p_hci_cmd_cb->cmd_cmpl_q), p_cmd);
    204 
    205     /* start timer */
    206     if (BTU_CMD_CMPL_TIMEOUT > 0)
    207     {
    208 #if (defined(BTU_CMD_CMPL_TOUT_DOUBLE_CHECK) && BTU_CMD_CMPL_TOUT_DOUBLE_CHECK == TRUE)
    209         p_hci_cmd_cb->checked_hcisu = FALSE;
    210 #endif
    211         btu_start_timer (&(p_hci_cmd_cb->cmd_cmpl_timer),
    212                          (UINT16)(BTU_TTYPE_BTU_CMD_CMPL + controller_id),
    213                          BTU_CMD_CMPL_TIMEOUT);
    214     }
    215 }
    216 
    217 /*******************************************************************************
    218 **
    219 ** Function         btu_hcif_process_event
    220 **
    221 ** Description      This function is called when an event is received from
    222 **                  the Host Controller.
    223 **
    224 ** Returns          void
    225 **
    226 *******************************************************************************/
    227 void btu_hcif_process_event (UINT8 controller_id, BT_HDR *p_msg)
    228 {
    229     UINT8   *p = (UINT8 *)(p_msg + 1) + p_msg->offset;
    230     UINT8   hci_evt_code, hci_evt_len;
    231 #if BLE_INCLUDED == TRUE
    232     UINT8   ble_sub_code;
    233 #endif
    234     STREAM_TO_UINT8  (hci_evt_code, p);
    235     STREAM_TO_UINT8  (hci_evt_len, p);
    236 
    237     switch (hci_evt_code)
    238     {
    239         case HCI_INQUIRY_COMP_EVT:
    240             btu_hcif_inquiry_comp_evt (p, hci_evt_len);
    241             break;
    242         case HCI_INQUIRY_RESULT_EVT:
    243             btu_hcif_inquiry_result_evt (p, hci_evt_len);
    244             break;
    245         case HCI_INQUIRY_RSSI_RESULT_EVT:
    246             btu_hcif_inquiry_rssi_result_evt (p, hci_evt_len);
    247             break;
    248 #if (BTM_EIR_CLIENT_INCLUDED == TRUE)
    249         case HCI_EXTENDED_INQUIRY_RESULT_EVT:
    250             btu_hcif_extended_inquiry_result_evt (p, hci_evt_len);
    251             break;
    252 #endif
    253         case HCI_CONNECTION_COMP_EVT:
    254             btu_hcif_connection_comp_evt (p, hci_evt_len);
    255             break;
    256         case HCI_CONNECTION_REQUEST_EVT:
    257             btu_hcif_connection_request_evt (p, hci_evt_len);
    258             break;
    259         case HCI_DISCONNECTION_COMP_EVT:
    260             btu_hcif_disconnection_comp_evt (p, hci_evt_len);
    261             break;
    262         case HCI_AUTHENTICATION_COMP_EVT:
    263             btu_hcif_authentication_comp_evt (p, hci_evt_len);
    264             break;
    265         case HCI_RMT_NAME_REQUEST_COMP_EVT:
    266             btu_hcif_rmt_name_request_comp_evt (p, hci_evt_len);
    267             break;
    268         case HCI_ENCRYPTION_CHANGE_EVT:
    269             btu_hcif_encryption_change_evt (p, hci_evt_len);
    270             break;
    271 #if BLE_INCLUDED == TRUE
    272         case HCI_ENCRYPTION_KEY_REFRESH_COMP_EVT:
    273             btu_hcif_encyption_key_refresh_cmpl_evt(p, hci_evt_len);
    274             break;
    275 #endif
    276         case HCI_CHANGE_CONN_LINK_KEY_EVT:
    277             btu_hcif_change_conn_link_key_evt (p, hci_evt_len);
    278             break;
    279         case HCI_MASTER_LINK_KEY_COMP_EVT:
    280             btu_hcif_master_link_key_comp_evt (p, hci_evt_len);
    281             break;
    282         case HCI_READ_RMT_FEATURES_COMP_EVT:
    283             btu_hcif_read_rmt_features_comp_evt (p, hci_evt_len);
    284             break;
    285         case HCI_READ_RMT_EXT_FEATURES_COMP_EVT:
    286             btu_hcif_read_rmt_ext_features_comp_evt (p, hci_evt_len);
    287             break;
    288         case HCI_READ_RMT_VERSION_COMP_EVT:
    289             btu_hcif_read_rmt_version_comp_evt (p, hci_evt_len);
    290             break;
    291         case HCI_QOS_SETUP_COMP_EVT:
    292             btu_hcif_qos_setup_comp_evt (p, hci_evt_len);
    293             break;
    294         case HCI_COMMAND_COMPLETE_EVT:
    295             btu_hcif_command_complete_evt (controller_id, p, hci_evt_len);
    296             break;
    297         case HCI_COMMAND_STATUS_EVT:
    298             btu_hcif_command_status_evt (controller_id, p, hci_evt_len);
    299             break;
    300         case HCI_HARDWARE_ERROR_EVT:
    301             btu_hcif_hardware_error_evt (p, hci_evt_len);
    302             break;
    303         case HCI_FLUSH_OCCURED_EVT:
    304             btu_hcif_flush_occured_evt (p, hci_evt_len);
    305             break;
    306         case HCI_ROLE_CHANGE_EVT:
    307             btu_hcif_role_change_evt (p, hci_evt_len);
    308             break;
    309         case HCI_NUM_COMPL_DATA_PKTS_EVT:
    310             btu_hcif_num_compl_data_pkts_evt (p, hci_evt_len);
    311             break;
    312         case HCI_MODE_CHANGE_EVT:
    313             btu_hcif_mode_change_evt (p, hci_evt_len);
    314             break;
    315         case HCI_RETURN_LINK_KEYS_EVT:
    316             btu_hcif_return_link_keys_evt (p, hci_evt_len);
    317             break;
    318         case HCI_PIN_CODE_REQUEST_EVT:
    319             btu_hcif_pin_code_request_evt (p, hci_evt_len);
    320             break;
    321         case HCI_LINK_KEY_REQUEST_EVT:
    322             btu_hcif_link_key_request_evt (p, hci_evt_len);
    323             break;
    324         case HCI_LINK_KEY_NOTIFICATION_EVT:
    325             btu_hcif_link_key_notification_evt (p, hci_evt_len);
    326             break;
    327         case HCI_LOOPBACK_COMMAND_EVT:
    328             btu_hcif_loopback_command_evt (p, hci_evt_len);
    329             break;
    330         case HCI_DATA_BUF_OVERFLOW_EVT:
    331             btu_hcif_data_buf_overflow_evt (p, hci_evt_len);
    332             break;
    333         case HCI_MAX_SLOTS_CHANGED_EVT:
    334             btu_hcif_max_slots_changed_evt (p, hci_evt_len);
    335             break;
    336         case HCI_READ_CLOCK_OFF_COMP_EVT:
    337             btu_hcif_read_clock_off_comp_evt (p, hci_evt_len);
    338             break;
    339         case HCI_CONN_PKT_TYPE_CHANGE_EVT:
    340             btu_hcif_conn_pkt_type_change_evt (p, hci_evt_len);
    341             break;
    342         case HCI_QOS_VIOLATION_EVT:
    343             btu_hcif_qos_violation_evt (p, hci_evt_len);
    344             break;
    345         case HCI_PAGE_SCAN_MODE_CHANGE_EVT:
    346             btu_hcif_page_scan_mode_change_evt (p, hci_evt_len);
    347             break;
    348         case HCI_PAGE_SCAN_REP_MODE_CHNG_EVT:
    349             btu_hcif_page_scan_rep_mode_chng_evt (p, hci_evt_len);
    350             break;
    351         case HCI_ESCO_CONNECTION_COMP_EVT:
    352             btu_hcif_esco_connection_comp_evt (p, hci_evt_len);
    353             break;
    354         case HCI_ESCO_CONNECTION_CHANGED_EVT:
    355             btu_hcif_esco_connection_chg_evt (p, hci_evt_len);
    356             break;
    357 #if (BTM_SSR_INCLUDED == TRUE)
    358         case HCI_SNIFF_SUB_RATE_EVT:
    359             btu_hcif_ssr_evt (p, hci_evt_len);
    360             break;
    361 #endif  /* BTM_SSR_INCLUDED == TRUE */
    362         case HCI_RMT_HOST_SUP_FEAT_NOTIFY_EVT:
    363             btu_hcif_host_support_evt (p, hci_evt_len);
    364             break;
    365         case HCI_IO_CAPABILITY_REQUEST_EVT:
    366             btu_hcif_io_cap_request_evt (p, hci_evt_len);
    367             break;
    368         case HCI_IO_CAPABILITY_RESPONSE_EVT:
    369             btu_hcif_io_cap_response_evt (p, hci_evt_len);
    370             break;
    371         case HCI_USER_CONFIRMATION_REQUEST_EVT:
    372             btu_hcif_user_conf_request_evt (p, hci_evt_len);
    373             break;
    374         case HCI_USER_PASSKEY_REQUEST_EVT:
    375             btu_hcif_user_passkey_request_evt (p, hci_evt_len);
    376             break;
    377 #if BTM_OOB_INCLUDED == TRUE
    378         case HCI_REMOTE_OOB_DATA_REQUEST_EVT:
    379             btu_hcif_rem_oob_request_evt (p, hci_evt_len);
    380             break;
    381 #endif
    382         case HCI_SIMPLE_PAIRING_COMPLETE_EVT:
    383             btu_hcif_simple_pair_complete_evt (p, hci_evt_len);
    384             break;
    385         case HCI_USER_PASSKEY_NOTIFY_EVT:
    386             btu_hcif_user_passkey_notif_evt (p, hci_evt_len);
    387             break;
    388         case HCI_KEYPRESS_NOTIFY_EVT:
    389             btu_hcif_keypress_notif_evt (p, hci_evt_len);
    390             break;
    391         case HCI_LINK_SUPER_TOUT_CHANGED_EVT:
    392             btu_hcif_link_super_tout_evt (p, hci_evt_len);
    393             break;
    394 #if L2CAP_NON_FLUSHABLE_PB_INCLUDED == TRUE
    395         case HCI_ENHANCED_FLUSH_COMPLETE_EVT:
    396             btu_hcif_enhanced_flush_complete_evt (p, hci_evt_len);
    397             break;
    398 #endif
    399 
    400 #if (BLE_INCLUDED == TRUE)
    401         case HCI_BLE_EVENT:
    402             STREAM_TO_UINT8  (ble_sub_code, p);
    403 
    404             BT_TRACE_2 (TRACE_LAYER_HCI, TRACE_TYPE_EVENT, "BLE HCI(id=%d) event = 0x%02x)",
    405                         hci_evt_code,  ble_sub_code);
    406 
    407             switch (ble_sub_code)
    408             {
    409                 case HCI_BLE_ADV_PKT_RPT_EVT: /* result of inquiry */
    410                     btu_ble_process_adv_pkt(p, hci_evt_len);
    411                     break;
    412                 case HCI_BLE_CONN_COMPLETE_EVT:
    413                     btu_ble_ll_conn_complete_evt(p, hci_evt_len);
    414                     break;
    415                 case HCI_BLE_LL_CONN_PARAM_UPD_EVT:
    416                     btu_ble_ll_conn_param_upd_evt(p, hci_evt_len);
    417                     break;
    418                 case HCI_BLE_READ_REMOTE_FEAT_CMPL_EVT:
    419                     btu_ble_read_remote_feat_evt(p, hci_evt_len);
    420                     break;
    421                 case HCI_BLE_LTK_REQ_EVT: /* received only at slave device */
    422                     btu_ble_proc_ltk_req(p, hci_evt_len);
    423                     break;
    424             }
    425             break;
    426 #endif /* BLE_INCLUDED */
    427         case HCI_VENDOR_SPECIFIC_EVT:
    428                 btm_vendor_specific_evt (p, hci_evt_len);
    429             break;
    430     }
    431     // reset the  num_hci_cmds_timed_out upon receving any event from controller.
    432     num_hci_cmds_timed_out = 0;
    433 }
    434 
    435 
    436 /*******************************************************************************
    437 **
    438 ** Function         btu_hcif_send_cmd
    439 **
    440 ** Description      This function is called to check if it can send commands
    441 **                  to the Host Controller. It may be passed the address of
    442 **                  a packet to send.
    443 **
    444 ** Returns          void
    445 **
    446 *******************************************************************************/
    447 void btu_hcif_send_cmd (UINT8 controller_id, BT_HDR *p_buf)
    448 {
    449     tHCI_CMD_CB * p_hci_cmd_cb = &(btu_cb.hci_cmd_cb[controller_id]);
    450 
    451 #if ((L2CAP_HOST_FLOW_CTRL == TRUE)||defined(HCI_TESTER))
    452     UINT8 *pp;
    453     UINT16 code;
    454 #endif
    455 
    456     /* If there are already commands in the queue, then enqueue this command */
    457     if ((p_buf) && (p_hci_cmd_cb->cmd_xmit_q.count))
    458     {
    459         GKI_enqueue (&(p_hci_cmd_cb->cmd_xmit_q), p_buf);
    460         p_buf = NULL;
    461     }
    462 
    463     /* Allow for startup case, where no acks may be received */
    464     if ( ((controller_id == LOCAL_BR_EDR_CONTROLLER_ID)
    465          && (p_hci_cmd_cb->cmd_window == 0)
    466          && (btm_cb.devcb.state == BTM_DEV_STATE_WAIT_RESET_CMPLT)) )
    467     {
    468         p_hci_cmd_cb->cmd_window = p_hci_cmd_cb->cmd_xmit_q.count + 1;
    469     }
    470 
    471     /* See if we can send anything */
    472     while (p_hci_cmd_cb->cmd_window != 0)
    473     {
    474         if (!p_buf)
    475             p_buf = (BT_HDR *)GKI_dequeue (&(p_hci_cmd_cb->cmd_xmit_q));
    476 
    477         if (p_buf)
    478         {
    479             btu_hcif_store_cmd(controller_id, p_buf);
    480 
    481 #if ((L2CAP_HOST_FLOW_CTRL == TRUE)||defined(HCI_TESTER))
    482             pp = (UINT8 *)(p_buf + 1) + p_buf->offset;
    483 
    484             STREAM_TO_UINT16 (code, pp);
    485 
    486             /*
    487              * We do not need to decrease window for host flow control,
    488              * host flow control does not receive an event back from controller
    489              */
    490             if (code != HCI_HOST_NUM_PACKETS_DONE)
    491 #endif
    492                 p_hci_cmd_cb->cmd_window--;
    493 
    494             if (controller_id == LOCAL_BR_EDR_CONTROLLER_ID)
    495             {
    496                 HCI_CMD_TO_LOWER(p_buf);
    497             }
    498             else
    499             {
    500                 /* Unknown controller */
    501                 BT_TRACE_1 (TRACE_LAYER_HCI, TRACE_TYPE_WARNING, "BTU HCI(ctrl id=%d) controller ID not recognized", controller_id);
    502                 GKI_freebuf(p_buf);;
    503             }
    504 
    505             p_buf = NULL;
    506         }
    507         else
    508             break;
    509     }
    510 
    511     if (p_buf)
    512         GKI_enqueue (&(p_hci_cmd_cb->cmd_xmit_q), p_buf);
    513 
    514 #if (defined(HCILP_INCLUDED) && HCILP_INCLUDED == TRUE)
    515     if (controller_id == LOCAL_BR_EDR_CONTROLLER_ID)
    516     {
    517         /* check if controller can go to sleep */
    518         btu_check_bt_sleep ();
    519     }
    520 #endif
    521 
    522 }
    523 
    524 
    525 /*******************************************************************************
    526 **
    527 ** Function         btu_hcif_send_host_rdy_for_data
    528 **
    529 ** Description      This function is called to check if it can send commands
    530 **                  to the Host Controller. It may be passed the address of
    531 **                  a packet to send.
    532 **
    533 ** Returns          void
    534 **
    535 *******************************************************************************/
    536 void btu_hcif_send_host_rdy_for_data(void)
    537 {
    538     UINT16      num_pkts[MAX_L2CAP_LINKS + 4];      /* 3 SCO connections */
    539     UINT16      handles[MAX_L2CAP_LINKS + 4];
    540     UINT8       num_ents;
    541 
    542     /* Get the L2CAP numbers */
    543     num_ents = l2c_link_pkts_rcvd (num_pkts, handles);
    544 
    545     /* Get the SCO numbers */
    546     /* No SCO for now ?? */
    547 
    548     if (num_ents)
    549     {
    550         btsnd_hcic_host_num_xmitted_pkts (num_ents, handles, num_pkts);
    551     }
    552 }
    553 
    554 /*******************************************************************************
    555 **
    556 ** Function         btu_hcif_inquiry_comp_evt
    557 **
    558 ** Description      Process event HCI_INQUIRY_COMP_EVT
    559 **
    560 ** Returns          void
    561 **
    562 *******************************************************************************/
    563 static void btu_hcif_inquiry_comp_evt (UINT8 *p, UINT16 evt_len)
    564 {
    565     UINT8   status;
    566 
    567     STREAM_TO_UINT8    (status, p);
    568 
    569     /* Tell inquiry processing that we are done */
    570     btm_process_inq_complete(status, BTM_BR_INQUIRY_MASK);
    571 }
    572 
    573 
    574 /*******************************************************************************
    575 **
    576 ** Function         btu_hcif_inquiry_result_evt
    577 **
    578 ** Description      Process event HCI_INQUIRY_RESULT_EVT
    579 **
    580 ** Returns          void
    581 **
    582 *******************************************************************************/
    583 static void btu_hcif_inquiry_result_evt (UINT8 *p, UINT16 evt_len)
    584 {
    585     /* Store results in the cache */
    586     btm_process_inq_results (p, BTM_INQ_RESULT_STANDARD);
    587 }
    588 
    589 /*******************************************************************************
    590 **
    591 ** Function         btu_hcif_inquiry_rssi_result_evt
    592 **
    593 ** Description      Process event HCI_INQUIRY_RSSI_RESULT_EVT
    594 **
    595 ** Returns          void
    596 **
    597 *******************************************************************************/
    598 static void btu_hcif_inquiry_rssi_result_evt (UINT8 *p, UINT16 evt_len)
    599 {
    600     /* Store results in the cache */
    601     btm_process_inq_results (p, BTM_INQ_RESULT_WITH_RSSI);
    602 }
    603 
    604 /*******************************************************************************
    605 **
    606 ** Function         btu_hcif_extended_inquiry_result_evt
    607 **
    608 ** Description      Process event HCI_EXTENDED_INQUIRY_RESULT_EVT
    609 **
    610 ** Returns          void
    611 **
    612 *******************************************************************************/
    613 #if (BTM_EIR_CLIENT_INCLUDED == TRUE)
    614 static void btu_hcif_extended_inquiry_result_evt (UINT8 *p, UINT16 evt_len)
    615 {
    616     /* Store results in the cache */
    617     btm_process_inq_results (p, BTM_INQ_RESULT_EXTENDED);
    618 }
    619 #endif
    620 
    621 /*******************************************************************************
    622 **
    623 ** Function         btu_hcif_connection_comp_evt
    624 **
    625 ** Description      Process event HCI_CONNECTION_COMP_EVT
    626 **
    627 ** Returns          void
    628 **
    629 *******************************************************************************/
    630 static void btu_hcif_connection_comp_evt (UINT8 *p, UINT16 evt_len)
    631 {
    632     UINT8       status;
    633     UINT16      handle;
    634     BD_ADDR     bda;
    635     UINT8       link_type;
    636     UINT8       enc_mode;
    637 #if BTM_SCO_INCLUDED == TRUE
    638     tBTM_ESCO_DATA  esco_data;
    639 #endif
    640 
    641     STREAM_TO_UINT8    (status, p);
    642     STREAM_TO_UINT16   (handle, p);
    643     STREAM_TO_BDADDR   (bda, p);
    644     STREAM_TO_UINT8    (link_type, p);
    645     STREAM_TO_UINT8    (enc_mode, p);
    646 
    647     handle = HCID_GET_HANDLE (handle);
    648 
    649     if (link_type == HCI_LINK_TYPE_ACL)
    650     {
    651         btm_sec_connected (bda, handle, status, enc_mode);
    652 
    653         l2c_link_hci_conn_comp (status, handle, bda);
    654     }
    655 #if BTM_SCO_INCLUDED == TRUE
    656     else
    657     {
    658         memset(&esco_data, 0, sizeof(tBTM_ESCO_DATA));
    659         /* esco_data.link_type = HCI_LINK_TYPE_SCO; already zero */
    660         memcpy (esco_data.bd_addr, bda, BD_ADDR_LEN);
    661         btm_sco_connected (status, bda, handle, &esco_data);
    662     }
    663 #endif /* BTM_SCO_INCLUDED */
    664 }
    665 
    666 
    667 /*******************************************************************************
    668 **
    669 ** Function         btu_hcif_connection_request_evt
    670 **
    671 ** Description      Process event HCI_CONNECTION_REQUEST_EVT
    672 **
    673 ** Returns          void
    674 **
    675 *******************************************************************************/
    676 static void btu_hcif_connection_request_evt (UINT8 *p, UINT16 evt_len)
    677 {
    678     BD_ADDR     bda;
    679     DEV_CLASS   dc;
    680     UINT8       link_type;
    681 
    682     STREAM_TO_BDADDR   (bda, p);
    683     STREAM_TO_DEVCLASS (dc, p);
    684     STREAM_TO_UINT8    (link_type, p);
    685 
    686     /* Pass request to security manager to check connect filters before */
    687     /* passing request to l2cap */
    688     if (link_type == HCI_LINK_TYPE_ACL)
    689     {
    690         btm_sec_conn_req (bda, dc);
    691     }
    692 #if BTM_SCO_INCLUDED == TRUE
    693     else
    694     {
    695         btm_sco_conn_req (bda, dc, link_type);
    696     }
    697 #endif /* BTM_SCO_INCLUDED */
    698 }
    699 
    700 
    701 /*******************************************************************************
    702 **
    703 ** Function         btu_hcif_disconnection_comp_evt
    704 **
    705 ** Description      Process event HCI_DISCONNECTION_COMP_EVT
    706 **
    707 ** Returns          void
    708 **
    709 *******************************************************************************/
    710 static void btu_hcif_disconnection_comp_evt (UINT8 *p, UINT16 evt_len)
    711 {
    712     UINT8   status;
    713     UINT16  handle;
    714     UINT8   reason;
    715 
    716     STREAM_TO_UINT8  (status, p);
    717     STREAM_TO_UINT16 (handle, p);
    718     STREAM_TO_UINT8  (reason, p);
    719 
    720     handle = HCID_GET_HANDLE (handle);
    721 
    722 #if BTM_SCO_INCLUDED == TRUE
    723     /* If L2CAP doesn't know about it, send it to SCO */
    724     if (!l2c_link_hci_disc_comp (handle, reason))
    725         btm_sco_removed (handle, reason);
    726 #else
    727     l2c_link_hci_disc_comp (handle, reason);
    728 #endif /* BTM_SCO_INCLUDED */
    729 
    730     /* Notify security manager */
    731     btm_sec_disconnected (handle, reason);
    732 }
    733 
    734 /*******************************************************************************
    735 **
    736 ** Function         btu_hcif_authentication_comp_evt
    737 **
    738 ** Description      Process event HCI_AUTHENTICATION_COMP_EVT
    739 **
    740 ** Returns          void
    741 **
    742 *******************************************************************************/
    743 static void btu_hcif_authentication_comp_evt (UINT8 *p, UINT16 evt_len)
    744 {
    745     UINT8   status;
    746     UINT16  handle;
    747 
    748     STREAM_TO_UINT8  (status, p);
    749     STREAM_TO_UINT16 (handle, p);
    750 
    751     btm_sec_auth_complete (handle, status);
    752 }
    753 
    754 
    755 /*******************************************************************************
    756 **
    757 ** Function         btu_hcif_rmt_name_request_comp_evt
    758 **
    759 ** Description      Process event HCI_RMT_NAME_REQUEST_COMP_EVT
    760 **
    761 ** Returns          void
    762 **
    763 *******************************************************************************/
    764 static void btu_hcif_rmt_name_request_comp_evt (UINT8 *p, UINT16 evt_len)
    765 {
    766     UINT8   status;
    767     BD_ADDR bd_addr;
    768 
    769     STREAM_TO_UINT8 (status, p);
    770     STREAM_TO_BDADDR (bd_addr, p);
    771 
    772     evt_len -= (1 + BD_ADDR_LEN);
    773 
    774     btm_process_remote_name (bd_addr, p, evt_len, status);
    775 
    776     btm_sec_rmt_name_request_complete (bd_addr, p, status);
    777 }
    778 
    779 
    780 /*******************************************************************************
    781 **
    782 ** Function         btu_hcif_encryption_change_evt
    783 **
    784 ** Description      Process event HCI_ENCRYPTION_CHANGE_EVT
    785 **
    786 ** Returns          void
    787 **
    788 *******************************************************************************/
    789 static void btu_hcif_encryption_change_evt (UINT8 *p, UINT16 evt_len)
    790 {
    791     UINT8   status;
    792     UINT16  handle;
    793     UINT8   encr_enable;
    794 
    795     STREAM_TO_UINT8  (status, p);
    796     STREAM_TO_UINT16 (handle, p);
    797     STREAM_TO_UINT8  (encr_enable, p);
    798 
    799     btm_acl_encrypt_change (handle, status, encr_enable);
    800     btm_sec_encrypt_change (handle, status, encr_enable);
    801 }
    802 
    803 
    804 /*******************************************************************************
    805 **
    806 ** Function         btu_hcif_change_conn_link_key_evt
    807 **
    808 ** Description      Process event HCI_CHANGE_CONN_LINK_KEY_EVT
    809 **
    810 ** Returns          void
    811 **
    812 *******************************************************************************/
    813 static void btu_hcif_change_conn_link_key_evt (UINT8 *p, UINT16 evt_len)
    814 {
    815     UINT8   status;
    816     UINT16  handle;
    817 
    818     STREAM_TO_UINT8  (status, p);
    819     STREAM_TO_UINT16 (handle, p);
    820 
    821     btm_acl_link_key_change (handle, status);
    822 }
    823 
    824 
    825 /*******************************************************************************
    826 **
    827 ** Function         btu_hcif_master_link_key_comp_evt
    828 **
    829 ** Description      Process event HCI_MASTER_LINK_KEY_COMP_EVT
    830 **
    831 ** Returns          void
    832 **
    833 *******************************************************************************/
    834 static void btu_hcif_master_link_key_comp_evt (UINT8 *p, UINT16 evt_len)
    835 {
    836     UINT8   status;
    837     UINT16  handle;
    838     UINT8   key_flg;
    839 
    840     STREAM_TO_UINT8  (status, p);
    841     STREAM_TO_UINT16 (handle, p);
    842     STREAM_TO_UINT8  (key_flg, p);
    843 
    844     btm_sec_mkey_comp_event (handle, status, key_flg);
    845 }
    846 
    847 
    848 /*******************************************************************************
    849 **
    850 ** Function         btu_hcif_read_rmt_features_comp_evt
    851 **
    852 ** Description      Process event HCI_READ_RMT_FEATURES_COMP_EVT
    853 **
    854 ** Returns          void
    855 **
    856 *******************************************************************************/
    857 static void btu_hcif_read_rmt_features_comp_evt (UINT8 *p, UINT16 evt_len)
    858 {
    859     btm_read_remote_features_complete(p);
    860 }
    861 
    862 /*******************************************************************************
    863 **
    864 ** Function         btu_hcif_read_rmt_ext_features_comp_evt
    865 **
    866 ** Description      Process event HCI_READ_RMT_EXT_FEATURES_COMP_EVT
    867 **
    868 ** Returns          void
    869 **
    870 *******************************************************************************/
    871 static void btu_hcif_read_rmt_ext_features_comp_evt (UINT8 *p, UINT16 evt_len)
    872 {
    873     UINT8 *p_cur = p;
    874     UINT8 status;
    875     UINT16 handle;
    876 
    877     STREAM_TO_UINT8 (status, p_cur);
    878 
    879     if (status == HCI_SUCCESS)
    880         btm_read_remote_ext_features_complete(p);
    881     else
    882     {
    883         STREAM_TO_UINT16 (handle, p_cur);
    884         btm_read_remote_ext_features_failed(status, handle);
    885     }
    886 }
    887 
    888 /*******************************************************************************
    889 **
    890 ** Function         btu_hcif_read_rmt_version_comp_evt
    891 **
    892 ** Description      Process event HCI_READ_RMT_VERSION_COMP_EVT
    893 **
    894 ** Returns          void
    895 **
    896 *******************************************************************************/
    897 static void btu_hcif_read_rmt_version_comp_evt (UINT8 *p, UINT16 evt_len)
    898 {
    899     btm_read_remote_version_complete (p);
    900 }
    901 
    902 
    903 /*******************************************************************************
    904 **
    905 ** Function         btu_hcif_qos_setup_comp_evt
    906 **
    907 ** Description      Process event HCI_QOS_SETUP_COMP_EVT
    908 **
    909 ** Returns          void
    910 **
    911 *******************************************************************************/
    912 static void btu_hcif_qos_setup_comp_evt (UINT8 *p, UINT16 evt_len)
    913 {
    914     UINT8 status;
    915     UINT16 handle;
    916     FLOW_SPEC flow;
    917 
    918     STREAM_TO_UINT8 (status, p);
    919     STREAM_TO_UINT16 (handle, p);
    920     STREAM_TO_UINT8 (flow.qos_flags, p);
    921     STREAM_TO_UINT8 (flow.service_type, p);
    922     STREAM_TO_UINT32 (flow.token_rate, p);
    923     STREAM_TO_UINT32 (flow.peak_bandwidth, p);
    924     STREAM_TO_UINT32 (flow.latency, p);
    925     STREAM_TO_UINT32 (flow.delay_variation, p);
    926 
    927     btm_qos_setup_complete(status, handle, &flow);
    928 }
    929 
    930 
    931 /*******************************************************************************
    932 **
    933 ** Function         btu_hcif_esco_connection_comp_evt
    934 **
    935 ** Description      Process event HCI_ESCO_CONNECTION_COMP_EVT
    936 **
    937 ** Returns          void
    938 **
    939 *******************************************************************************/
    940 static void btu_hcif_esco_connection_comp_evt (UINT8 *p, UINT16 evt_len)
    941 {
    942 #if BTM_SCO_INCLUDED == TRUE
    943     tBTM_ESCO_DATA  data;
    944     UINT16          handle;
    945     BD_ADDR         bda;
    946     UINT8           status;
    947 
    948     STREAM_TO_UINT8 (status, p);
    949     STREAM_TO_UINT16 (handle, p);
    950     STREAM_TO_BDADDR (bda, p);
    951 
    952     STREAM_TO_UINT8 (data.link_type, p);
    953     STREAM_TO_UINT8 (data.tx_interval, p);
    954     STREAM_TO_UINT8 (data.retrans_window, p);
    955     STREAM_TO_UINT16 (data.rx_pkt_len, p);
    956     STREAM_TO_UINT16 (data.tx_pkt_len, p);
    957     STREAM_TO_UINT8 (data.air_mode, p);
    958 
    959     memcpy (data.bd_addr, bda, BD_ADDR_LEN);
    960     btm_sco_connected (status, bda, handle, &data);
    961 #endif
    962 }
    963 
    964 
    965 /*******************************************************************************
    966 **
    967 ** Function         btu_hcif_esco_connection_chg_evt
    968 **
    969 ** Description      Process event HCI_ESCO_CONNECTION_CHANGED_EVT
    970 **
    971 ** Returns          void
    972 **
    973 *******************************************************************************/
    974 static void btu_hcif_esco_connection_chg_evt (UINT8 *p, UINT16 evt_len)
    975 {
    976 #if BTM_SCO_INCLUDED == TRUE
    977     UINT16  handle;
    978     UINT16  tx_pkt_len;
    979     UINT16  rx_pkt_len;
    980     UINT8   status;
    981     UINT8   tx_interval;
    982     UINT8   retrans_window;
    983 
    984     STREAM_TO_UINT8 (status, p);
    985     STREAM_TO_UINT16 (handle, p);
    986 
    987     STREAM_TO_UINT8 (tx_interval, p);
    988     STREAM_TO_UINT8 (retrans_window, p);
    989     STREAM_TO_UINT16 (rx_pkt_len, p);
    990     STREAM_TO_UINT16 (tx_pkt_len, p);
    991 
    992     btm_esco_proc_conn_chg (status, handle, tx_interval, retrans_window,
    993                             rx_pkt_len, tx_pkt_len);
    994 #endif
    995 }
    996 
    997 /*******************************************************************************
    998 **
    999 ** Function         btu_hcif_hdl_command_complete
   1000 **
   1001 ** Description      Handle command complete event
   1002 **
   1003 ** Returns          void
   1004 **
   1005 *******************************************************************************/
   1006 static void btu_hcif_hdl_command_complete (UINT16 opcode, UINT8 *p, UINT16 evt_len,
   1007                                            void *p_cplt_cback, UINT8 ctr_id)
   1008 {
   1009     switch (opcode)
   1010     {
   1011         case HCI_RESET:
   1012             btm_reset_complete ();  /* BR/EDR */
   1013             break;
   1014 
   1015         case HCI_INQUIRY_CANCEL:
   1016             /* Tell inquiry processing that we are done */
   1017             btm_process_cancel_complete(HCI_SUCCESS, BTM_BR_INQUIRY_MASK);
   1018             break;
   1019         case HCI_SET_EVENT_FILTER:
   1020             btm_event_filter_complete (p);
   1021             break;
   1022 
   1023         case HCI_READ_STORED_LINK_KEY:
   1024             btm_read_stored_link_key_complete (p);
   1025             break;
   1026 
   1027         case HCI_WRITE_STORED_LINK_KEY:
   1028             btm_write_stored_link_key_complete (p);
   1029             break;
   1030 
   1031         case HCI_DELETE_STORED_LINK_KEY:
   1032             btm_delete_stored_link_key_complete (p);
   1033             break;
   1034 
   1035         case HCI_READ_LOCAL_VERSION_INFO:
   1036             btm_read_local_version_complete (p, evt_len);
   1037             break;
   1038 
   1039         case HCI_READ_POLICY_SETTINGS:
   1040             btm_read_link_policy_complete (p);
   1041             break;
   1042 
   1043         case HCI_READ_BUFFER_SIZE:
   1044             btm_read_hci_buf_size_complete (p, evt_len);
   1045             break;
   1046 
   1047         case HCI_READ_LOCAL_SUPPORTED_CMDS:
   1048             btm_read_local_supported_cmds_complete (p);
   1049             break;
   1050 
   1051         case HCI_READ_LOCAL_FEATURES:
   1052             btm_read_local_features_complete (p, evt_len);
   1053             break;
   1054 
   1055         case HCI_READ_LOCAL_EXT_FEATURES:
   1056             btm_read_local_ext_features_complete (p, evt_len);
   1057             break;
   1058 
   1059         case HCI_READ_LOCAL_NAME:
   1060             btm_read_local_name_complete (p, evt_len);
   1061             break;
   1062 
   1063         case HCI_READ_BD_ADDR:
   1064             btm_read_local_addr_complete (p, evt_len);
   1065             break;
   1066 
   1067         case HCI_GET_LINK_QUALITY:
   1068             btm_read_link_quality_complete (p);
   1069             break;
   1070 
   1071         case HCI_READ_RSSI:
   1072             btm_read_rssi_complete (p);
   1073             break;
   1074 
   1075         case HCI_READ_TRANSMIT_POWER_LEVEL:
   1076             btm_read_tx_power_complete(p, FALSE);
   1077             break;
   1078 
   1079         case HCI_CREATE_CONNECTION_CANCEL:
   1080             btm_create_conn_cancel_complete(p);
   1081             break;
   1082 
   1083         case HCI_READ_LOCAL_OOB_DATA:
   1084 #if BTM_OOB_INCLUDED == TRUE
   1085             btm_read_local_oob_complete(p);
   1086 #endif
   1087             break;
   1088 
   1089 
   1090         case HCI_READ_INQ_TX_POWER_LEVEL:
   1091             btm_read_linq_tx_power_complete (p);
   1092             break;
   1093 
   1094         case HCI_WRITE_SIMPLE_PAIRING_MODE:
   1095             btm_write_simple_paring_mode_complete (p);
   1096             break;
   1097 
   1098         case HCI_WRITE_LE_HOST_SUPPORTED:
   1099             btm_write_le_host_supported_complete (p);
   1100             break;
   1101 
   1102 #if (BLE_INCLUDED == TRUE)
   1103 /* BLE Commands */
   1104         case HCI_BLE_READ_WHITE_LIST_SIZE :
   1105             btm_read_white_list_size_complete(p, evt_len);
   1106             break;
   1107 
   1108         case HCI_BLE_ADD_WHITE_LIST:
   1109             btm_ble_add_2_white_list_complete(*p);
   1110             break;
   1111 
   1112         case HCI_BLE_CLEAR_WHITE_LIST:
   1113             btm_ble_clear_white_list_complete(p, evt_len);
   1114             break;
   1115 
   1116         case HCI_BLE_REMOVE_WHITE_LIST:
   1117             btm_ble_remove_from_white_list_complete(p, evt_len);
   1118             break;
   1119 
   1120         case HCI_BLE_RAND:
   1121         case HCI_BLE_ENCRYPT:
   1122 
   1123             btm_ble_rand_enc_complete (p, opcode, (tBTM_RAND_ENC_CB *)p_cplt_cback);
   1124             break;
   1125         case HCI_BLE_READ_BUFFER_SIZE:
   1126             btm_read_ble_buf_size_complete(p, evt_len);
   1127             break;
   1128 
   1129         case HCI_BLE_READ_LOCAL_SPT_FEAT:
   1130             btm_read_ble_local_supported_features_complete(p, evt_len);
   1131             break;
   1132 
   1133         case HCI_BLE_READ_ADV_CHNL_TX_POWER:
   1134             btm_read_tx_power_complete(p, TRUE);
   1135             break;
   1136 
   1137         case HCI_BLE_WRITE_ADV_ENABLE:
   1138             btm_ble_write_adv_enable_complete(p);
   1139             break;
   1140 
   1141         case HCI_BLE_TRANSMITTER_TEST:
   1142         case HCI_BLE_RECEIVER_TEST:
   1143         case HCI_BLE_TEST_END:
   1144             btm_ble_test_command_complete(p);
   1145             break;
   1146 #endif /* (BLE_INCLUDED == TRUE) */
   1147 
   1148         default:
   1149             if ((opcode & HCI_GRP_VENDOR_SPECIFIC) == HCI_GRP_VENDOR_SPECIFIC)
   1150                 btm_vsc_complete (p, opcode, evt_len, (tBTM_CMPL_CB *)p_cplt_cback);
   1151             break;
   1152     }
   1153 }
   1154 
   1155 /*******************************************************************************
   1156 **
   1157 ** Function         btu_hcif_command_complete_evt
   1158 **
   1159 ** Description      Process event HCI_COMMAND_COMPLETE_EVT
   1160 **
   1161 ** Returns          void
   1162 **
   1163 *******************************************************************************/
   1164 static void btu_hcif_command_complete_evt (UINT8 controller_id, UINT8 *p, UINT16 evt_len)
   1165 {
   1166     tHCI_CMD_CB *p_hci_cmd_cb = &(btu_cb.hci_cmd_cb[controller_id]);
   1167     UINT16      cc_opcode;
   1168     BT_HDR      *p_cmd;
   1169     void        *p_cplt_cback = NULL;
   1170 
   1171     STREAM_TO_UINT8  (p_hci_cmd_cb->cmd_window, p);
   1172 
   1173 #if (defined(HCI_MAX_SIMUL_CMDS) && (HCI_MAX_SIMUL_CMDS > 0))
   1174     if (p_hci_cmd_cb->cmd_window > HCI_MAX_SIMUL_CMDS)
   1175         p_hci_cmd_cb->cmd_window = HCI_MAX_SIMUL_CMDS;
   1176 #endif
   1177 
   1178     STREAM_TO_UINT16 (cc_opcode, p);
   1179 
   1180     evt_len -= 3;
   1181 
   1182     /* only do this for certain commands */
   1183     if ((cc_opcode != HCI_RESET) && (cc_opcode != HCI_HOST_NUM_PACKETS_DONE) &&
   1184         (cc_opcode != HCI_COMMAND_NONE))
   1185     {
   1186         /* dequeue and free stored command */
   1187 
   1188 /* always use cmd code check, when one cmd timeout waiting for cmd_cmpl,
   1189    it'll cause the rest of the command goes in wrong order                  */
   1190         p_cmd = (BT_HDR *) GKI_getfirst (&p_hci_cmd_cb->cmd_cmpl_q);
   1191 
   1192         while (p_cmd)
   1193         {
   1194             UINT16 opcode_dequeued;
   1195             UINT8  *p_dequeued;
   1196 
   1197             /* Make sure dequeued command is for the command_cplt received */
   1198             p_dequeued = (UINT8 *)(p_cmd + 1) + p_cmd->offset;
   1199             STREAM_TO_UINT16 (opcode_dequeued, p_dequeued);
   1200 
   1201             if (opcode_dequeued != cc_opcode)
   1202             {
   1203                 /* opcode does not match, check next command in the queue */
   1204                 p_cmd = (BT_HDR *) GKI_getnext(p_cmd);
   1205                 continue;
   1206             }
   1207             GKI_remove_from_queue(&p_hci_cmd_cb->cmd_cmpl_q, p_cmd);
   1208 
   1209             /* If command was a VSC, then extract command_complete callback */
   1210             if ((cc_opcode & HCI_GRP_VENDOR_SPECIFIC) == HCI_GRP_VENDOR_SPECIFIC
   1211 #if BLE_INCLUDED == TRUE
   1212                 || (cc_opcode == HCI_BLE_RAND )
   1213                 || (cc_opcode == HCI_BLE_ENCRYPT)
   1214 #endif
   1215                )
   1216             {
   1217                 p_cplt_cback = *((void **)(p_cmd + 1));
   1218             }
   1219 
   1220             GKI_freebuf (p_cmd);
   1221 
   1222             break;
   1223         }
   1224 
   1225         /* if more commands in queue restart timer */
   1226         if (BTU_CMD_CMPL_TIMEOUT > 0)
   1227         {
   1228             if (!GKI_queue_is_empty (&(p_hci_cmd_cb->cmd_cmpl_q)))
   1229             {
   1230 #if (defined(BTU_CMD_CMPL_TOUT_DOUBLE_CHECK) && BTU_CMD_CMPL_TOUT_DOUBLE_CHECK == TRUE)
   1231                 p_hci_cmd_cb->checked_hcisu = FALSE;
   1232 #endif
   1233                 btu_start_timer (&(p_hci_cmd_cb->cmd_cmpl_timer),
   1234                                  (UINT16)(BTU_TTYPE_BTU_CMD_CMPL + controller_id),
   1235                                  BTU_CMD_CMPL_TIMEOUT);
   1236             }
   1237             else
   1238             {
   1239                 btu_stop_timer (&(p_hci_cmd_cb->cmd_cmpl_timer));
   1240             }
   1241         }
   1242     }
   1243 
   1244     /* handle event */
   1245     btu_hcif_hdl_command_complete (cc_opcode, p, evt_len, p_cplt_cback, controller_id);
   1246 
   1247     /* see if we can send more commands */
   1248     btu_hcif_send_cmd (controller_id, NULL);
   1249 }
   1250 
   1251 
   1252 /*******************************************************************************
   1253 **
   1254 ** Function         btu_hcif_hdl_command_status
   1255 **
   1256 ** Description      Handle a command status event
   1257 **
   1258 ** Returns          void
   1259 **
   1260 *******************************************************************************/
   1261 static void btu_hcif_hdl_command_status (UINT16 opcode, UINT8 status, UINT8 *p_cmd,
   1262                                          void *p_vsc_status_cback, UINT8 controller_id)
   1263 {
   1264     BD_ADDR         bd_addr;
   1265     UINT16          handle;
   1266 #if BTM_SCO_INCLUDED == TRUE
   1267     tBTM_ESCO_DATA  esco_data;
   1268 #endif
   1269 
   1270 #if BTM_PWR_MGR_INCLUDED == TRUE
   1271     switch (opcode)
   1272     {
   1273         case HCI_EXIT_SNIFF_MODE:
   1274         case HCI_EXIT_PARK_MODE:
   1275 #if BTM_SCO_WAKE_PARKED_LINK == TRUE
   1276             if (status != HCI_SUCCESS)
   1277             {
   1278                 /* Allow SCO initiation to continue if waiting for change mode event */
   1279                 if (p_cmd != NULL)
   1280                 {
   1281                     p_cmd++;    /* bypass length field */
   1282                     STREAM_TO_UINT16 (handle, p_cmd);
   1283                     btm_sco_chk_pend_unpark (status, handle);
   1284                 }
   1285             }
   1286 #endif
   1287             /* Case Falls Through */
   1288 
   1289         case HCI_HOLD_MODE:
   1290         case HCI_SNIFF_MODE:
   1291         case HCI_PARK_MODE:
   1292             btm_pm_proc_cmd_status(status);
   1293             break;
   1294 
   1295         default:
   1296 #endif  /* BTM_PWR_MGR_INCLUDED */
   1297             /* If command failed to start, we may need to tell BTM */
   1298             if (status != HCI_SUCCESS)
   1299             {
   1300                 switch (opcode)
   1301                 {
   1302                     case HCI_INQUIRY:
   1303                         /* Tell inquiry processing that we are done */
   1304                         btm_process_inq_complete(status, BTM_BR_INQUIRY_MASK);
   1305                         break;
   1306 
   1307                     case HCI_RMT_NAME_REQUEST:
   1308                         /* Tell inquiry processing that we are done */
   1309                         btm_process_remote_name (NULL, NULL, 0, status);
   1310 
   1311                         btm_sec_rmt_name_request_complete (NULL, NULL, status);
   1312                         break;
   1313 
   1314                     case HCI_CHANGE_CONN_LINK_KEY:
   1315                         /* Let host know we're done with error */
   1316                         /* read handle out of stored command */
   1317                         if (p_cmd != NULL)
   1318                         {
   1319                             p_cmd++;
   1320                             STREAM_TO_UINT16 (handle, p_cmd);
   1321 
   1322                             btm_acl_link_key_change (handle, status);
   1323                         }
   1324                         break;
   1325 
   1326                     case HCI_QOS_SETUP_COMP_EVT:
   1327                         /* Tell qos setup that we are done */
   1328                         btm_qos_setup_complete(status,0,NULL);
   1329                         break;
   1330 
   1331                     case HCI_SWITCH_ROLE:
   1332                         /* Tell BTM that the command failed */
   1333                         /* read bd addr out of stored command */
   1334                         if (p_cmd != NULL)
   1335                         {
   1336                             p_cmd++;
   1337                             STREAM_TO_BDADDR (bd_addr, p_cmd);
   1338                             btm_acl_role_changed(status, bd_addr, BTM_ROLE_UNDEFINED);
   1339                         }
   1340                         else
   1341                             btm_acl_role_changed(status, NULL, BTM_ROLE_UNDEFINED);
   1342                         l2c_link_role_changed (NULL, BTM_ROLE_UNDEFINED, HCI_ERR_COMMAND_DISALLOWED);
   1343                         break;
   1344 
   1345                     case HCI_CREATE_CONNECTION:
   1346                         /* read bd addr out of stored command */
   1347                         if (p_cmd != NULL)
   1348                         {
   1349                             p_cmd++;
   1350                             STREAM_TO_BDADDR (bd_addr, p_cmd);
   1351                             btm_sec_connected (bd_addr, HCI_INVALID_HANDLE, status, 0);
   1352                             l2c_link_hci_conn_comp (status, HCI_INVALID_HANDLE, bd_addr);
   1353                         }
   1354                         break;
   1355 
   1356                     case HCI_READ_RMT_EXT_FEATURES:
   1357                         if (p_cmd != NULL)
   1358                         {
   1359                             p_cmd++; /* skip command length */
   1360                             STREAM_TO_UINT16 (handle, p_cmd);
   1361                         }
   1362                         else
   1363                             handle = HCI_INVALID_HANDLE;
   1364 
   1365                         btm_read_remote_ext_features_failed(status, handle);
   1366                         break;
   1367 
   1368                     case HCI_AUTHENTICATION_REQUESTED:
   1369                         /* Device refused to start authentication.  That should be treated as authentication failure. */
   1370                         btm_sec_auth_complete (BTM_INVALID_HCI_HANDLE, status);
   1371                         break;
   1372 
   1373                     case HCI_SET_CONN_ENCRYPTION:
   1374                         /* Device refused to start encryption.  That should be treated as encryption failure. */
   1375                         btm_sec_encrypt_change (BTM_INVALID_HCI_HANDLE, status, FALSE);
   1376                         break;
   1377 
   1378 #if BTM_SCO_INCLUDED == TRUE
   1379                     case HCI_SETUP_ESCO_CONNECTION:
   1380                         /* read handle out of stored command */
   1381                         if (p_cmd != NULL)
   1382                         {
   1383                             p_cmd++;
   1384                             STREAM_TO_UINT16 (handle, p_cmd);
   1385 
   1386                             /* Determine if initial connection failed or is a change of setup */
   1387                             if (btm_is_sco_active(handle))
   1388                                 btm_esco_proc_conn_chg (status, handle, 0, 0, 0, 0);
   1389                             else
   1390                                 btm_sco_connected (status, NULL, handle, &esco_data);
   1391                         }
   1392                         break;
   1393 #endif
   1394 
   1395 /* This is commented out until an upper layer cares about returning event
   1396 #if L2CAP_NON_FLUSHABLE_PB_INCLUDED == TRUE
   1397             case HCI_ENHANCED_FLUSH:
   1398                 break;
   1399 #endif
   1400 */
   1401                     default:
   1402                         if ((opcode & HCI_GRP_VENDOR_SPECIFIC) == HCI_GRP_VENDOR_SPECIFIC)
   1403                             btm_vsc_complete (&status, opcode, 1, (tBTM_CMPL_CB *)p_vsc_status_cback);
   1404                         break;
   1405                 }
   1406 
   1407             }
   1408             else
   1409             {
   1410                 if ((opcode & HCI_GRP_VENDOR_SPECIFIC) == HCI_GRP_VENDOR_SPECIFIC)
   1411                     btm_vsc_complete (&status, opcode, 1, (tBTM_CMPL_CB *)p_vsc_status_cback);
   1412             }
   1413 #if BTM_PWR_MGR_INCLUDED == TRUE
   1414     }
   1415 #endif
   1416 }
   1417 
   1418 /*******************************************************************************
   1419 **
   1420 ** Function         btu_hcif_command_status_evt
   1421 **
   1422 ** Description      Process event HCI_COMMAND_STATUS_EVT
   1423 **
   1424 ** Returns          void
   1425 **
   1426 *******************************************************************************/
   1427 static void btu_hcif_command_status_evt (UINT8 controller_id, UINT8 *p, UINT16 evt_len)
   1428 {
   1429     tHCI_CMD_CB * p_hci_cmd_cb = &(btu_cb.hci_cmd_cb[controller_id]);
   1430     UINT8       status;
   1431     UINT16      opcode;
   1432     UINT16      cmd_opcode;
   1433     BT_HDR      *p_cmd = NULL;
   1434     UINT8       *p_data = NULL;
   1435     void        *p_vsc_status_cback = NULL;
   1436 
   1437     STREAM_TO_UINT8  (status, p);
   1438     STREAM_TO_UINT8  (p_hci_cmd_cb->cmd_window, p);
   1439 
   1440 #if (defined(HCI_MAX_SIMUL_CMDS) && (HCI_MAX_SIMUL_CMDS > 0))
   1441     if (p_hci_cmd_cb->cmd_window > HCI_MAX_SIMUL_CMDS)
   1442         p_hci_cmd_cb->cmd_window = HCI_MAX_SIMUL_CMDS;
   1443 #endif
   1444 
   1445     STREAM_TO_UINT16 (opcode, p);
   1446 
   1447     /* only do this for certain commands */
   1448     if ((opcode != HCI_RESET) && (opcode != HCI_HOST_NUM_PACKETS_DONE) &&
   1449         (opcode != HCI_COMMAND_NONE))
   1450     {
   1451         /*look for corresponding command in cmd_queue*/
   1452         p_cmd = (BT_HDR *) GKI_getfirst(&(p_hci_cmd_cb->cmd_cmpl_q));
   1453         while (p_cmd)
   1454         {
   1455             p_data = (UINT8 *)(p_cmd + 1) + p_cmd->offset;
   1456             STREAM_TO_UINT16 (cmd_opcode, p_data);
   1457 
   1458             /* Make sure this  command is for the command_status received */
   1459             if (cmd_opcode != opcode)
   1460             {
   1461                 /* opcode does not match, check next command in the queue */
   1462                 p_cmd = (BT_HDR *) GKI_getnext(p_cmd);
   1463                 continue;
   1464             }
   1465             else
   1466             {
   1467                 GKI_remove_from_queue(&p_hci_cmd_cb->cmd_cmpl_q, p_cmd);
   1468 
   1469                 /* If command was a VSC, then extract command_status callback */
   1470                  if ((cmd_opcode & HCI_GRP_VENDOR_SPECIFIC) == HCI_GRP_VENDOR_SPECIFIC)
   1471                 {
   1472                     p_vsc_status_cback = *((void **)(p_cmd + 1));
   1473                 }
   1474                 break;
   1475             }
   1476         }
   1477 
   1478         /* if more commands in queue restart timer */
   1479         if (BTU_CMD_CMPL_TIMEOUT > 0)
   1480         {
   1481             if (!GKI_queue_is_empty (&(p_hci_cmd_cb->cmd_cmpl_q)))
   1482             {
   1483 #if (defined(BTU_CMD_CMPL_TOUT_DOUBLE_CHECK) && BTU_CMD_CMPL_TOUT_DOUBLE_CHECK == TRUE)
   1484                 p_hci_cmd_cb->checked_hcisu = FALSE;
   1485 #endif
   1486                 btu_start_timer (&(p_hci_cmd_cb->cmd_cmpl_timer),
   1487                                  (UINT16)(BTU_TTYPE_BTU_CMD_CMPL + controller_id),
   1488                                  BTU_CMD_CMPL_TIMEOUT);
   1489             }
   1490             else
   1491             {
   1492                 btu_stop_timer (&(p_hci_cmd_cb->cmd_cmpl_timer));
   1493             }
   1494         }
   1495     }
   1496 
   1497     /* handle command */
   1498     btu_hcif_hdl_command_status (opcode, status, p_data, p_vsc_status_cback, controller_id);
   1499 
   1500     /* free stored command */
   1501     if (p_cmd != NULL)
   1502     {
   1503         GKI_freebuf (p_cmd);
   1504     }
   1505     else
   1506     {
   1507         BT_TRACE_1 (TRACE_LAYER_HCI, TRACE_TYPE_WARNING,
   1508                     "No command in queue matching opcode %d", opcode);
   1509     }
   1510 
   1511     /* See if we can forward any more commands */
   1512     btu_hcif_send_cmd (controller_id, NULL);
   1513 }
   1514 
   1515 /*******************************************************************************
   1516 **
   1517 ** Function         btu_hcif_cmd_timeout
   1518 **
   1519 ** Description      Handle a command timeout
   1520 **
   1521 ** Returns          void
   1522 **
   1523 *******************************************************************************/
   1524 void btu_hcif_cmd_timeout (UINT8 controller_id)
   1525 {
   1526     tHCI_CMD_CB * p_hci_cmd_cb = &(btu_cb.hci_cmd_cb[controller_id]);
   1527     BT_HDR  *p_cmd;
   1528     UINT8   *p;
   1529     void    *p_cplt_cback = NULL;
   1530     UINT16  opcode;
   1531     UINT16  event;
   1532 
   1533 #if (defined(BTU_CMD_CMPL_TOUT_DOUBLE_CHECK) && BTU_CMD_CMPL_TOUT_DOUBLE_CHECK == TRUE)
   1534     if (!(p_hci_cmd_cb->checked_hcisu))
   1535     {
   1536         BT_TRACE_1 (TRACE_LAYER_HCI, TRACE_TYPE_WARNING, "BTU HCI(id=%d) command timeout - double check HCISU", controller_id);
   1537 
   1538         /* trigger HCISU to read any pending data in transport buffer */
   1539         GKI_send_event(HCISU_TASK, HCISU_EVT_MASK);
   1540 
   1541         btu_start_timer (&(p_hci_cmd_cb->cmd_cmpl_timer),
   1542                          (UINT16)(BTU_TTYPE_BTU_CMD_CMPL + controller_id),
   1543                          2); /* start short timer, if timer is set to 1 then it could expire before HCISU checks. */
   1544 
   1545         p_hci_cmd_cb->checked_hcisu = TRUE;
   1546 
   1547         return;
   1548     }
   1549 #endif
   1550 
   1551     /* set the controller cmd window to 1, as if we received a response, so
   1552     ** the flow of commands from the stack doesn't hang */
   1553     p_hci_cmd_cb->cmd_window = 1;
   1554 
   1555     /* get queued command */
   1556     if ((p_cmd = (BT_HDR *) GKI_dequeue (&(p_hci_cmd_cb->cmd_cmpl_q))) == NULL)
   1557     {
   1558         BT_TRACE_0 (TRACE_LAYER_HCI, TRACE_TYPE_WARNING, "Cmd timeout; no cmd in queue");
   1559         return;
   1560     }
   1561 
   1562     /* if more commands in queue restart timer */
   1563     if (BTU_CMD_CMPL_TIMEOUT > 0)
   1564     {
   1565         if (!GKI_queue_is_empty (&(p_hci_cmd_cb->cmd_cmpl_q)))
   1566         {
   1567 #if (defined(BTU_CMD_CMPL_TOUT_DOUBLE_CHECK) && BTU_CMD_CMPL_TOUT_DOUBLE_CHECK == TRUE)
   1568             p_hci_cmd_cb->checked_hcisu = FALSE;
   1569 #endif
   1570             btu_start_timer (&(p_hci_cmd_cb->cmd_cmpl_timer),
   1571                              (UINT16)(BTU_TTYPE_BTU_CMD_CMPL + controller_id),
   1572                              BTU_CMD_CMPL_TIMEOUT);
   1573         }
   1574     }
   1575 
   1576     p = (UINT8 *)(p_cmd + 1) + p_cmd->offset;
   1577 #if (NFC_INCLUDED == TRUE)
   1578     if (controller_id == NFC_CONTROLLER_ID)
   1579     {
   1580         //TODO call nfc_ncif_cmd_timeout
   1581         BT_TRACE_2 (TRACE_LAYER_HCI, TRACE_TYPE_WARNING, "BTU NCI command timeout - header 0x%02x%02x", p[0], p[1]);
   1582         return;
   1583     }
   1584 #endif
   1585 
   1586     /* get opcode from stored command */
   1587     STREAM_TO_UINT16 (opcode, p);
   1588 
   1589 // btla-specific ++
   1590 #if (defined(ANDROID_APP_INCLUDED) && (ANDROID_APP_INCLUDED == TRUE))
   1591     ALOGE("######################################################################");
   1592     ALOGE("#");
   1593     ALOGE("# WARNING : BTU HCI(id=%d) command timeout. opcode=0x%x", controller_id, opcode);
   1594     ALOGE("#");
   1595     ALOGE("######################################################################");
   1596 #else
   1597     BT_TRACE_2 (TRACE_LAYER_HCI, TRACE_TYPE_WARNING, "BTU HCI(id=%d) command timeout. opcode=0x%x", controller_id, opcode);
   1598 #endif
   1599 // btla-specific ++
   1600 
   1601     /* send stack a fake command complete or command status, but first determine
   1602     ** which to send
   1603     */
   1604     switch (opcode)
   1605     {
   1606         case HCI_HOLD_MODE:
   1607         case HCI_SNIFF_MODE:
   1608         case HCI_EXIT_SNIFF_MODE:
   1609         case HCI_PARK_MODE:
   1610         case HCI_EXIT_PARK_MODE:
   1611         case HCI_INQUIRY:
   1612         case HCI_RMT_NAME_REQUEST:
   1613         case HCI_QOS_SETUP_COMP_EVT:
   1614         case HCI_CREATE_CONNECTION:
   1615         case HCI_CHANGE_CONN_LINK_KEY:
   1616         case HCI_SWITCH_ROLE:
   1617         case HCI_READ_RMT_EXT_FEATURES:
   1618         case HCI_AUTHENTICATION_REQUESTED:
   1619         case HCI_SET_CONN_ENCRYPTION:
   1620 #if BTM_SCO_INCLUDED == TRUE
   1621         case HCI_SETUP_ESCO_CONNECTION:
   1622 #endif
   1623             /* fake a command status */
   1624             btu_hcif_hdl_command_status (opcode, HCI_ERR_UNSPECIFIED, p, NULL, controller_id);
   1625             break;
   1626 
   1627         default:
   1628             /* If vendor specific restore the callback function */
   1629             if ((opcode & HCI_GRP_VENDOR_SPECIFIC) == HCI_GRP_VENDOR_SPECIFIC
   1630 #if BLE_INCLUDED == TRUE
   1631                 || (opcode == HCI_BLE_RAND ) ||
   1632                 (opcode == HCI_BLE_ENCRYPT)
   1633 #endif
   1634                )
   1635             {
   1636                 p_cplt_cback = *((void **)(p_cmd + 1));
   1637 #if 0
   1638                 BT_TRACE_2 (TRACE_LAYER_HCI, TRACE_TYPE_DEBUG,
   1639                             "Restoring VSC callback for opcode=0x%04x, Callback function=0x%07x",
   1640                             opcode, (UINT32)p_cplt_cback);
   1641 #endif
   1642             }
   1643 
   1644             /* fake a command complete; first create a fake event */
   1645             event = HCI_ERR_UNSPECIFIED;
   1646             btu_hcif_hdl_command_complete (opcode, (UINT8 *)&event, 1, p_cplt_cback, controller_id);
   1647             break;
   1648     }
   1649 
   1650     /* free stored command */
   1651     GKI_freebuf(p_cmd);
   1652 
   1653     num_hci_cmds_timed_out++;
   1654     /* When we receive consecutive HCI cmd timeouts for >=BTM_MAX_HCI_CMD_TOUT_BEFORE_RESTART
   1655      times, Bluetooth process will be killed and restarted */
   1656     if (num_hci_cmds_timed_out >= BTM_MAX_HCI_CMD_TOUT_BEFORE_RESTART)
   1657     {
   1658         BT_TRACE_1(TRACE_LAYER_HCI, TRACE_TYPE_ERROR,
   1659                   "Num consecutive HCI Cmd tout =%d Restarting BT process",num_hci_cmds_timed_out);
   1660 
   1661         usleep(10000); /* 10 milliseconds */
   1662         /* Killing the process to force a restart as part of fault tolerance */
   1663         kill(getpid(), SIGKILL);
   1664     }
   1665     else
   1666     {
   1667         BT_TRACE_1 (TRACE_LAYER_HCI, TRACE_TYPE_WARNING, "HCI Cmd timeout counter %d",
   1668                     num_hci_cmds_timed_out);
   1669 
   1670         /* If anyone wants device status notifications, give him one */
   1671         btm_report_device_status (BTM_DEV_STATUS_CMD_TOUT);
   1672     }
   1673     /* See if we can forward any more commands */
   1674     btu_hcif_send_cmd (controller_id, NULL);
   1675 }
   1676 
   1677 /*******************************************************************************
   1678 **
   1679 ** Function         btu_hcif_hardware_error_evt
   1680 **
   1681 ** Description      Process event HCI_HARDWARE_ERROR_EVT
   1682 **
   1683 ** Returns          void
   1684 **
   1685 *******************************************************************************/
   1686 static void btu_hcif_hardware_error_evt (UINT8 *p, UINT16 evt_len)
   1687 {
   1688     BT_TRACE_1 (TRACE_LAYER_HCI, TRACE_TYPE_ERROR, "Ctlr H/w error event - code:0x%x", *p);
   1689 
   1690     /* If anyone wants device status notifications, give him one. */
   1691     btm_report_device_status (BTM_DEV_STATUS_DOWN);
   1692 
   1693     /* Reset the controller */
   1694     if (BTM_IsDeviceUp())
   1695         BTM_DeviceReset (NULL);
   1696 }
   1697 
   1698 
   1699 /*******************************************************************************
   1700 **
   1701 ** Function         btu_hcif_flush_occured_evt
   1702 **
   1703 ** Description      Process event HCI_FLUSH_OCCURED_EVT
   1704 **
   1705 ** Returns          void
   1706 **
   1707 *******************************************************************************/
   1708 static void btu_hcif_flush_occured_evt (UINT8 *p, UINT16 evt_len)
   1709 {
   1710 }
   1711 
   1712 
   1713 /*******************************************************************************
   1714 **
   1715 ** Function         btu_hcif_role_change_evt
   1716 **
   1717 ** Description      Process event HCI_ROLE_CHANGE_EVT
   1718 **
   1719 ** Returns          void
   1720 **
   1721 *******************************************************************************/
   1722 static void btu_hcif_role_change_evt (UINT8 *p, UINT16 evt_len)
   1723 {
   1724     UINT8       status;
   1725     BD_ADDR     bda;
   1726     UINT8       role;
   1727 
   1728     STREAM_TO_UINT8 (status, p);
   1729     STREAM_TO_BDADDR (bda, p);
   1730     STREAM_TO_UINT8  (role, p);
   1731 
   1732     l2c_link_role_changed (bda, role, status);
   1733     btm_acl_role_changed(status, bda, role);
   1734 }
   1735 
   1736 
   1737 /*******************************************************************************
   1738 **
   1739 ** Function         btu_hcif_num_compl_data_pkts_evt
   1740 **
   1741 ** Description      Process event HCI_NUM_COMPL_DATA_PKTS_EVT
   1742 **
   1743 ** Returns          void
   1744 **
   1745 *******************************************************************************/
   1746 static void btu_hcif_num_compl_data_pkts_evt (UINT8 *p, UINT16 evt_len)
   1747 {
   1748     /* Process for L2CAP and SCO */
   1749     l2c_link_process_num_completed_pkts (p);
   1750 
   1751     /* Send on to SCO */
   1752     /*?? No SCO for now */
   1753 }
   1754 
   1755 /*******************************************************************************
   1756 **
   1757 ** Function         btu_hcif_mode_change_evt
   1758 **
   1759 ** Description      Process event HCI_MODE_CHANGE_EVT
   1760 **
   1761 ** Returns          void
   1762 **
   1763 *******************************************************************************/
   1764 static void btu_hcif_mode_change_evt (UINT8 *p, UINT16 evt_len)
   1765 {
   1766     UINT8       status;
   1767     UINT16      handle;
   1768     UINT8       current_mode;
   1769     UINT16      interval;
   1770 
   1771     STREAM_TO_UINT8 (status, p);
   1772 
   1773     STREAM_TO_UINT16 (handle, p);
   1774     STREAM_TO_UINT8 (current_mode, p);
   1775     STREAM_TO_UINT16 (interval, p);
   1776 #if BTM_PWR_MGR_INCLUDED == TRUE
   1777 #if BTM_SCO_WAKE_PARKED_LINK == TRUE
   1778     btm_sco_chk_pend_unpark (status, handle);
   1779 #endif
   1780     btm_pm_proc_mode_change (status, handle, current_mode, interval);
   1781 #else
   1782     btm_process_mode_change (status, handle, current_mode, interval);
   1783 #endif /* BTM_PWR_MGR_INCLUDED == TRUE */
   1784 
   1785 #if (HID_DEV_INCLUDED == TRUE) && (HID_DEV_PM_INCLUDED == TRUE)
   1786     hidd_pm_proc_mode_change( status, current_mode, interval ) ;
   1787 #endif
   1788 }
   1789 
   1790 /*******************************************************************************
   1791 **
   1792 ** Function         btu_hcif_ssr_evt
   1793 **
   1794 ** Description      Process event HCI_SNIFF_SUB_RATE_EVT
   1795 **
   1796 ** Returns          void
   1797 **
   1798 *******************************************************************************/
   1799     #if (BTM_SSR_INCLUDED == TRUE)
   1800 static void btu_hcif_ssr_evt (UINT8 *p, UINT16 evt_len)
   1801 {
   1802 #if (BTM_PWR_MGR_INCLUDED == TRUE)
   1803     btm_pm_proc_ssr_evt(p, evt_len);
   1804 #endif
   1805 }
   1806     #endif
   1807 
   1808 
   1809 /*******************************************************************************
   1810 **
   1811 ** Function         btu_hcif_return_link_keys_evt
   1812 **
   1813 ** Description      Process event HCI_RETURN_LINK_KEYS_EVT
   1814 **
   1815 ** Returns          void
   1816 **
   1817 *******************************************************************************/
   1818 
   1819 static void btu_hcif_return_link_keys_evt (UINT8 *p, UINT16 evt_len)
   1820 {
   1821     UINT8                       num_keys;
   1822     tBTM_RETURN_LINK_KEYS_EVT   *result;
   1823 
   1824     /* get the number of link keys */
   1825     num_keys = *p;
   1826 
   1827     /* If there are no link keys don't call the call back */
   1828     if (!num_keys)
   1829         return;
   1830 
   1831     /* Take one extra byte at the beginning to specify event */
   1832     result = (tBTM_RETURN_LINK_KEYS_EVT *)(--p);
   1833     result->event = BTM_CB_EVT_RETURN_LINK_KEYS;
   1834 
   1835     /* Call the BTM function to pass the link keys to application */
   1836     btm_return_link_keys_evt (result);
   1837 }
   1838 
   1839 
   1840 /*******************************************************************************
   1841 **
   1842 ** Function         btu_hcif_pin_code_request_evt
   1843 **
   1844 ** Description      Process event HCI_PIN_CODE_REQUEST_EVT
   1845 **
   1846 ** Returns          void
   1847 **
   1848 *******************************************************************************/
   1849 static void btu_hcif_pin_code_request_evt (UINT8 *p, UINT16 evt_len)
   1850 {
   1851     BD_ADDR  bda;
   1852 
   1853     STREAM_TO_BDADDR (bda, p);
   1854 
   1855     /* Tell L2CAP that there was a PIN code request,  */
   1856     /* it may need to stretch timeouts                */
   1857     l2c_pin_code_request (bda);
   1858 
   1859     btm_sec_pin_code_request (bda);
   1860 }
   1861 
   1862 
   1863 /*******************************************************************************
   1864 **
   1865 ** Function         btu_hcif_link_key_request_evt
   1866 **
   1867 ** Description      Process event HCI_LINK_KEY_REQUEST_EVT
   1868 **
   1869 ** Returns          void
   1870 **
   1871 *******************************************************************************/
   1872 static void btu_hcif_link_key_request_evt (UINT8 *p, UINT16 evt_len)
   1873 {
   1874     BD_ADDR  bda;
   1875 
   1876     STREAM_TO_BDADDR (bda, p);
   1877     btm_sec_link_key_request (bda);
   1878 }
   1879 
   1880 
   1881 /*******************************************************************************
   1882 **
   1883 ** Function         btu_hcif_link_key_notification_evt
   1884 **
   1885 ** Description      Process event HCI_LINK_KEY_NOTIFICATION_EVT
   1886 **
   1887 ** Returns          void
   1888 **
   1889 *******************************************************************************/
   1890 static void btu_hcif_link_key_notification_evt (UINT8 *p, UINT16 evt_len)
   1891 {
   1892     BD_ADDR  bda;
   1893     LINK_KEY key;
   1894     UINT8    key_type;
   1895 
   1896     STREAM_TO_BDADDR (bda, p);
   1897     STREAM_TO_ARRAY16 (key, p);
   1898     STREAM_TO_UINT8 (key_type, p);
   1899 
   1900     btm_sec_link_key_notification (bda, key, key_type);
   1901 }
   1902 
   1903 
   1904 /*******************************************************************************
   1905 **
   1906 ** Function         btu_hcif_loopback_command_evt
   1907 **
   1908 ** Description      Process event HCI_LOOPBACK_COMMAND_EVT
   1909 **
   1910 ** Returns          void
   1911 **
   1912 *******************************************************************************/
   1913 static void btu_hcif_loopback_command_evt (UINT8 *p, UINT16 evt_len)
   1914 {
   1915 }
   1916 
   1917 
   1918 /*******************************************************************************
   1919 **
   1920 ** Function         btu_hcif_data_buf_overflow_evt
   1921 **
   1922 ** Description      Process event HCI_DATA_BUF_OVERFLOW_EVT
   1923 **
   1924 ** Returns          void
   1925 **
   1926 *******************************************************************************/
   1927 static void btu_hcif_data_buf_overflow_evt (UINT8 *p, UINT16 evt_len)
   1928 {
   1929 }
   1930 
   1931 
   1932 /*******************************************************************************
   1933 **
   1934 ** Function         btu_hcif_max_slots_changed_evt
   1935 **
   1936 ** Description      Process event HCI_MAX_SLOTS_CHANGED_EVT
   1937 **
   1938 ** Returns          void
   1939 **
   1940 *******************************************************************************/
   1941 static void btu_hcif_max_slots_changed_evt (UINT8 *p, UINT16 evt_len)
   1942 {
   1943 }
   1944 
   1945 
   1946 /*******************************************************************************
   1947 **
   1948 ** Function         btu_hcif_read_clock_off_comp_evt
   1949 **
   1950 ** Description      Process event HCI_READ_CLOCK_OFF_COMP_EVT
   1951 **
   1952 ** Returns          void
   1953 **
   1954 *******************************************************************************/
   1955 static void btu_hcif_read_clock_off_comp_evt (UINT8 *p, UINT16 evt_len)
   1956 {
   1957     UINT8       status;
   1958     UINT16      handle;
   1959     UINT16      clock_offset;
   1960 
   1961     STREAM_TO_UINT8  (status, p);
   1962 
   1963     /* If failed to get clock offset just drop the result */
   1964     if (status != HCI_SUCCESS)
   1965         return;
   1966 
   1967     STREAM_TO_UINT16 (handle, p);
   1968     STREAM_TO_UINT16 (clock_offset, p);
   1969 
   1970     handle = HCID_GET_HANDLE (handle);
   1971 
   1972     btm_process_clk_off_comp_evt (handle, clock_offset);
   1973     btm_sec_update_clock_offset (handle, clock_offset);
   1974 }
   1975 
   1976 
   1977 /*******************************************************************************
   1978 **
   1979 ** Function         btu_hcif_conn_pkt_type_change_evt
   1980 **
   1981 ** Description      Process event HCI_CONN_PKT_TYPE_CHANGE_EVT
   1982 **
   1983 ** Returns          void
   1984 **
   1985 *******************************************************************************/
   1986 static void btu_hcif_conn_pkt_type_change_evt (UINT8 *p, UINT16 evt_len)
   1987 {
   1988 }
   1989 
   1990 
   1991 /*******************************************************************************
   1992 **
   1993 ** Function         btu_hcif_qos_violation_evt
   1994 **
   1995 ** Description      Process event HCI_QOS_VIOLATION_EVT
   1996 **
   1997 ** Returns          void
   1998 **
   1999 *******************************************************************************/
   2000 static void btu_hcif_qos_violation_evt (UINT8 *p, UINT16 evt_len)
   2001 {
   2002     UINT16   handle;
   2003 
   2004     STREAM_TO_UINT16 (handle, p);
   2005 
   2006     handle = HCID_GET_HANDLE (handle);
   2007 
   2008 
   2009     l2c_link_hci_qos_violation (handle);
   2010 }
   2011 
   2012 
   2013 /*******************************************************************************
   2014 **
   2015 ** Function         btu_hcif_page_scan_mode_change_evt
   2016 **
   2017 ** Description      Process event HCI_PAGE_SCAN_MODE_CHANGE_EVT
   2018 **
   2019 ** Returns          void
   2020 **
   2021 *******************************************************************************/
   2022 static void btu_hcif_page_scan_mode_change_evt (UINT8 *p, UINT16 evt_len)
   2023 {
   2024 }
   2025 
   2026 
   2027 /*******************************************************************************
   2028 **
   2029 ** Function         btu_hcif_page_scan_rep_mode_chng_evt
   2030 **
   2031 ** Description      Process event HCI_PAGE_SCAN_REP_MODE_CHNG_EVT
   2032 **
   2033 ** Returns          void
   2034 **
   2035 *******************************************************************************/
   2036 static void btu_hcif_page_scan_rep_mode_chng_evt (UINT8 *p, UINT16 evt_len)
   2037 {
   2038 }
   2039 
   2040 /**********************************************
   2041 ** Simple Pairing Events
   2042 ***********************************************/
   2043 
   2044 /*******************************************************************************
   2045 **
   2046 ** Function         btu_hcif_host_support_evt
   2047 **
   2048 ** Description      Process event HCI_RMT_HOST_SUP_FEAT_NOTIFY_EVT
   2049 **
   2050 ** Returns          void
   2051 **
   2052 *******************************************************************************/
   2053 static void btu_hcif_host_support_evt (UINT8 *p, UINT16 evt_len)
   2054 {
   2055     btm_sec_rmt_host_support_feat_evt(p);
   2056 }
   2057 
   2058 /*******************************************************************************
   2059 **
   2060 ** Function         btu_hcif_io_cap_request_evt
   2061 **
   2062 ** Description      Process event HCI_IO_CAPABILITY_REQUEST_EVT
   2063 **
   2064 ** Returns          void
   2065 **
   2066 *******************************************************************************/
   2067 static void btu_hcif_io_cap_request_evt (UINT8 *p, UINT16 evt_len)
   2068 {
   2069     btm_io_capabilities_req(p);
   2070 }
   2071 
   2072 
   2073 /*******************************************************************************
   2074 **
   2075 ** Function         btu_hcif_io_cap_response_evt
   2076 **
   2077 ** Description      Process event HCI_IO_CAPABILITY_RESPONSE_EVT
   2078 **
   2079 ** Returns          void
   2080 **
   2081 *******************************************************************************/
   2082 static void btu_hcif_io_cap_response_evt (UINT8 *p, UINT16 evt_len)
   2083 {
   2084     btm_io_capabilities_rsp(p);
   2085 }
   2086 
   2087 
   2088 /*******************************************************************************
   2089 **
   2090 ** Function         btu_hcif_user_conf_request_evt
   2091 **
   2092 ** Description      Process event HCI_USER_CONFIRMATION_REQUEST_EVT
   2093 **
   2094 ** Returns          void
   2095 **
   2096 *******************************************************************************/
   2097 static void btu_hcif_user_conf_request_evt (UINT8 *p, UINT16 evt_len)
   2098 {
   2099     btm_proc_sp_req_evt(BTM_SP_CFM_REQ_EVT, p);
   2100 }
   2101 
   2102 
   2103 /*******************************************************************************
   2104 **
   2105 ** Function         btu_hcif_user_passkey_request_evt
   2106 **
   2107 ** Description      Process event HCI_USER_PASSKEY_REQUEST_EVT
   2108 **
   2109 ** Returns          void
   2110 **
   2111 *******************************************************************************/
   2112 static void btu_hcif_user_passkey_request_evt (UINT8 *p, UINT16 evt_len)
   2113 {
   2114     btm_proc_sp_req_evt(BTM_SP_KEY_REQ_EVT, p);
   2115 }
   2116 
   2117 /*******************************************************************************
   2118 **
   2119 ** Function         btu_hcif_user_passkey_notif_evt
   2120 **
   2121 ** Description      Process event HCI_USER_PASSKEY_NOTIFY_EVT
   2122 **
   2123 ** Returns          void
   2124 **
   2125 *******************************************************************************/
   2126 static void btu_hcif_user_passkey_notif_evt (UINT8 *p, UINT16 evt_len)
   2127 {
   2128     btm_proc_sp_req_evt(BTM_SP_KEY_NOTIF_EVT, p);
   2129 }
   2130 
   2131 /*******************************************************************************
   2132 **
   2133 ** Function         btu_hcif_keypress_notif_evt
   2134 **
   2135 ** Description      Process event HCI_KEYPRESS_NOTIFY_EVT
   2136 **
   2137 ** Returns          void
   2138 **
   2139 *******************************************************************************/
   2140 static void btu_hcif_keypress_notif_evt (UINT8 *p, UINT16 evt_len)
   2141 {
   2142     btm_keypress_notif_evt(p);
   2143 }
   2144 
   2145 /*******************************************************************************
   2146 **
   2147 ** Function         btu_hcif_link_super_tout_evt
   2148 **
   2149 ** Description      Process event HCI_LINK_SUPER_TOUT_CHANGED_EVT
   2150 **
   2151 ** Returns          void
   2152 **
   2153 *******************************************************************************/
   2154 static void btu_hcif_link_super_tout_evt (UINT8 *p, UINT16 evt_len)
   2155 {
   2156     UINT16 handle, timeout;
   2157     STREAM_TO_UINT16 (handle, p);
   2158     STREAM_TO_UINT16 (timeout, p);
   2159 
   2160     btm_proc_lsto_evt(handle, timeout);
   2161 }
   2162 
   2163 /*******************************************************************************
   2164 **
   2165 ** Function         btu_hcif_rem_oob_request_evt
   2166 **
   2167 ** Description      Process event HCI_REMOTE_OOB_DATA_REQUEST_EVT
   2168 **
   2169 ** Returns          void
   2170 **
   2171 *******************************************************************************/
   2172     #if BTM_OOB_INCLUDED == TRUE
   2173 static void btu_hcif_rem_oob_request_evt (UINT8 *p, UINT16 evt_len)
   2174 {
   2175     btm_rem_oob_req(p);
   2176 }
   2177     #endif
   2178 
   2179 /*******************************************************************************
   2180 **
   2181 ** Function         btu_hcif_simple_pair_complete_evt
   2182 **
   2183 ** Description      Process event HCI_SIMPLE_PAIRING_COMPLETE_EVT
   2184 **
   2185 ** Returns          void
   2186 **
   2187 *******************************************************************************/
   2188 static void btu_hcif_simple_pair_complete_evt (UINT8 *p, UINT16 evt_len)
   2189 {
   2190     btm_simple_pair_complete(p);
   2191 }
   2192 /*******************************************************************************
   2193 **
   2194 ** Function         btu_hcif_flush_cmd_queue
   2195 **
   2196 ** Description      Flush the HCI command complete queue and transmit queue when
   2197 **                  needed.
   2198 **
   2199 ** Returns          void
   2200 **
   2201 *******************************************************************************/
   2202 void btu_hcif_flush_cmd_queue(void)
   2203 {
   2204     BT_HDR *p_cmd;
   2205 
   2206     btu_cb.hci_cmd_cb[0].cmd_window = 0;
   2207     while ((p_cmd = (BT_HDR *) GKI_dequeue (&btu_cb.hci_cmd_cb[0].cmd_cmpl_q)) != NULL)
   2208     {
   2209         GKI_freebuf (p_cmd);
   2210     }
   2211     while ((p_cmd = (BT_HDR *) GKI_dequeue (&btu_cb.hci_cmd_cb[0].cmd_xmit_q)) != NULL)
   2212     {
   2213         GKI_freebuf (p_cmd);
   2214     }
   2215 }
   2216 
   2217 /*******************************************************************************
   2218 **
   2219 ** Function         btu_hcif_enhanced_flush_complete_evt
   2220 **
   2221 ** Description      Process event HCI_ENHANCED_FLUSH_COMPLETE_EVT
   2222 **
   2223 ** Returns          void
   2224 **
   2225 *******************************************************************************/
   2226 #if L2CAP_NON_FLUSHABLE_PB_INCLUDED == TRUE
   2227 static void btu_hcif_enhanced_flush_complete_evt (UINT8 *p, UINT16 evt_len)
   2228 {
   2229 /* This is empty until an upper layer cares about returning event */
   2230 }
   2231 #endif
   2232 /**********************************************
   2233 ** End of Simple Pairing Events
   2234 ***********************************************/
   2235 
   2236 
   2237 /**********************************************
   2238 ** BLE Events
   2239 ***********************************************/
   2240 #if (defined BLE_INCLUDED) && (BLE_INCLUDED == TRUE)
   2241 static void btu_hcif_encyption_key_refresh_cmpl_evt (UINT8 *p, UINT16 evt_len)
   2242 {
   2243     UINT8   status;
   2244     UINT16  handle;
   2245 
   2246     STREAM_TO_UINT8  (status, p);
   2247     STREAM_TO_UINT16 (handle, p);
   2248 
   2249     btm_sec_encrypt_change (handle, status, 1);
   2250 }
   2251 
   2252 static void btu_ble_process_adv_pkt (UINT8 *p, UINT16 evt_len)
   2253 {
   2254     BT_TRACE_0 (TRACE_LAYER_HCI, TRACE_TYPE_EVENT, "btu_ble_process_adv_pkt");
   2255 
   2256     btm_ble_process_adv_pkt(p);
   2257 }
   2258 
   2259 static void btu_ble_ll_conn_complete_evt ( UINT8 *p, UINT16 evt_len)
   2260 {
   2261     btm_ble_conn_complete(p, evt_len);
   2262 }
   2263 
   2264 static void btu_ble_ll_conn_param_upd_evt (UINT8 *p, UINT16 evt_len)
   2265 {
   2266 /* This is empty until an upper layer cares about returning event */
   2267 }
   2268 
   2269 static void btu_ble_read_remote_feat_evt (UINT8 *p, UINT16 evt_len)
   2270 {
   2271     btm_ble_read_remote_features_complete(p);
   2272 }
   2273 
   2274 static void btu_ble_proc_ltk_req (UINT8 *p, UINT16 evt_len)
   2275 {
   2276     UINT16 ediv, handle;
   2277     UINT8   *pp;
   2278 
   2279     STREAM_TO_UINT16(handle, p);
   2280     pp = p + 8;
   2281     STREAM_TO_UINT16(ediv, pp);
   2282 #if BLE_INCLUDED == TRUE && SMP_INCLUDED == TRUE
   2283     btm_ble_ltk_request(handle, p, ediv);
   2284 #endif
   2285     /* This is empty until an upper layer cares about returning event */
   2286 }
   2287 /**********************************************
   2288 ** End of BLE Events Handler
   2289 ***********************************************/
   2290 #endif /* BLE_INCLUDED */
   2291 
   2292