/****************************************************************************** * * Copyright (C) 2003-2014 Broadcom Corporation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ******************************************************************************/ /****************************************************************************** * * This is the API implementation file for the BTA device manager. * ******************************************************************************/ #include "bta/bta_sys.h" #include "bta/bta_api.h" #include "bta_dm_int.h" #include "bta_sys_int.h" #include "stack/btm_api.h" #include "btm_int.h" #include #include "bta/utl.h" #include "osi/allocator.h" /***************************************************************************** ** Constants *****************************************************************************/ static const tBTA_SYS_REG bta_dm_reg = { bta_dm_sm_execute, bta_dm_sm_disable }; static const tBTA_SYS_REG bta_dm_search_reg = { bta_dm_search_sm_execute, bta_dm_search_sm_disable }; /******************************************************************************* ** ** Function BTA_EnableBluetooth ** ** Description Enables bluetooth service. This function must be ** called before any other functions in the BTA API are called. ** ** ** Returns tBTA_STATUS ** *******************************************************************************/ tBTA_STATUS BTA_EnableBluetooth(tBTA_DM_SEC_CBACK *p_cback) { tBTA_DM_API_ENABLE *p_msg; /* Bluetooth disabling is in progress */ if (bta_dm_cb.disabling) { return BTA_FAILURE; } memset(&bta_dm_cb, 0, sizeof(bta_dm_cb)); bta_sys_register (BTA_ID_DM, &bta_dm_reg ); bta_sys_register (BTA_ID_DM_SEARCH, &bta_dm_search_reg ); /* if UUID list is not provided as static data */ bta_sys_eir_register(bta_dm_eir_update_uuid); if ((p_msg = (tBTA_DM_API_ENABLE *) osi_malloc(sizeof(tBTA_DM_API_ENABLE))) != NULL) { p_msg->hdr.event = BTA_DM_API_ENABLE_EVT; p_msg->p_sec_cback = p_cback; bta_sys_sendmsg(p_msg); return BTA_SUCCESS; } return BTA_FAILURE; } /******************************************************************************* ** ** Function BTA_DisableBluetooth ** ** Description Disables bluetooth service. This function is called when ** the application no longer needs bluetooth service ** ** Returns void ** *******************************************************************************/ tBTA_STATUS BTA_DisableBluetooth(void) { BT_HDR *p_msg; if ((p_msg = (BT_HDR *) osi_malloc(sizeof(BT_HDR))) != NULL) { p_msg->event = BTA_DM_API_DISABLE_EVT; bta_sys_sendmsg(p_msg); } else { return BTA_FAILURE; } return BTA_SUCCESS; } /******************************************************************************* ** ** Function BTA_EnableTestMode ** ** Description Enables bluetooth device under test mode ** ** ** Returns tBTA_STATUS ** *******************************************************************************/ tBTA_STATUS BTA_EnableTestMode(void) { BT_HDR *p_msg; APPL_TRACE_API("BTA_EnableTestMode"); if ((p_msg = (BT_HDR *) osi_malloc(sizeof(BT_HDR))) != NULL) { p_msg->event = BTA_DM_API_ENABLE_TEST_MODE_EVT; bta_sys_sendmsg(p_msg); return BTA_SUCCESS; } return BTA_FAILURE; } /******************************************************************************* ** ** Function BTA_DisableTestMode ** ** Description Disable bluetooth device under test mode ** ** ** Returns None ** *******************************************************************************/ void BTA_DisableTestMode(void) { BT_HDR *p_msg; APPL_TRACE_API("BTA_DisableTestMode"); if ((p_msg = (BT_HDR *) osi_malloc(sizeof(BT_HDR))) != NULL) { p_msg->event = BTA_DM_API_DISABLE_TEST_MODE_EVT; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSetDeviceName ** ** Description This function sets the Bluetooth name of local device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSetDeviceName(const char *p_name) { tBTA_DM_API_SET_NAME *p_msg; if ((p_msg = (tBTA_DM_API_SET_NAME *) osi_malloc(sizeof(tBTA_DM_API_SET_NAME))) != NULL) { p_msg->hdr.event = BTA_DM_API_SET_NAME_EVT; /* truncate the name if needed */ BCM_STRNCPY_S((char *)p_msg->name, p_name, BD_NAME_LEN); p_msg->name[BD_NAME_LEN] = '\0'; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmGetDeviceName ** ** Description This function gets the Bluetooth name of local device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmGetDeviceName(tBTA_GET_DEV_NAME_CBACK *p_cback) { tBTA_DM_API_GET_NAME *p_msg; if ((p_msg = (tBTA_DM_API_GET_NAME *) osi_malloc(sizeof(tBTA_DM_API_GET_NAME))) != NULL) { p_msg->hdr.event = BTA_DM_API_GET_NAME_EVT; p_msg->p_cback = p_cback; bta_sys_sendmsg(p_msg); } } #if (CLASSIC_BT_INCLUDED == TRUE) void BTA_DmConfigEir(tBTA_DM_EIR_CONF *eir_config) { tBTA_DM_API_CONFIG_EIR *p_msg; UINT8 eir_manufac_spec_len = eir_config->bta_dm_eir_manufac_spec_len; UINT8 eir_url_len = eir_config->bta_dm_eir_url_len; if (eir_manufac_spec_len > HCI_EXT_INQ_RESPONSE_LEN) { APPL_TRACE_WARNING ("%s: Manufacturer data is too long(%d), cut it to %d\n", __func__, eir_manufac_spec_len, HCI_EXT_INQ_RESPONSE_LEN); eir_manufac_spec_len = HCI_EXT_INQ_RESPONSE_LEN; } if (eir_url_len > HCI_EXT_INQ_RESPONSE_LEN) { APPL_TRACE_WARNING ("%s: URL is too long(%d), cut it to %d\n", __func__, eir_url_len, HCI_EXT_INQ_RESPONSE_LEN); eir_url_len = HCI_EXT_INQ_RESPONSE_LEN; } if ((p_msg = (tBTA_DM_API_CONFIG_EIR *) osi_malloc(sizeof(tBTA_DM_API_CONFIG_EIR) + eir_manufac_spec_len + eir_url_len)) != NULL) { p_msg->hdr.event = BTA_DM_API_CONFIG_EIR_EVT; p_msg->eir_fec_required = eir_config->bta_dm_eir_fec_required; p_msg->eir_included_tx_power = eir_config->bta_dm_eir_included_tx_power; p_msg->eir_included_uuid = eir_config->bta_dm_eir_included_uuid; p_msg->eir_flags = eir_config->bta_dm_eir_flags; p_msg->eir_manufac_spec_len = eir_manufac_spec_len; p_msg->eir_manufac_spec = p_msg->data; p_msg->eir_url_len = eir_url_len; p_msg->eir_url = p_msg->data + eir_manufac_spec_len; if (eir_manufac_spec_len > 0) { memcpy(p_msg->eir_manufac_spec, eir_config->bta_dm_eir_manufac_spec, eir_manufac_spec_len); } if (eir_url_len > 0) { memcpy(p_msg->eir_url, eir_config->bta_dm_eir_url, eir_url_len); } bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSetAfhChannels ** ** Description This function sets the AFH channels ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSetAfhChannels(const uint8_t *channels, tBTA_CMPL_CB *set_afh_cb) { tBTA_DM_API_SET_AFH_CHANNELS *p_msg; if ((p_msg = (tBTA_DM_API_SET_AFH_CHANNELS *) osi_malloc(sizeof(tBTA_DM_API_SET_AFH_CHANNELS))) != NULL) { p_msg->hdr.event = BTA_DM_API_SET_AFH_CHANNELS_EVT; p_msg->set_afh_cb = set_afh_cb; memcpy(p_msg->channels, channels, AFH_CHANNELS_LEN); bta_sys_sendmsg(p_msg); } } #endif /// CLASSIC_BT_INCLUDED == TRUE #if (SDP_INCLUDED == TRUE) /******************************************************************************* ** ** Function BTA_DmGetRemoteName ** ** Description This function gets the peer device's Bluetooth name. ** ** ** Returns void ** *******************************************************************************/ void BTA_DmGetRemoteName(BD_ADDR remote_addr, tBTA_CMPL_CB *rmt_name_cb) { tBTA_DM_API_GET_REMOTE_NAME *p_msg; if ((p_msg = (tBTA_DM_API_GET_REMOTE_NAME *) osi_malloc(sizeof(tBTA_DM_API_GET_REMOTE_NAME))) != NULL) { p_msg->hdr.event = BTA_DM_API_GET_REMOTE_NAME_EVT; p_msg->rmt_name_cb = rmt_name_cb; bdcpy(p_msg->rmt_addr, remote_addr); bta_sys_sendmsg(p_msg); } } #endif #if (BLE_INCLUDED == TRUE) /******************************************************************************* ** ** Function BTA_DmBleSetChannels ** ** Description This function sets BLE channels ** ** ** Returns void ** *******************************************************************************/ void BTA_DmBleSetChannels(const uint8_t *channels, tBTA_CMPL_CB *set_channels_cb) { tBTA_DM_API_BLE_SET_CHANNELS *p_msg; if ((p_msg = (tBTA_DM_API_BLE_SET_CHANNELS *) osi_malloc(sizeof(tBTA_DM_API_BLE_SET_CHANNELS))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_SET_CHANNELS_EVT; p_msg->set_channels_cb = set_channels_cb; memcpy(p_msg->channels, channels, BLE_CHANNELS_LEN); bta_sys_sendmsg(p_msg); } } void BTA_DmUpdateWhiteList(BOOLEAN add_remove, BD_ADDR remote_addr, tBLE_ADDR_TYPE addr_type, tBTA_UPDATE_WHITELIST_CBACK *update_wl_cb) { tBTA_DM_API_UPDATE_WHITE_LIST *p_msg; if ((p_msg = (tBTA_DM_API_UPDATE_WHITE_LIST *)osi_malloc(sizeof(tBTA_DM_API_UPDATE_WHITE_LIST))) != NULL) { p_msg->hdr.event = BTA_DM_API_UPDATE_WHITE_LIST_EVT; p_msg->add_remove = add_remove; p_msg->addr_type = addr_type; p_msg->update_wl_cb = update_wl_cb; memcpy(p_msg->remote_addr, remote_addr, sizeof(BD_ADDR)); bta_sys_sendmsg(p_msg); } } void BTA_DmClearWhiteList(tBTA_UPDATE_WHITELIST_CBACK *update_wl_cb) { tBTA_DM_API_UPDATE_WHITE_LIST *p_msg; if ((p_msg = (tBTA_DM_API_UPDATE_WHITE_LIST *)osi_malloc(sizeof(tBTA_DM_API_UPDATE_WHITE_LIST))) != NULL) { p_msg->hdr.event = BTA_DM_API_CLEAR_WHITE_LIST_EVT; p_msg->update_wl_cb = update_wl_cb; bta_sys_sendmsg(p_msg); } } void BTA_DmBleReadAdvTxPower(tBTA_CMPL_CB *cmpl_cb) { tBTA_DM_API_READ_ADV_TX_POWER *p_msg; if ((p_msg = (tBTA_DM_API_READ_ADV_TX_POWER *)osi_malloc(sizeof(tBTA_DM_API_READ_ADV_TX_POWER))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_READ_ADV_TX_POWER_EVT; p_msg->read_tx_power_cb = cmpl_cb; bta_sys_sendmsg(p_msg); } } #endif ///BLE_INCLUDED == TRUE void BTA_DmReadRSSI(BD_ADDR remote_addr, tBTA_TRANSPORT transport, tBTA_CMPL_CB *cmpl_cb) { tBTA_DM_API_READ_RSSI *p_msg; if ((p_msg = (tBTA_DM_API_READ_RSSI *)osi_malloc(sizeof(tBTA_DM_API_READ_RSSI))) != NULL) { p_msg->hdr.event = BTA_DM_API_READ_RSSI_EVT; memcpy(p_msg->remote_addr, remote_addr, sizeof(BD_ADDR)); p_msg->transport = transport; p_msg->read_rssi_cb = cmpl_cb; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSetVisibility ** ** Description This function sets the Bluetooth connectable, ** discoverable, pairable and conn paired only modes of local device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSetVisibility(tBTA_DM_DISC disc_mode, tBTA_DM_CONN conn_mode, UINT8 pairable_mode, UINT8 conn_filter ) { tBTA_DM_API_SET_VISIBILITY *p_msg; if ((p_msg = (tBTA_DM_API_SET_VISIBILITY *) osi_malloc(sizeof(tBTA_DM_API_SET_VISIBILITY))) != NULL) { p_msg->hdr.event = BTA_DM_API_SET_VISIBILITY_EVT; p_msg->disc_mode = disc_mode; p_msg->conn_mode = conn_mode; p_msg->pair_mode = pairable_mode; p_msg->conn_paired_only = conn_filter; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSearch ** ** Description This function searches for peer Bluetooth devices. It performs ** an inquiry and gets the remote name for devices. Service ** discovery is done if services is non zero ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSearch(tBTA_DM_INQ *p_dm_inq, tBTA_SERVICE_MASK services, tBTA_DM_SEARCH_CBACK *p_cback) { tBTA_DM_API_SEARCH *p_msg; if ((p_msg = (tBTA_DM_API_SEARCH *) osi_malloc(sizeof(tBTA_DM_API_SEARCH))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_SEARCH)); p_msg->hdr.event = BTA_DM_API_SEARCH_EVT; memcpy(&p_msg->inq_params, p_dm_inq, sizeof(tBTA_DM_INQ)); p_msg->services = services; p_msg->p_cback = p_cback; p_msg->rs_res = BTA_DM_RS_NONE; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSearchCancel ** ** Description This function cancels a search initiated by BTA_DmSearch ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSearchCancel(void) { BT_HDR *p_msg; if ((p_msg = (BT_HDR *) osi_malloc(sizeof(BT_HDR))) != NULL) { p_msg->event = BTA_DM_API_SEARCH_CANCEL_EVT; bta_sys_sendmsg(p_msg); } } #if (SDP_INCLUDED == TRUE) /******************************************************************************* ** ** Function BTA_DmDiscover ** ** Description This function does service discovery for services of a ** peer device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmDiscover(BD_ADDR bd_addr, tBTA_SERVICE_MASK services, tBTA_DM_SEARCH_CBACK *p_cback, BOOLEAN sdp_search) { tBTA_DM_API_DISCOVER *p_msg; if ((p_msg = (tBTA_DM_API_DISCOVER *) osi_malloc(sizeof(tBTA_DM_API_DISCOVER))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_DISCOVER)); p_msg->hdr.event = BTA_DM_API_DISCOVER_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->services = services; p_msg->p_cback = p_cback; p_msg->sdp_search = sdp_search; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmDiscoverUUID ** ** Description This function does service discovery for services of a ** peer device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmDiscoverUUID(BD_ADDR bd_addr, tSDP_UUID *uuid, tBTA_DM_SEARCH_CBACK *p_cback, BOOLEAN sdp_search) { tBTA_DM_API_DISCOVER *p_msg; if ((p_msg = (tBTA_DM_API_DISCOVER *) osi_malloc(sizeof(tBTA_DM_API_DISCOVER))) != NULL) { p_msg->hdr.event = BTA_DM_API_DISCOVER_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->services = BTA_USER_SERVICE_MASK; //Not exposed at API level p_msg->p_cback = p_cback; p_msg->sdp_search = sdp_search; #if BLE_INCLUDED == TRUE && BTA_GATT_INCLUDED == TRUE p_msg->num_uuid = 0; p_msg->p_uuid = NULL; #endif memcpy( &p_msg->uuid, uuid, sizeof(tSDP_UUID) ); bta_sys_sendmsg(p_msg); } } #endif ///SDP_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmBond ** ** Description This function initiates a bonding procedure with a peer ** device ** ** ** Returns void ** *******************************************************************************/ #if (SMP_INCLUDED == TRUE) void BTA_DmBond(BD_ADDR bd_addr) { tBTA_DM_API_BOND *p_msg; p_msg = (tBTA_DM_API_BOND *) osi_malloc(sizeof(tBTA_DM_API_BOND)); if (p_msg != NULL) { p_msg->hdr.event = BTA_DM_API_BOND_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->transport = BTA_TRANSPORT_UNKNOWN; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBondByTransports ** ** Description This function initiates a bonding procedure with a peer ** device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmBondByTransport(BD_ADDR bd_addr, tBTA_TRANSPORT transport) { tBTA_DM_API_BOND *p_msg; if ((p_msg = (tBTA_DM_API_BOND *) osi_malloc(sizeof(tBTA_DM_API_BOND))) != NULL) { p_msg->hdr.event = BTA_DM_API_BOND_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->transport = transport; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBondCancel ** ** Description This function cancels the bonding procedure with a peer ** device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmBondCancel(BD_ADDR bd_addr) { tBTA_DM_API_BOND_CANCEL *p_msg; if ((p_msg = (tBTA_DM_API_BOND_CANCEL *) osi_malloc(sizeof(tBTA_DM_API_BOND_CANCEL))) != NULL) { p_msg->hdr.event = BTA_DM_API_BOND_CANCEL_EVT; bdcpy(p_msg->bd_addr, bd_addr); bta_sys_sendmsg(p_msg); } } #endif ///SMP_INCLUDED == TRUE #if (CLASSIC_BT_INCLUDED == TRUE) /******************************************************************************* ** ** Function BTA_DMSetPinType ** ** Description This function set pin type as BTM_PIN_TYPE_FIXED or BTM_PIN_TYPE_VARIABLE ** ** ** Returns void ** *******************************************************************************/ void BTA_DMSetPinType (UINT8 pin_type, UINT8 *pin_code, UINT8 pin_code_len) { tBTA_DM_API_SET_PIN_TYPE *p_msg; if ((p_msg = (tBTA_DM_API_SET_PIN_TYPE *) osi_malloc(sizeof(tBTA_DM_API_SET_PIN_TYPE))) != NULL) { p_msg->hdr.event = BTA_DM_API_SET_PIN_TYPE_EVT; p_msg->pin_type = pin_type; p_msg->pin_len = pin_code_len; memcpy(p_msg->p_pin, pin_code, pin_code_len); bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmPinReply ** ** Description This function provides a pincode for a remote device when ** one is requested by DM through BTA_DM_PIN_REQ_EVT ** ** ** Returns void ** *******************************************************************************/ void BTA_DmPinReply(BD_ADDR bd_addr, BOOLEAN accept, UINT8 pin_len, UINT8 *p_pin) { tBTA_DM_API_PIN_REPLY *p_msg; if ((p_msg = (tBTA_DM_API_PIN_REPLY *) osi_malloc(sizeof(tBTA_DM_API_PIN_REPLY))) != NULL) { p_msg->hdr.event = BTA_DM_API_PIN_REPLY_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->accept = accept; if (accept) { p_msg->pin_len = pin_len; memcpy(p_msg->p_pin, p_pin, pin_len); } bta_sys_sendmsg(p_msg); } } #endif ///CLASSIC_BT_INCLUDED == TRUE #if (BTM_OOB_INCLUDED == TRUE && SMP_INCLUDED == TRUE) /******************************************************************************* ** ** Function BTA_DmLocalOob ** ** Description This function retrieves the OOB data from local controller. ** The result is reported by: ** - bta_dm_co_loc_oob_ext() if device supports secure ** connections (SC) ** - bta_dm_co_loc_oob() if device doesn't support SC ** ** Returns void ** *******************************************************************************/ void BTA_DmLocalOob(void) { tBTA_DM_API_LOC_OOB *p_msg; if ((p_msg = (tBTA_DM_API_LOC_OOB *) osi_malloc(sizeof(tBTA_DM_API_LOC_OOB))) != NULL) { p_msg->hdr.event = BTA_DM_API_LOC_OOB_EVT; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmOobReply ** ** This function is called to provide the OOB data for ** SMP in response to BTA_LE_OOB_REQ_EVT ** ** Parameters: bd_addr - Address of the peer device ** len - length of simple pairing Randomizer C ** p_value - simple pairing Randomizer C. ** ** Returns void ** *******************************************************************************/ void BTA_DmOobReply(BD_ADDR bd_addr, UINT8 len, UINT8 *p_value) { tBTA_DM_API_OOB_REPLY *p_msg; if ((p_msg = (tBTA_DM_API_OOB_REPLY *) osi_malloc(sizeof(tBTA_DM_API_OOB_REPLY))) != NULL) { p_msg->hdr.event = BTA_DM_API_OOB_REPLY_EVT; if(p_value == NULL || len > BT_OCTET16_LEN) { osi_free(p_msg); return; } memcpy(p_msg->bd_addr, bd_addr, BD_ADDR_LEN); p_msg->len = len; memcpy(p_msg->value, p_value, len); bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSecureConnectionOobReply ** ** This function is called to provide the OOB data for ** SMP in response to BTA_LE_OOB_REQ_EVT ** ** Parameters: bd_addr - Address of the peer device ** p_c - Pointer to Confirmation ** p_r - Pointer to Randomizer ** ** Returns void ** *******************************************************************************/ void BTA_DmSecureConnectionOobReply(BD_ADDR bd_addr, UINT8 *p_c, UINT8 *p_r) { tBTA_DM_API_SC_OOB_REPLY *p_msg; if ((p_msg = (tBTA_DM_API_SC_OOB_REPLY *) osi_malloc(sizeof(tBTA_DM_API_OOB_REPLY))) != NULL) { p_msg->hdr.event = BTA_DM_API_SC_OOB_REPLY_EVT; if((p_c == NULL) || (p_r == NULL)) { return; } memcpy(p_msg->bd_addr, bd_addr, BD_ADDR_LEN); memcpy(p_msg->c, p_c, BT_OCTET16_LEN); memcpy(p_msg->r, p_r, BT_OCTET16_LEN); bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSecureConnectionCreateOobData ** ** This function is called to create the OOB data for ** SMP when secure connection ** ** Returns void ** *******************************************************************************/ void BTA_DmSecureConnectionCreateOobData(void) { tBTA_DM_API_SC_CR_OOB_DATA *p_msg; if ((p_msg = (tBTA_DM_API_SC_CR_OOB_DATA *) osi_malloc(sizeof(tBTA_DM_API_SC_CR_OOB_DATA))) != NULL) { p_msg->hdr.event = BTA_DM_API_SC_CR_OOB_DATA_EVT; bta_sys_sendmsg(p_msg); } } #endif /* BTM_OOB_INCLUDED */ /******************************************************************************* ** ** Function BTA_DmConfirm ** ** Description This function accepts or rejects the numerical value of the ** Simple Pairing process on BTA_DM_SP_CFM_REQ_EVT ** ** Returns void ** *******************************************************************************/ #if (SMP_INCLUDED == TRUE) void BTA_DmConfirm(BD_ADDR bd_addr, BOOLEAN accept) { tBTA_DM_API_CONFIRM *p_msg; if ((p_msg = (tBTA_DM_API_CONFIRM *) osi_malloc(sizeof(tBTA_DM_API_CONFIRM))) != NULL) { p_msg->hdr.event = BTA_DM_API_CONFIRM_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->accept = accept; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmPasskeyReqReply ** ** Description This function is called to provide the passkey for ** Simple Pairing in response to BTA_DM_SP_KEY_REQ_EVT ** ** Returns void ** *******************************************************************************/ #if (BT_SSP_INCLUDED == TRUE) void BTA_DmPasskeyReqReply(BOOLEAN accept, BD_ADDR bd_addr, UINT32 passkey) { tBTA_DM_API_KEY_REQ *p_msg; if ((p_msg = (tBTA_DM_API_KEY_REQ *) osi_malloc(sizeof(tBTA_DM_API_KEY_REQ))) != NULL) { p_msg->hdr.event = BTA_DM_API_KEY_REQ_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->accept = accept; p_msg->passkey = passkey; bta_sys_sendmsg(p_msg); } } #endif ///BT_SSP_INCLUDED == TRUE #endif ///SMP_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmAddDevice ** ** Description This function adds a device to the security database list of ** peer device ** ** ** Returns void ** *******************************************************************************/ void BTA_DmAddDevice(BD_ADDR bd_addr, DEV_CLASS dev_class, LINK_KEY link_key, tBTA_SERVICE_MASK trusted_mask, BOOLEAN is_trusted, UINT8 key_type, tBTA_IO_CAP io_cap, UINT8 pin_length, UINT8 sc_support) { tBTA_DM_API_ADD_DEVICE *p_msg; if ((p_msg = (tBTA_DM_API_ADD_DEVICE *) osi_malloc(sizeof(tBTA_DM_API_ADD_DEVICE))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_ADD_DEVICE)); p_msg->hdr.event = BTA_DM_API_ADD_DEVICE_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->tm = trusted_mask; p_msg->is_trusted = is_trusted; p_msg->io_cap = io_cap; p_msg->sc_support = sc_support; if (link_key) { p_msg->link_key_known = TRUE; p_msg->key_type = key_type; memcpy(p_msg->link_key, link_key, LINK_KEY_LEN); } /* Load device class if specified */ if (dev_class) { p_msg->dc_known = TRUE; memcpy (p_msg->dc, dev_class, DEV_CLASS_LEN); } memset (p_msg->bd_name, 0, BD_NAME_LEN + 1); memset (p_msg->features, 0, sizeof (p_msg->features)); p_msg->pin_length = pin_length; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmRemoveDevice ** ** Description This function removes a device fromthe security database list of ** peer device. It manages unpairing even while connected. ** ** ** Returns void ** *******************************************************************************/ tBTA_STATUS BTA_DmRemoveDevice(BD_ADDR bd_addr, tBT_TRANSPORT transport) { tBTA_DM_API_REMOVE_DEVICE *p_msg; if ((p_msg = (tBTA_DM_API_REMOVE_DEVICE *) osi_malloc(sizeof(tBTA_DM_API_REMOVE_DEVICE))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_REMOVE_DEVICE)); p_msg->hdr.event = BTA_DM_API_REMOVE_DEVICE_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->transport = transport; bta_sys_sendmsg(p_msg); } else { return BTA_FAILURE; } return BTA_SUCCESS; } // #endif ///SMP_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_GetEirService ** ** Description This function is called to get BTA service mask from EIR. ** ** Parameters p_eir - pointer of EIR significant part ** p_services - return the BTA service mask ** ** Returns None ** *******************************************************************************/ extern const UINT16 bta_service_id_to_uuid_lkup_tbl []; void BTA_GetEirService( UINT8 *p_eir, tBTA_SERVICE_MASK *p_services ) { UINT8 xx, yy; UINT8 num_uuid, max_num_uuid = 32; UINT8 uuid_list[32 * LEN_UUID_16]; UINT16 *p_uuid16 = (UINT16 *)uuid_list; tBTA_SERVICE_MASK mask; BTM_GetEirUuidList( p_eir, LEN_UUID_16, &num_uuid, uuid_list, max_num_uuid); for ( xx = 0; xx < num_uuid; xx++ ) { mask = 1; for ( yy = 0; yy < BTA_MAX_SERVICE_ID; yy++ ) { if ( *(p_uuid16 + xx) == bta_service_id_to_uuid_lkup_tbl[yy] ) { *p_services |= mask; break; } mask <<= 1; } /* for HSP v1.2 only device */ if (*(p_uuid16 + xx) == UUID_SERVCLASS_HEADSET_HS) { *p_services |= BTA_HSP_SERVICE_MASK; } if (*(p_uuid16 + xx) == UUID_SERVCLASS_HDP_SOURCE) { *p_services |= BTA_HL_SERVICE_MASK; } if (*(p_uuid16 + xx) == UUID_SERVCLASS_HDP_SINK) { *p_services |= BTA_HL_SERVICE_MASK; } } } /******************************************************************************* ** ** Function BTA_DmGetConnectionState ** ** Description Returns whether the remote device is currently connected. ** ** Returns 0 if the device is NOT connected. ** *******************************************************************************/ UINT16 BTA_DmGetConnectionState( BD_ADDR bd_addr ) { tBTA_DM_PEER_DEVICE *p_dev = bta_dm_find_peer_device(bd_addr); return (p_dev && p_dev->conn_state == BTA_DM_CONNECTED); } #if (SDP_INCLUDED == TRUE) /******************************************************************************* ** Device Identification (DI) Server Functions *******************************************************************************/ /******************************************************************************* ** ** Function BTA_DmSetLocalDiRecord ** ** Description This function adds a DI record to the local SDP database. ** ** Returns BTA_SUCCESS if record set successfully, otherwise error code. ** *******************************************************************************/ tBTA_STATUS BTA_DmSetLocalDiRecord( tBTA_DI_RECORD *p_device_info, UINT32 *p_handle ) { tBTA_STATUS status = BTA_FAILURE; if (bta_dm_di_cb.di_num < BTA_DI_NUM_MAX) { if (SDP_SetLocalDiRecord((tSDP_DI_RECORD *)p_device_info, p_handle) == SDP_SUCCESS) { if (!p_device_info->primary_record) { bta_dm_di_cb.di_handle[bta_dm_di_cb.di_num] = *p_handle; bta_dm_di_cb.di_num ++; } bta_sys_add_uuid(UUID_SERVCLASS_PNP_INFORMATION); status = BTA_SUCCESS; } } return status; } #endif ///SDP_INCLUDED == TRUE /******************************************************************************* ** ** Function bta_dmexecutecallback ** ** Description This function will request BTA to execute a call back in the context of BTU task ** This API was named in lower case because it is only intended ** for the internal customers(like BTIF). ** ** Returns void ** *******************************************************************************/ void bta_dmexecutecallback (tBTA_DM_EXEC_CBACK *p_callback, void *p_param) { tBTA_DM_API_EXECUTE_CBACK *p_msg; if ((p_msg = (tBTA_DM_API_EXECUTE_CBACK *) osi_malloc(sizeof(tBTA_DM_API_EXECUTE_CBACK))) != NULL) { p_msg->hdr.event = BTA_DM_API_EXECUTE_CBACK_EVT; p_msg->p_param = p_param; p_msg->p_exec_cback = p_callback; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmAddBleKey ** ** Description Add/modify LE device information. This function will be ** normally called during host startup to restore all required ** information stored in the NVRAM. ** ** Parameters: bd_addr - BD address of the peer ** p_le_key - LE key values. ** key_type - LE SMP key type. ** ** Returns BTA_SUCCESS if successful ** BTA_FAIL if operation failed. ** *******************************************************************************/ #if BLE_INCLUDED == TRUE #if SMP_INCLUDED == TRUE void BTA_DmAddBleKey (BD_ADDR bd_addr, tBTA_LE_KEY_VALUE *p_le_key, tBTA_LE_KEY_TYPE key_type) { tBTA_DM_API_ADD_BLEKEY *p_msg; if ((p_msg = (tBTA_DM_API_ADD_BLEKEY *) osi_malloc(sizeof(tBTA_DM_API_ADD_BLEKEY))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_ADD_BLEKEY)); p_msg->hdr.event = BTA_DM_API_ADD_BLEKEY_EVT; p_msg->key_type = key_type; bdcpy(p_msg->bd_addr, bd_addr); memcpy(&p_msg->blekey, p_le_key, sizeof(tBTA_LE_KEY_VALUE)); bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmAddBleDevice ** ** Description Add a BLE device. This function will be normally called ** during host startup to restore all required information ** for a LE device stored in the NVRAM. ** ** Parameters: bd_addr - BD address of the peer ** dev_type - Remote device's device type. ** auth_mode - auth mode ** addr_type - LE device address type. ** ** Returns void ** *******************************************************************************/ void BTA_DmAddBleDevice(BD_ADDR bd_addr, tBLE_ADDR_TYPE addr_type, int auth_mode, tBT_DEVICE_TYPE dev_type) { tBTA_DM_API_ADD_BLE_DEVICE *p_msg; if ((p_msg = (tBTA_DM_API_ADD_BLE_DEVICE *) osi_malloc(sizeof(tBTA_DM_API_ADD_BLE_DEVICE))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_ADD_BLE_DEVICE)); p_msg->hdr.event = BTA_DM_API_ADD_BLEDEVICE_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->addr_type = addr_type; p_msg->auth_mode = auth_mode; p_msg->dev_type = dev_type; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBlePasskeyReply ** ** Description Send BLE SMP passkey reply. ** ** Parameters: bd_addr - BD address of the peer ** accept - passkey entry sucessful or declined. ** passkey - passkey value, must be a 6 digit number, ** can be lead by 0. ** ** Returns void ** *******************************************************************************/ void BTA_DmBlePasskeyReply(BD_ADDR bd_addr, BOOLEAN accept, UINT32 passkey) { tBTA_DM_API_PASSKEY_REPLY *p_msg; if ((p_msg = (tBTA_DM_API_PASSKEY_REPLY *) osi_malloc(sizeof(tBTA_DM_API_PASSKEY_REPLY))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_PASSKEY_REPLY)); p_msg->hdr.event = BTA_DM_API_BLE_PASSKEY_REPLY_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->accept = accept; if (accept) { p_msg->passkey = passkey; } bta_sys_sendmsg(p_msg); } } void BTA_DmBleSetStaticPasskey(bool add, uint32_t passkey) { tBTA_DM_API_SET_DEFAULT_PASSKEY *p_msg; if ((p_msg = (tBTA_DM_API_SET_DEFAULT_PASSKEY *) osi_malloc(sizeof(tBTA_DM_API_SET_DEFAULT_PASSKEY))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_SET_DEFAULT_PASSKEY)); p_msg->hdr.event = BTA_DM_API_BLE_SET_STATIC_PASSKEY_EVT; p_msg->add = add; p_msg->static_passkey = passkey; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleConfirmReply ** ** Description Send BLE SMP SC user confirmation reply. ** ** Parameters: bd_addr - BD address of the peer ** accept - numbers to compare are the same or different. ** ** Returns void ** *******************************************************************************/ void BTA_DmBleConfirmReply(BD_ADDR bd_addr, BOOLEAN accept) { tBTA_DM_API_CONFIRM *p_msg = (tBTA_DM_API_CONFIRM *)osi_malloc(sizeof(tBTA_DM_API_CONFIRM)); if (p_msg != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_CONFIRM)); p_msg->hdr.event = BTA_DM_API_BLE_CONFIRM_REPLY_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->accept = accept; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleSecurityGrant ** ** Description Grant security request access. ** ** Parameters: bd_addr - BD address of the peer ** res - security grant status. ** ** Returns void ** *******************************************************************************/ void BTA_DmBleSecurityGrant(BD_ADDR bd_addr, tBTA_DM_BLE_SEC_GRANT res) { tBTA_DM_API_BLE_SEC_GRANT *p_msg; if ((p_msg = (tBTA_DM_API_BLE_SEC_GRANT *) osi_malloc(sizeof(tBTA_DM_API_BLE_SEC_GRANT))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_SEC_GRANT)); p_msg->hdr.event = BTA_DM_API_BLE_SEC_GRANT_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->res = res; bta_sys_sendmsg(p_msg); } } #endif ///SMP_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmSetBlePrefConnParams ** ** Description This function is called to set the preferred connection ** parameters when default connection parameter is not desired. ** ** Parameters: bd_addr - BD address of the peripheral ** scan_interval - scan interval ** scan_window - scan window ** min_conn_int - minimum preferred connection interval ** max_conn_int - maximum preferred connection interval ** slave_latency - preferred slave latency ** supervision_tout - preferred supervision timeout ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSetBlePrefConnParams(BD_ADDR bd_addr, UINT16 min_conn_int, UINT16 max_conn_int, UINT16 slave_latency, UINT16 supervision_tout ) { #if BLE_INCLUDED == TRUE tBTA_DM_API_BLE_CONN_PARAMS *p_msg; if ((p_msg = (tBTA_DM_API_BLE_CONN_PARAMS *) osi_malloc(sizeof(tBTA_DM_API_BLE_CONN_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_CONN_PARAMS)); p_msg->hdr.event = BTA_DM_API_BLE_CONN_PARAM_EVT; memcpy(p_msg->peer_bda, bd_addr, BD_ADDR_LEN); p_msg->conn_int_max = max_conn_int; p_msg->conn_int_min = min_conn_int; p_msg->slave_latency = slave_latency; p_msg->supervision_tout = supervision_tout; bta_sys_sendmsg(p_msg); } #endif } /******************************************************************************* ** ** Function BTA_DmSetBleConnScanParams ** ** Description This function is called to set scan parameters used in ** BLE connection request ** ** Parameters: scan_interval - scan interval ** scan_window - scan window ** ** Returns void ** *******************************************************************************/ void BTA_DmSetBleConnScanParams(UINT32 scan_interval, UINT32 scan_window) { tBTA_DM_API_BLE_SCAN_PARAMS *p_msg; if ((p_msg = (tBTA_DM_API_BLE_SCAN_PARAMS *)osi_malloc(sizeof(tBTA_DM_API_BLE_SCAN_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_SCAN_PARAMS)); p_msg->hdr.event = BTA_DM_API_BLE_CONN_SCAN_PARAM_EVT; p_msg->scan_int = scan_interval; p_msg->scan_window = scan_window; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSetBleScanParams ** ** Description This function is called to set scan parameters ** ** Parameters: client_if - Client IF ** scan_interval - scan interval ** scan_window - scan window ** scan_mode - scan mode ** scan_param_setup_status_cback - Set scan param status callback ** ** Returns void ** *******************************************************************************/ void BTA_DmSetBleScanParams(tGATT_IF client_if, UINT32 scan_interval, UINT32 scan_window, tBLE_SCAN_MODE scan_mode, tBLE_SCAN_PARAM_SETUP_CBACK scan_param_setup_cback) { tBTA_DM_API_BLE_SCAN_PARAMS *p_msg; if ((p_msg = (tBTA_DM_API_BLE_SCAN_PARAMS *)osi_malloc(sizeof(tBTA_DM_API_BLE_SCAN_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_SCAN_PARAMS)); p_msg->hdr.event = BTA_DM_API_BLE_SCAN_PARAM_EVT; p_msg->client_if = client_if; p_msg->scan_int = scan_interval; p_msg->scan_window = scan_window; p_msg->scan_mode = scan_mode; p_msg->scan_param_setup_cback = scan_param_setup_cback; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSetBleScanFilterParams ** ** Description This function is called to set scan parameters ** ** Parameters: client_if - Client IF ** scan_interval - scan interval ** scan_window - scan window ** scan_mode - scan mode ** scan_duplicate_filter - scan duplicate filter ** scan_param_setup_status_cback - Set scan param status callback ** ** Returns void ** *******************************************************************************/ void BTA_DmSetBleScanFilterParams(tGATT_IF client_if, UINT32 scan_interval, UINT32 scan_window, tBLE_SCAN_MODE scan_mode, UINT8 scan_fil_poilcy, UINT8 addr_type_own, UINT8 scan_duplicate_filter, tBLE_SCAN_PARAM_SETUP_CBACK scan_param_setup_cback) { tBTA_DM_API_BLE_SCAN_FILTER_PARAMS *p_msg; if ((p_msg = (tBTA_DM_API_BLE_SCAN_FILTER_PARAMS *)osi_malloc(sizeof(tBTA_DM_API_BLE_SCAN_FILTER_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_SCAN_FILTER_PARAMS)); p_msg->hdr.event = BTA_DM_API_BLE_SCAN_FIL_PARAM_EVT; p_msg->client_if = client_if; p_msg->scan_int = scan_interval; p_msg->scan_window = scan_window; p_msg->scan_mode = scan_mode; p_msg->addr_type_own = addr_type_own; p_msg->scan_duplicate_filter = scan_duplicate_filter; p_msg->scan_filter_policy = scan_fil_poilcy; p_msg->scan_param_setup_cback = scan_param_setup_cback; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSetBleAdvParams ** ** Description This function sets the advertising parameters BLE functionality. ** It is to be called when device act in peripheral or broadcaster ** role. ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSetBleAdvParams (UINT16 adv_int_min, UINT16 adv_int_max, tBLE_BD_ADDR *p_dir_bda) { #if BLE_INCLUDED == TRUE tBTA_DM_API_BLE_ADV_PARAMS *p_msg; APPL_TRACE_API ("BTA_DmSetBleAdvParam: %d, %d\n", adv_int_min, adv_int_max); if ((p_msg = (tBTA_DM_API_BLE_ADV_PARAMS *) osi_malloc(sizeof(tBTA_DM_API_BLE_ADV_PARAMS) + sizeof(tBLE_BD_ADDR))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_ADV_PARAMS) + sizeof(tBLE_BD_ADDR)); p_msg->hdr.event = BTA_DM_API_BLE_ADV_PARAM_EVT; p_msg->adv_int_min = adv_int_min; p_msg->adv_int_max = adv_int_max; if (p_dir_bda != NULL) { p_msg->p_dir_bda = (tBLE_BD_ADDR *)(p_msg + 1); memcpy(p_msg->p_dir_bda, p_dir_bda, sizeof(tBLE_BD_ADDR)); } bta_sys_sendmsg(p_msg); } #endif } void BTA_DmSetBleAdvParamsAll (UINT16 adv_int_min, UINT16 adv_int_max, UINT8 adv_type, tBLE_ADDR_TYPE addr_type_own, tBTM_BLE_ADV_CHNL_MAP chnl_map, tBTM_BLE_AFP adv_fil_pol, tBLE_BD_ADDR *p_dir_bda, tBTA_START_ADV_CMPL_CBACK p_start_adv_cb) { #if BLE_INCLUDED == TRUE tBTA_DM_API_BLE_ADV_PARAMS_ALL *p_msg; APPL_TRACE_API ("BTA_DmSetBleAdvParamsAll: %d, %d\n", adv_int_min, adv_int_max); APPL_TRACE_API ("adv_type = %d, addr_type_own = %d, chnl_map = %d, adv_fil_pol = %d\n", adv_type, addr_type_own, chnl_map, adv_fil_pol); if ((p_msg = (tBTA_DM_API_BLE_ADV_PARAMS_ALL *) osi_malloc(sizeof(tBTA_DM_API_BLE_ADV_PARAMS_ALL) + sizeof(tBLE_BD_ADDR))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_ADV_PARAMS_ALL)); p_msg->hdr.event = BTA_DM_API_BLE_ADV_PARAM_All_EVT; p_msg->adv_int_min = adv_int_min; p_msg->adv_int_max = adv_int_max; p_msg->adv_type = adv_type; p_msg->addr_type_own = addr_type_own; p_msg->channel_map = chnl_map; p_msg->adv_filter_policy = adv_fil_pol; p_msg->p_start_adv_cback = p_start_adv_cb; if (p_dir_bda != NULL) { p_msg->p_dir_bda = (tBLE_BD_ADDR *)(p_msg + 1); memcpy(p_msg->p_dir_bda, p_dir_bda, sizeof(tBLE_BD_ADDR)); } bta_sys_sendmsg(p_msg); } #endif } #endif ///BLE_INCLUDED == TRUE /******************************************************************************* ** BLE ADV data management API ********************************************************************************/ #if BLE_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmBleSetAdvConfig ** ** Description This function is called to override the BTA default ADV parameters. ** ** Parameters data_mask: adv data mask. ** p_adv_cfg: Pointer to User defined ADV data structure. This ** memory space can not be freed until p_adv_data_cback ** is received. ** p_adv_data_cback: set adv data complete callback. ** ** Returns None ** *******************************************************************************/ void BTA_DmBleSetAdvConfig (tBTA_BLE_AD_MASK data_mask, tBTA_BLE_ADV_DATA *p_adv_cfg, tBTA_SET_ADV_DATA_CMPL_CBACK *p_adv_data_cback) { tBTA_DM_API_SET_ADV_CONFIG *p_msg; if ((p_msg = (tBTA_DM_API_SET_ADV_CONFIG *) osi_malloc(sizeof(tBTA_DM_API_SET_ADV_CONFIG))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_SET_ADV_CONFIG_EVT; p_msg->data_mask = data_mask; p_msg->p_adv_data_cback = p_adv_data_cback; p_msg->p_adv_cfg = p_adv_cfg; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleSetAdvConfigRaw ** ** Description This function is called to set raw Advertising data ** ** Parameters p_raw_adv : raw advertising data. ** raw_adv_len : raw advertising data length. ** p_adv_data_cback : set adv data complete callback. ** ** Returns None ** *******************************************************************************/ void BTA_DmBleSetAdvConfigRaw (UINT8 *p_raw_adv, UINT32 raw_adv_len, tBTA_SET_ADV_DATA_CMPL_CBACK *p_adv_data_cback) { tBTA_DM_API_SET_ADV_CONFIG_RAW *p_msg; if ((p_msg = (tBTA_DM_API_SET_ADV_CONFIG_RAW *) osi_malloc(sizeof(tBTA_DM_API_SET_ADV_CONFIG_RAW) + raw_adv_len)) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_SET_ADV_CONFIG_RAW_EVT; p_msg->p_adv_data_cback = p_adv_data_cback; p_msg->p_raw_adv = (UINT8 *)(p_msg + 1); memcpy(p_msg->p_raw_adv, p_raw_adv, raw_adv_len); p_msg->raw_adv_len = raw_adv_len; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleSetLongAdv ** ** Description This function is called to set long Advertising data ** ** Parameters adv_data : long advertising data. ** adv_data_len : long advertising data length. ** p_adv_data_cback : set long adv data complete callback. ** ** Returns None ** *******************************************************************************/ void BTA_DmBleSetLongAdv (UINT8 *adv_data, UINT32 adv_data_len, tBTA_SET_ADV_DATA_CMPL_CBACK *p_adv_data_cback) { tBTA_DM_API_SET_LONG_ADV *p_msg; if ((p_msg = (tBTA_DM_API_SET_LONG_ADV *) osi_malloc(sizeof(tBTA_DM_API_SET_LONG_ADV))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_SET_LONG_ADV_EVT; p_msg->p_adv_data_cback = p_adv_data_cback; p_msg->adv_data = adv_data; p_msg->adv_data_len = adv_data_len; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleSetScanRsp ** ** Description This function is called to override the BTA scan response. ** ** Parameters Pointer to User defined ADV data structure ** ** Returns None ** *******************************************************************************/ extern void BTA_DmBleSetScanRsp (tBTA_BLE_AD_MASK data_mask, tBTA_BLE_ADV_DATA *p_adv_cfg, tBTA_SET_ADV_DATA_CMPL_CBACK *p_adv_data_cback) { tBTA_DM_API_SET_ADV_CONFIG *p_msg; if ((p_msg = (tBTA_DM_API_SET_ADV_CONFIG *) osi_malloc(sizeof(tBTA_DM_API_SET_ADV_CONFIG))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_SET_SCAN_RSP_EVT; p_msg->data_mask = data_mask; p_msg->p_adv_data_cback = p_adv_data_cback; p_msg->p_adv_cfg = p_adv_cfg; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleSetScanRspRaw ** ** Description This function is called to set raw scan response data ** ** Parameters p_raw_scan_rsp : raw scan_rspertising data. ** raw_scan_rsp_len : raw scan_rspertising data length. ** p_scan_rsp_data_cback : set scan_rsp data complete callback. ** ** Returns None ** *******************************************************************************/ void BTA_DmBleSetScanRspRaw (UINT8 *p_raw_scan_rsp, UINT32 raw_scan_rsp_len, tBTA_SET_ADV_DATA_CMPL_CBACK *p_scan_rsp_data_cback) { tBTA_DM_API_SET_ADV_CONFIG_RAW *p_msg; if ((p_msg = (tBTA_DM_API_SET_ADV_CONFIG_RAW *) osi_malloc(sizeof(tBTA_DM_API_SET_ADV_CONFIG_RAW) + raw_scan_rsp_len)) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_SET_SCAN_RSP_RAW_EVT; p_msg->p_adv_data_cback = p_scan_rsp_data_cback; p_msg->p_raw_adv = (UINT8 *)(p_msg + 1); memcpy(p_msg->p_raw_adv, p_raw_scan_rsp, raw_scan_rsp_len); p_msg->raw_adv_len = raw_scan_rsp_len; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmUpdateDuplicateExceptionalList ** ** Description This function is called to update duplicate scan exceptional list ** ** Parameters subcode : add, remove or clean duplicate scan exceptional list. ** type : device info type. ** device_info: device info ** p_update_duplicate_ignore_list_cback : update complete callback. ** ** Returns None ** *******************************************************************************/ void BTA_DmUpdateDuplicateExceptionalList(UINT8 subcode, UINT32 type, BD_ADDR device_info, tBTA_UPDATE_DUPLICATE_EXCEPTIONAL_LIST_CMPL_CBACK p_update_duplicate_exceptional_list_cback) { tBTA_DM_API_UPDATE_DUPLICATE_EXCEPTIONAL_LIST *p_msg; if ((p_msg = (tBTA_DM_API_UPDATE_DUPLICATE_EXCEPTIONAL_LIST *)osi_malloc(sizeof(tBTA_DM_API_UPDATE_DUPLICATE_EXCEPTIONAL_LIST))) != NULL) { p_msg->hdr.event = BTA_DM_API_UPDATE_DUPLICATE_EXCEPTIONAL_LIST_EVT; p_msg->subcode = subcode; p_msg->type = type; p_msg->exceptional_list_cb = p_update_duplicate_exceptional_list_cback; memcpy(p_msg->device_info, device_info, sizeof(BD_ADDR)); bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleSetStorageParams ** ** Description This function is called to override the BTA scan response. ** ** Parameters batch_scan_full_max -Max storage space (in %) allocated to full scanning ** batch_scan_trunc_max -Max storage space (in %) allocated to truncated scanning ** batch_scan_notify_threshold -Setup notification level based on total space ** p_setup_cback - Setup callback pointer ** p_thres_cback - Threshold callback pointer ** p_rep_cback - Reports callback pointer ** ref_value - Ref value ** ** Returns None ** *******************************************************************************/ extern void BTA_DmBleSetStorageParams(UINT8 batch_scan_full_max, UINT8 batch_scan_trunc_max, UINT8 batch_scan_notify_threshold, tBTA_BLE_SCAN_SETUP_CBACK *p_setup_cback, tBTA_BLE_SCAN_THRESHOLD_CBACK *p_thres_cback, tBTA_BLE_SCAN_REP_CBACK *p_rep_cback, tBTA_DM_BLE_REF_VALUE ref_value) { tBTA_DM_API_SET_STORAGE_CONFIG *p_msg; bta_dm_cb.p_setup_cback = p_setup_cback; if ((p_msg = (tBTA_DM_API_SET_STORAGE_CONFIG *) osi_malloc(sizeof(tBTA_DM_API_SET_STORAGE_CONFIG))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_SETUP_STORAGE_EVT; p_msg->p_setup_cback = bta_ble_scan_setup_cb; p_msg->p_thres_cback = p_thres_cback; p_msg->p_read_rep_cback = p_rep_cback; p_msg->ref_value = ref_value; p_msg->batch_scan_full_max = batch_scan_full_max; p_msg->batch_scan_trunc_max = batch_scan_trunc_max; p_msg->batch_scan_notify_threshold = batch_scan_notify_threshold; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleEnableBatchScan ** ** Description This function is called to enable the batch scan ** ** Parameters scan_mode -Batch scan mode ** scan_interval - Scan interval ** scan_window - Scan window ** discard_rule -Discard rules ** addr_type - Address type ** ref_value - Reference value ** ** Returns None ** *******************************************************************************/ extern void BTA_DmBleEnableBatchScan(tBTA_BLE_BATCH_SCAN_MODE scan_mode, UINT32 scan_interval, UINT32 scan_window, tBTA_BLE_DISCARD_RULE discard_rule, tBLE_ADDR_TYPE addr_type, tBTA_DM_BLE_REF_VALUE ref_value) { tBTA_DM_API_ENABLE_SCAN *p_msg; if ((p_msg = (tBTA_DM_API_ENABLE_SCAN *) osi_malloc(sizeof(tBTA_DM_API_ENABLE_SCAN))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_ENABLE_BATCH_SCAN_EVT; p_msg->scan_mode = scan_mode; p_msg->scan_int = scan_interval; p_msg->scan_window = scan_window; p_msg->discard_rule = discard_rule; p_msg->addr_type = addr_type; p_msg->ref_value = ref_value; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleDisableBatchScan ** ** Description This function is called to disable the batch scan ** ** Parameters ref_value - Reference value ** ** Returns None ** *******************************************************************************/ extern void BTA_DmBleDisableBatchScan(tBTA_DM_BLE_REF_VALUE ref_value) { tBTA_DM_API_DISABLE_SCAN *p_msg; if ((p_msg = (tBTA_DM_API_DISABLE_SCAN *) osi_malloc(sizeof(tBTA_DM_API_DISABLE_SCAN))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_DISABLE_BATCH_SCAN_EVT; p_msg->ref_value = ref_value; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleReadScanReports ** ** Description This function is called to read scan reports ** ** Parameters scan_type -Batch scan mode ** ref_value - Reference value ** ** Returns None ** *******************************************************************************/ extern void BTA_DmBleReadScanReports(tBTA_BLE_BATCH_SCAN_MODE scan_type, tBTA_DM_BLE_REF_VALUE ref_value) { tBTA_DM_API_READ_SCAN_REPORTS *p_msg; if ((p_msg = (tBTA_DM_API_READ_SCAN_REPORTS *) osi_malloc(sizeof(tBTA_DM_API_READ_SCAN_REPORTS))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_READ_SCAN_REPORTS_EVT; p_msg->scan_type = scan_type; p_msg->ref_value = ref_value; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleTrackAdvertiser ** ** Description This function is called to track advertiser ** ** Parameters ref_value - Reference value ** p_track_adv_cback - Track ADV callback ** ** Returns None ** *******************************************************************************/ extern void BTA_DmBleTrackAdvertiser(tBTA_DM_BLE_REF_VALUE ref_value, tBTA_BLE_TRACK_ADV_CBACK *p_track_adv_cback) { tBTA_DM_API_TRACK_ADVERTISER *p_msg; if ((p_msg = (tBTA_DM_API_TRACK_ADVERTISER *) osi_malloc(sizeof(tBTA_DM_API_TRACK_ADVERTISER))) != NULL) { p_msg->hdr.event = BTA_DM_API_BLE_TRACK_ADVERTISER_EVT; p_msg->p_track_adv_cback = p_track_adv_cback; p_msg->ref_value = ref_value; bta_sys_sendmsg(p_msg); } } #endif /******************************************************************************* ** BLE ADV data management API ********************************************************************************/ #if BLE_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmBleBroadcast ** ** Description This function starts or stops LE broadcasting. ** ** Parameters start: start or stop broadcast. ** ** Returns None ** *******************************************************************************/ extern void BTA_DmBleBroadcast (BOOLEAN start, tBTA_START_STOP_ADV_CMPL_CBACK *p_start_stop_adv_cb) { tBTA_DM_API_BLE_OBSERVE *p_msg; APPL_TRACE_API("BTA_DmBleBroadcast: start = %d \n", start); if ((p_msg = (tBTA_DM_API_BLE_OBSERVE *) osi_malloc(sizeof(tBTA_DM_API_BLE_OBSERVE))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_OBSERVE)); p_msg->hdr.event = BTA_DM_API_BLE_BROADCAST_EVT; p_msg->start = start; if (start == FALSE){ p_msg->p_stop_adv_cback= p_start_stop_adv_cb; } bta_sys_sendmsg(p_msg); } } #endif /******************************************************************************* ** ** Function BTA_DmBleSetBgConnType ** ** Description This function is called to set BLE connectable mode for a ** peripheral device. ** ** Parameters bg_conn_type: it can be auto connection, or selective connection. ** p_select_cback: callback function when selective connection procedure ** is being used. ** ** Returns void ** *******************************************************************************/ void BTA_DmBleSetBgConnType(tBTA_DM_BLE_CONN_TYPE bg_conn_type, tBTA_DM_BLE_SEL_CBACK *p_select_cback) { #if BLE_INCLUDED == TRUE tBTA_DM_API_BLE_SET_BG_CONN_TYPE *p_msg; if ((p_msg = (tBTA_DM_API_BLE_SET_BG_CONN_TYPE *) osi_malloc(sizeof(tBTA_DM_API_BLE_SET_BG_CONN_TYPE))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_SET_BG_CONN_TYPE)); p_msg->hdr.event = BTA_DM_API_BLE_SET_BG_CONN_TYPE; p_msg->bg_conn_type = bg_conn_type; p_msg->p_select_cback = p_select_cback; bta_sys_sendmsg(p_msg); } #endif } /******************************************************************************* ** ** Function bta_dm_discover_send_msg ** ** Description This function send discover message to BTA task. ** ** Returns void ** *******************************************************************************/ #if BLE_INCLUDED == TRUE && BTA_GATT_INCLUDED == TRUE && SDP_INCLUDED == TRUE static void bta_dm_discover_send_msg(BD_ADDR bd_addr, tBTA_SERVICE_MASK_EXT *p_services, tBTA_DM_SEARCH_CBACK *p_cback, BOOLEAN sdp_search, tBTA_TRANSPORT transport) { tBTA_DM_API_DISCOVER *p_msg; UINT16 len = p_services ? (sizeof(tBTA_DM_API_DISCOVER) + sizeof(tBT_UUID) * p_services->num_uuid) : sizeof(tBTA_DM_API_DISCOVER); if ((p_msg = (tBTA_DM_API_DISCOVER *) osi_malloc(len)) != NULL) { memset(p_msg, 0, len); p_msg->hdr.event = BTA_DM_API_DISCOVER_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->p_cback = p_cback; p_msg->sdp_search = sdp_search; p_msg->transport = transport; if (p_services != NULL) { #if BLE_INCLUDED == TRUE && BTA_GATT_INCLUDED == TRUE p_msg->services = p_services->srvc_mask; p_msg->num_uuid = p_services->num_uuid; if (p_services->num_uuid != 0) { p_msg->p_uuid = (tBT_UUID *)(p_msg + 1); memcpy(p_msg->p_uuid, p_services->p_uuid, sizeof(tBT_UUID) * p_services->num_uuid); } #endif } bta_sys_sendmsg(p_msg); } } #endif /******************************************************************************* ** ** Function BTA_DmDiscoverByTransport ** ** Description This function does service discovery on particular transport ** for services of a ** peer device. When services.num_uuid is 0, it indicates all ** GATT based services are to be searched; otherwise a list of ** UUID of interested services should be provided through ** p_services->p_uuid. ** ** ** ** Returns void ** *******************************************************************************/ void BTA_DmDiscoverByTransport(BD_ADDR bd_addr, tBTA_SERVICE_MASK_EXT *p_services, tBTA_DM_SEARCH_CBACK *p_cback, BOOLEAN sdp_search, tBTA_TRANSPORT transport) { #if BLE_INCLUDED == TRUE && BTA_GATT_INCLUDED == TRUE && SDP_INCLUDED == TRUE bta_dm_discover_send_msg(bd_addr, p_services, p_cback, sdp_search, transport); #endif } /******************************************************************************* ** ** Function BTA_DmDiscoverExt ** ** Description This function does service discovery for services of a ** peer device. When services.num_uuid is 0, it indicates all ** GATT based services are to be searched; other wise a list of ** UUID of interested services should be provided through ** p_services->p_uuid. ** ** ** ** Returns void ** *******************************************************************************/ void BTA_DmDiscoverExt(BD_ADDR bd_addr, tBTA_SERVICE_MASK_EXT *p_services, tBTA_DM_SEARCH_CBACK *p_cback, BOOLEAN sdp_search) { #if BLE_INCLUDED == TRUE && BTA_GATT_INCLUDED == TRUE && SDP_INCLUDED == TRUE bta_dm_discover_send_msg(bd_addr, p_services, p_cback, sdp_search, BTA_TRANSPORT_UNKNOWN); #endif } /******************************************************************************* ** ** Function BTA_DmSearchExt ** ** Description This function searches for peer Bluetooth devices. It performs ** an inquiry and gets the remote name for devices. Service ** discovery is done if services is non zero ** ** Parameters p_dm_inq: inquiry conditions ** p_services: if service is not empty, service discovery will be done. ** for all GATT based service condition, put num_uuid, and ** p_uuid is the pointer to the list of UUID values. ** p_cback: callback functino when search is completed. ** ** ** ** Returns void ** *******************************************************************************/ void BTA_DmSearchExt(tBTA_DM_INQ *p_dm_inq, tBTA_SERVICE_MASK_EXT *p_services, tBTA_DM_SEARCH_CBACK *p_cback) { #if BLE_INCLUDED == TRUE && BTA_GATT_INCLUDED == TRUE tBTA_DM_API_SEARCH *p_msg; UINT16 len = p_services ? (sizeof(tBTA_DM_API_SEARCH) + sizeof(tBT_UUID) * p_services->num_uuid) : sizeof(tBTA_DM_API_SEARCH); if ((p_msg = (tBTA_DM_API_SEARCH *) osi_malloc(len)) != NULL) { memset(p_msg, 0, len); p_msg->hdr.event = BTA_DM_API_SEARCH_EVT; memcpy(&p_msg->inq_params, p_dm_inq, sizeof(tBTA_DM_INQ)); p_msg->p_cback = p_cback; p_msg->rs_res = BTA_DM_RS_NONE; if (p_services != NULL) { p_msg->services = p_services->srvc_mask; p_msg->num_uuid = p_services->num_uuid; if (p_services->num_uuid != 0) { p_msg->p_uuid = (tBT_UUID *)(p_msg + 1); memcpy(p_msg->p_uuid, p_services->p_uuid, sizeof(tBT_UUID) * p_services->num_uuid); } else { p_msg->p_uuid = NULL; } } bta_sys_sendmsg(p_msg); } #else UNUSED(p_dm_inq); UNUSED(p_services); UNUSED(p_cback); #endif } /******************************************************************************* ** ** Function BTA_DmBleUpdateConnectionParam ** ** Description Update connection parameters, can only be used when connection is up. ** ** Parameters: bd_addr - BD address of the peer ** min_int - minimum connection interval, [0x0004~ 0x4000] ** max_int - maximum connection interval, [0x0004~ 0x4000] ** latency - slave latency [0 ~ 500] ** timeout - supervision timeout [0x000a ~ 0xc80] ** ** Returns void ** *******************************************************************************/ void BTA_DmBleUpdateConnectionParam(BD_ADDR bd_addr, UINT16 min_int, UINT16 max_int, UINT16 latency, UINT16 timeout) { #if BLE_INCLUDED == TRUE tBTA_DM_API_UPDATE_CONN_PARAM *p_msg; p_msg = (tBTA_DM_API_UPDATE_CONN_PARAM *) osi_malloc(sizeof(tBTA_DM_API_UPDATE_CONN_PARAM)); if (p_msg != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_UPDATE_CONN_PARAM)); p_msg->hdr.event = BTA_DM_API_UPDATE_CONN_PARAM_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->min_int = min_int; p_msg->max_int = max_int; p_msg->latency = latency; p_msg->timeout = timeout; bta_sys_sendmsg(p_msg); } #endif } #if BLE_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmBleConfigLocalPrivacy ** ** Description Enable/disable privacy on the local device ** ** Parameters: privacy_enable - enable/disabe privacy on remote device. ** ** Returns void ** *******************************************************************************/ void BTA_DmBleConfigLocalPrivacy(BOOLEAN privacy_enable, tBTA_SET_LOCAL_PRIVACY_CBACK *set_local_privacy_cback) { ///This function used the irk to generate the resolve address #if BLE_INCLUDED == TRUE && BLE_PRIVACY_SPT == TRUE tBTA_DM_API_LOCAL_PRIVACY *p_msg; if ((p_msg = (tBTA_DM_API_LOCAL_PRIVACY *) osi_malloc(sizeof(tBTA_DM_API_ENABLE_PRIVACY))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_LOCAL_PRIVACY)); p_msg->hdr.event = BTA_DM_API_LOCAL_PRIVACY_EVT; p_msg->privacy_enable = privacy_enable; p_msg->set_local_privacy_cback = set_local_privacy_cback; bta_sys_sendmsg(p_msg); } #else UNUSED (privacy_enable); #endif } /******************************************************************************* ** ** Function BTA_DmBleConfigLocalIcon ** ** Description set gap local icon ** ** Parameters: icon - appearance value. ** ** Returns void ** *******************************************************************************/ void BTA_DmBleConfigLocalIcon(uint16_t icon) { tBTA_DM_API_LOCAL_ICON *p_msg; if ((p_msg = (tBTA_DM_API_LOCAL_ICON *) osi_malloc(sizeof(tBTA_DM_API_LOCAL_ICON))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_LOCAL_ICON)); p_msg->hdr.event = BTA_DM_API_LOCAL_ICON_EVT; p_msg->icon = icon; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_BleEnableAdvInstance ** ** Description This function enable a Multi-ADV instance with the specififed ** adv parameters ** ** Parameters p_params: pointer to the adv parameter structure. ** p_cback: callback function associated to this adv instance. ** p_ref: reference data pointer to this adv instance. ** ** Returns BTA_SUCCESS if command started successfully; otherwise failure. ** *******************************************************************************/ void BTA_BleEnableAdvInstance (tBTA_BLE_ADV_PARAMS *p_params, tBTA_BLE_MULTI_ADV_CBACK *p_cback, void *p_ref) { ///This function just used for vendor debug tBTA_DM_API_BLE_MULTI_ADV_ENB *p_msg; UINT16 len = sizeof(tBTA_BLE_ADV_PARAMS) + sizeof(tBTA_DM_API_BLE_MULTI_ADV_ENB); APPL_TRACE_API ("BTA_BleEnableAdvInstance"); if ((p_msg = (tBTA_DM_API_BLE_MULTI_ADV_ENB *) osi_malloc(len)) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_MULTI_ADV_ENB)); p_msg->hdr.event = BTA_DM_API_BLE_MULTI_ADV_ENB_EVT; p_msg->p_cback = (void *)p_cback; if (p_params != NULL) { p_msg->p_params = (void *)(p_msg + 1); memcpy(p_msg->p_params, p_params, sizeof(tBTA_BLE_ADV_PARAMS)); } p_msg->p_ref = p_ref; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_BleUpdateAdvInstParam ** ** Description This function update a Multi-ADV instance with the specififed ** adv parameters. ** ** Parameters inst_id: Adv instance to update the parameter. ** p_params: pointer to the adv parameter structure. ** ** Returns BTA_SUCCESS if command started successfully; otherwise failure. ** *******************************************************************************/ void BTA_BleUpdateAdvInstParam (UINT8 inst_id, tBTA_BLE_ADV_PARAMS *p_params) { ///This function just used for vendor debug tBTA_DM_API_BLE_MULTI_ADV_PARAM *p_msg; UINT16 len = sizeof(tBTA_BLE_ADV_PARAMS) + sizeof(tBTA_DM_API_BLE_MULTI_ADV_PARAM); APPL_TRACE_API ("BTA_BleUpdateAdvInstParam"); if ((p_msg = (tBTA_DM_API_BLE_MULTI_ADV_PARAM *) osi_malloc(len)) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_MULTI_ADV_PARAM)); p_msg->hdr.event = BTA_DM_API_BLE_MULTI_ADV_PARAM_UPD_EVT; p_msg->inst_id = inst_id; p_msg->p_params = (void *)(p_msg + 1); memcpy(p_msg->p_params, p_params, sizeof(tBTA_BLE_ADV_PARAMS)); bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_BleCfgAdvInstData ** ** Description This function configure a Multi-ADV instance with the specififed ** adv data or scan response data. ** ** Parameter inst_id: Adv instance to configure the adv data or scan response. ** is_scan_rsp: is the data scan response or adv data. ** data_mask: adv data type as bit mask. ** p_data: pointer to the ADV data structure tBTA_BLE_ADV_DATA. This ** memory space can not be freed until BTA_BLE_MULTI_ADV_DATA_EVT ** is sent to application. ** ** Returns BTA_SUCCESS if command started successfully; otherwise failure. ** *******************************************************************************/ void BTA_BleCfgAdvInstData (UINT8 inst_id, BOOLEAN is_scan_rsp, tBTA_BLE_AD_MASK data_mask, tBTA_BLE_ADV_DATA *p_data) { ///This function just used for vendor debug tBTA_DM_API_BLE_MULTI_ADV_DATA *p_msg; UINT16 len = sizeof(tBTA_DM_API_BLE_MULTI_ADV_DATA) ; APPL_TRACE_API ("BTA_BleCfgAdvInstData"); if ((p_msg = (tBTA_DM_API_BLE_MULTI_ADV_DATA *) osi_malloc(len)) != NULL) { memset(p_msg, 0, len); p_msg->hdr.event = BTA_DM_API_BLE_MULTI_ADV_DATA_EVT; p_msg->inst_id = inst_id; p_msg->is_scan_rsp = is_scan_rsp; p_msg->data_mask = data_mask; p_msg->p_data = p_data; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_BleDisableAdvInstance ** ** Description This function disable a Multi-ADV instance. ** ** Parameter inst_id: instance ID to disable. ** ** Returns BTA_SUCCESS if command started successfully; otherwise failure. ** *******************************************************************************/ void BTA_BleDisableAdvInstance (UINT8 inst_id) //this function just used for vendor debug { tBTA_DM_API_BLE_MULTI_ADV_DISABLE *p_msg; APPL_TRACE_API ("BTA_BleDisableAdvInstance: %d", inst_id); if ((p_msg = (tBTA_DM_API_BLE_MULTI_ADV_DISABLE *) osi_malloc(sizeof(tBTA_DM_API_BLE_MULTI_ADV_DISABLE))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_MULTI_ADV_DISABLE)); p_msg->hdr.event = BTA_DM_API_BLE_MULTI_ADV_DISABLE_EVT; p_msg->inst_id = inst_id; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleCfgFilterCondition ** ** Description This function is called to configure the adv data payload filter ** condition. ** ** Parameters action: to read/write/clear ** cond_type: filter condition type ** filt_index - Filter index ** p_cond: filter condition parameter ** p_cmpl_back - Command completed callback ** ref_value - Reference value ** ** Returns void ** *******************************************************************************/ void BTA_DmBleCfgFilterCondition(tBTA_DM_BLE_SCAN_COND_OP action, tBTA_DM_BLE_PF_COND_TYPE cond_type, tBTA_DM_BLE_PF_FILT_INDEX filt_index, tBTA_DM_BLE_PF_COND_PARAM *p_cond, tBTA_DM_BLE_PF_CFG_CBACK *p_cmpl_cback, tBTA_DM_BLE_REF_VALUE ref_value) { #if BLE_ANDROID_CONTROLLER_SCAN_FILTER == TRUE tBTA_DM_API_CFG_FILTER_COND *p_msg; APPL_TRACE_API ("BTA_DmBleCfgFilterCondition: %d, %d", action, cond_type); UINT16 len = sizeof(tBTA_DM_API_CFG_FILTER_COND) + sizeof(tBTA_DM_BLE_PF_COND_PARAM); UINT8 *p; if (NULL != p_cond) { switch (cond_type) { case BTA_DM_BLE_PF_SRVC_DATA_PATTERN: case BTA_DM_BLE_PF_MANU_DATA: /* Length of pattern and pattern mask and other elements in */ /* tBTA_DM_BLE_PF_MANU_COND */ len += ((p_cond->manu_data.data_len) * 2) + sizeof(UINT16) + sizeof(UINT16) + sizeof(UINT8); break; case BTA_DM_BLE_PF_LOCAL_NAME: len += ((p_cond->local_name.data_len) + sizeof(UINT8)); break; case BTM_BLE_PF_SRVC_UUID: case BTM_BLE_PF_SRVC_SOL_UUID: len += sizeof(tBLE_BD_ADDR) + sizeof(tBTA_DM_BLE_PF_COND_MASK); break; default: break; } } if ((p_msg = (tBTA_DM_API_CFG_FILTER_COND *) osi_malloc(len)) != NULL) { memset (p_msg, 0, len); p_msg->hdr.event = BTA_DM_API_CFG_FILTER_COND_EVT; p_msg->action = action; p_msg->cond_type = cond_type; p_msg->filt_index = filt_index; p_msg->p_filt_cfg_cback = p_cmpl_cback; p_msg->ref_value = ref_value; if (p_cond) { p_msg->p_cond_param = (tBTA_DM_BLE_PF_COND_PARAM *)(p_msg + 1); memcpy(p_msg->p_cond_param, p_cond, sizeof(tBTA_DM_BLE_PF_COND_PARAM)); p = (UINT8 *)(p_msg->p_cond_param + 1); if (cond_type == BTA_DM_BLE_PF_SRVC_DATA_PATTERN || cond_type == BTA_DM_BLE_PF_MANU_DATA) { p_msg->p_cond_param->manu_data.p_pattern = p; p_msg->p_cond_param->manu_data.data_len = p_cond->manu_data.data_len; memcpy(p_msg->p_cond_param->manu_data.p_pattern, p_cond->manu_data.p_pattern, p_cond->manu_data.data_len); p += p_cond->manu_data.data_len; if (cond_type == BTA_DM_BLE_PF_MANU_DATA) { p_msg->p_cond_param->manu_data.company_id_mask = p_cond->manu_data.company_id_mask; if ( p_cond->manu_data.p_pattern_mask != NULL) { p_msg->p_cond_param->manu_data.p_pattern_mask = p; memcpy(p_msg->p_cond_param->manu_data.p_pattern_mask, p_cond->manu_data.p_pattern_mask, p_cond->manu_data.data_len); } } } else if (cond_type == BTA_DM_BLE_PF_LOCAL_NAME) { p_msg->p_cond_param->local_name.p_data = p; p_msg->p_cond_param->local_name.data_len = p_cond->local_name.data_len; memcpy(p_msg->p_cond_param->local_name.p_data, p_cond->local_name.p_data, p_cond->local_name.data_len); } else if ((cond_type == BTM_BLE_PF_SRVC_UUID || cond_type == BTM_BLE_PF_SRVC_SOL_UUID)) { if (p_cond->srvc_uuid.p_target_addr != NULL) { p_msg->p_cond_param->srvc_uuid.p_target_addr = (tBLE_BD_ADDR *)(p); p_msg->p_cond_param->srvc_uuid.p_target_addr->type = p_cond->srvc_uuid.p_target_addr->type; memcpy(p_msg->p_cond_param->srvc_uuid.p_target_addr->bda, p_cond->srvc_uuid.p_target_addr->bda, BD_ADDR_LEN); p = (UINT8 *)( p_msg->p_cond_param->srvc_uuid.p_target_addr + 1); } if (p_cond->srvc_uuid.p_uuid_mask) { p_msg->p_cond_param->srvc_uuid.p_uuid_mask = (tBTA_DM_BLE_PF_COND_MASK *)p; memcpy(p_msg->p_cond_param->srvc_uuid.p_uuid_mask, p_cond->srvc_uuid.p_uuid_mask, sizeof(tBTA_DM_BLE_PF_COND_MASK)); } } } bta_sys_sendmsg(p_msg); } #else UNUSED(action); UNUSED(cond_type); UNUSED(filt_index); UNUSED(p_cond); UNUSED(p_cmpl_cback); UNUSED(ref_value); #endif } /******************************************************************************* ** ** Function BTA_DmBleScanFilterSetup ** ** Description This function is called to setup the adv data payload filter param ** ** Parameters p_target: enable the filter condition on a target device; if NULL ** filt_index - Filter index ** p_filt_params -Filter parameters ** ref_value - Reference value ** action - Add, delete or clear ** p_cmpl_back - Command completed callback ** ** Returns void ** *******************************************************************************/ void BTA_DmBleScanFilterSetup(UINT8 action, tBTA_DM_BLE_PF_FILT_INDEX filt_index, tBTA_DM_BLE_PF_FILT_PARAMS *p_filt_params, tBLE_BD_ADDR *p_target, tBTA_DM_BLE_PF_PARAM_CBACK *p_cmpl_cback, tBTA_DM_BLE_REF_VALUE ref_value) { #if BLE_ANDROID_CONTROLLER_SCAN_FILTER == TRUE tBTA_DM_API_SCAN_FILTER_PARAM_SETUP *p_msg; APPL_TRACE_API ("BTA_DmBleScanFilterSetup: %d", action); UINT16 len = sizeof(tBTA_DM_API_SCAN_FILTER_PARAM_SETUP) + sizeof(tBLE_BD_ADDR); if ((p_msg = (tBTA_DM_API_SCAN_FILTER_PARAM_SETUP *) osi_malloc(len)) != NULL) { memset (p_msg, 0, len); p_msg->hdr.event = BTA_DM_API_SCAN_FILTER_SETUP_EVT; p_msg->action = action; p_msg->filt_index = filt_index; if (p_filt_params) { memcpy(&p_msg->filt_params, p_filt_params, sizeof(tBTA_DM_BLE_PF_FILT_PARAMS)); } p_msg->p_filt_param_cback = p_cmpl_cback; p_msg->ref_value = ref_value; if (p_target) { p_msg->p_target = (tBLE_BD_ADDR *)(p_msg + 1); memcpy(p_msg->p_target, p_target, sizeof(tBLE_BD_ADDR)); } bta_sys_sendmsg(p_msg); } #else UNUSED(action); UNUSED(filt_index); UNUSED(p_filt_params); UNUSED(p_target); UNUSED(p_cmpl_cback); UNUSED(ref_value); #endif } /******************************************************************************* ** ** Function BTA_DmBleGetEnergyInfo ** ** Description This function is called to obtain the energy info ** ** Parameters p_cmpl_cback - Command complete callback ** ** Returns void ** *******************************************************************************/ void BTA_DmBleGetEnergyInfo(tBTA_BLE_ENERGY_INFO_CBACK *p_cmpl_cback) { tBTA_DM_API_ENERGY_INFO *p_msg; APPL_TRACE_API ("BTA_DmBleGetEnergyInfo"); UINT16 len = sizeof(tBTA_DM_API_ENERGY_INFO) + sizeof(tBLE_BD_ADDR); if ((p_msg = (tBTA_DM_API_ENERGY_INFO *) osi_malloc(len)) != NULL) { memset (p_msg, 0, len); p_msg->hdr.event = BTA_DM_API_BLE_ENERGY_INFO_EVT; p_msg->p_energy_info_cback = p_cmpl_cback; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmEnableScanFilter ** ** Description This function is called to enable the adv data payload filter ** ** Parameters action - enable or disable the APCF feature ** p_cmpl_cback - Command completed callback ** ref_value - Reference value ** ** Returns void ** *******************************************************************************/ void BTA_DmEnableScanFilter(UINT8 action, tBTA_DM_BLE_PF_STATUS_CBACK *p_cmpl_cback, tBTA_DM_BLE_REF_VALUE ref_value) { #if BLE_ANDROID_CONTROLLER_SCAN_FILTER == TRUE tBTA_DM_API_ENABLE_SCAN_FILTER *p_msg; APPL_TRACE_API ("BTA_DmEnableScanFilter: %d\n", action); UINT16 len = sizeof(tBTA_DM_API_ENABLE_SCAN_FILTER) + sizeof(tBLE_BD_ADDR); if ((p_msg = (tBTA_DM_API_ENABLE_SCAN_FILTER *) osi_malloc(len)) != NULL) { memset (p_msg, 0, len); p_msg->hdr.event = BTA_DM_API_SCAN_FILTER_ENABLE_EVT; p_msg->action = action; p_msg->ref_value = ref_value; p_msg->p_filt_status_cback = p_cmpl_cback; bta_sys_sendmsg(p_msg); } #else UNUSED(action); UNUSED(p_cmpl_cback); UNUSED(ref_value); #endif } /******************************************************************************* ** ** Function BTA_DmBleUpdateConnectionParams ** ** Description Update connection parameters, can only be used when connection is up. ** ** Parameters: bd_addr - BD address of the peer ** min_int - minimum connection interval, [0x0004~ 0x4000] ** max_int - maximum connection interval, [0x0004~ 0x4000] ** latency - slave latency [0 ~ 500] ** timeout - supervision timeout [0x000a ~ 0xc80] ** ** Returns void ** *******************************************************************************/ void BTA_DmBleUpdateConnectionParams(BD_ADDR bd_addr, UINT16 min_int, UINT16 max_int, UINT16 latency, UINT16 timeout) { tBTA_DM_API_UPDATE_CONN_PARAM *p_msg; if ((p_msg = (tBTA_DM_API_UPDATE_CONN_PARAM *) osi_malloc(sizeof(tBTA_DM_API_UPDATE_CONN_PARAM))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_UPDATE_CONN_PARAM)); p_msg->hdr.event = BTA_DM_API_UPDATE_CONN_PARAM_EVT; bdcpy(p_msg->bd_addr, bd_addr); p_msg->min_int = min_int; p_msg->max_int = max_int; p_msg->latency = latency; p_msg->timeout = timeout; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleDisconnect ** ** Description Disconnect the ble connection, can only be used when connection is up. ** ** Parameters: bd_addr - BD address of the peer ** ** Returns void ** *******************************************************************************/ void BTA_DmBleDisconnect(BD_ADDR bd_addr) { tBTA_DM_API_BLE_DISCONNECT *p_msg; if ((p_msg = (tBTA_DM_API_BLE_DISCONNECT *) osi_malloc(sizeof(tBTA_DM_API_BLE_DISCONNECT))) != NULL) { memset (p_msg, 0, sizeof(tBTA_DM_API_BLE_DISCONNECT)); p_msg->hdr.event = BTA_DM_API_BLE_DISCONNECT_EVT; bdcpy(p_msg->remote_bda, bd_addr); bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleSetDataLength ** ** Description This function is to set maximum LE data packet size ** ** Returns void ** ** *******************************************************************************/ void BTA_DmBleSetDataLength(BD_ADDR remote_device, UINT16 tx_data_length, tBTA_SET_PKT_DATA_LENGTH_CBACK *p_set_pkt_data_cback) { tBTA_DM_API_BLE_SET_DATA_LENGTH *p_msg; if ((p_msg = (tBTA_DM_API_BLE_SET_DATA_LENGTH *)osi_malloc(sizeof(tBTA_DM_API_BLE_SET_DATA_LENGTH))) != NULL) { bdcpy(p_msg->remote_bda, remote_device); p_msg->hdr.event = BTA_DM_API_SET_DATA_LENGTH_EVT; p_msg->tx_data_length = tx_data_length; p_msg->p_set_pkt_data_cback = p_set_pkt_data_cback; bta_sys_sendmsg(p_msg); } } #endif /******************************************************************************* ** ** Function BTA_DmSetEncryption ** ** Description This function is called to ensure that connection is ** encrypted. Should be called only on an open connection. ** Typically only needed for connections that first want to ** bring up unencrypted links, then later encrypt them. ** ** Parameters: bd_addr - Address of the peer device ** transport - transport of the link to be encruypted ** p_callback - Pointer to callback function to indicat the ** link encryption status ** sec_act - This is the security action to indicate ** what kind of BLE security level is required for ** the BLE link if the BLE is supported ** Note: This parameter is ignored for the BR/EDR link ** or the BLE is not supported ** ** Returns void ** *******************************************************************************/ #if (SMP_INCLUDED == TRUE) void BTA_DmSetEncryption(BD_ADDR bd_addr, tBTA_TRANSPORT transport, tBTA_DM_ENCRYPT_CBACK *p_callback, tBTA_DM_BLE_SEC_ACT sec_act) { tBTA_DM_API_SET_ENCRYPTION *p_msg; APPL_TRACE_API("BTA_DmSetEncryption"); //todo if ((p_msg = (tBTA_DM_API_SET_ENCRYPTION *) osi_malloc(sizeof(tBTA_DM_API_SET_ENCRYPTION))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_SET_ENCRYPTION)); p_msg->hdr.event = BTA_DM_API_SET_ENCRYPTION_EVT; memcpy(p_msg->bd_addr, bd_addr, BD_ADDR_LEN); p_msg->transport = transport; p_msg->p_callback = p_callback; p_msg->sec_act = sec_act; bta_sys_sendmsg(p_msg); } } #endif ///SMP_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmCloseACL ** ** Description This function force to close an ACL connection and remove the ** device from the security database list of known devices. ** ** Parameters: bd_addr - Address of the peer device ** remove_dev - remove device or not after link down ** ** Returns void ** *******************************************************************************/ void BTA_DmCloseACL(BD_ADDR bd_addr, BOOLEAN remove_dev, tBTA_TRANSPORT transport) { tBTA_DM_API_REMOVE_ACL *p_msg; APPL_TRACE_API("BTA_DmCloseACL"); if ((p_msg = (tBTA_DM_API_REMOVE_ACL *) osi_malloc(sizeof(tBTA_DM_API_REMOVE_ACL))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_REMOVE_ACL)); p_msg->hdr.event = BTA_DM_API_REMOVE_ACL_EVT; memcpy(p_msg->bd_addr, bd_addr, BD_ADDR_LEN); p_msg->remove_dev = remove_dev; p_msg->transport = transport; bta_sys_sendmsg(p_msg); } } #if BLE_INCLUDED == TRUE /******************************************************************************* ** ** Function BTA_DmBleObserve ** ** Description This procedure keep the device listening for advertising ** events from a broadcast device. ** ** Parameters start: start or stop observe. ** ** Returns void ** ** Returns void. ** *******************************************************************************/ extern void BTA_DmBleObserve(BOOLEAN start, UINT32 duration, tBTA_DM_SEARCH_CBACK *p_results_cb, tBTA_START_STOP_SCAN_CMPL_CBACK *p_start_stop_scan_cb) { tBTA_DM_API_BLE_OBSERVE *p_msg; APPL_TRACE_API("BTA_DmBleObserve:start = %d ", start); if ((p_msg = (tBTA_DM_API_BLE_OBSERVE *) osi_malloc(sizeof(tBTA_DM_API_BLE_OBSERVE))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_OBSERVE)); p_msg->hdr.event = BTA_DM_API_BLE_OBSERVE_EVT; p_msg->start = start; p_msg->duration = duration; p_msg->p_cback = p_results_cb; if (start){ p_msg->p_start_scan_cback = p_start_stop_scan_cb; } else { p_msg->p_stop_scan_cback = p_start_stop_scan_cb; } bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleScan ** ** Description This procedure keep the device listening for advertising ** events from a broadcast device. ** ** Parameters start: start or stop scan. ** ** Returns void ** ** Returns void. ** *******************************************************************************/ extern void BTA_DmBleScan(BOOLEAN start, UINT32 duration, tBTA_DM_SEARCH_CBACK *p_results_cb, tBTA_START_STOP_SCAN_CMPL_CBACK *p_start_stop_scan_cb) { tBTA_DM_API_BLE_SCAN *p_msg; APPL_TRACE_API("BTA_DmBleScan:start = %d ", start); if ((p_msg = (tBTA_DM_API_BLE_SCAN *) osi_malloc(sizeof(tBTA_DM_API_BLE_SCAN))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_SCAN)); p_msg->hdr.event = BTA_DM_API_BLE_SCAN_EVT; p_msg->start = start; p_msg->duration = duration; p_msg->p_cback = p_results_cb; if (start){ p_msg->p_start_scan_cback = p_start_stop_scan_cb; } else { p_msg->p_stop_scan_cback = p_start_stop_scan_cb; } bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmBleStopAdvertising ** ** Description This function set the random address for the APP ** ** Parameters void ** ** Returns void ** ** *******************************************************************************/ extern void BTA_DmBleStopAdvertising(void) { BT_HDR *p_msg; APPL_TRACE_API("BTA_DmBleStopAdvertising\n"); if ((p_msg = (BT_HDR *) osi_malloc(sizeof(BT_HDR))) != NULL) { memset(p_msg, 0, sizeof(BT_HDR)); p_msg->event = BTA_DM_API_BLE_STOP_ADV_EVT; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_DmSetRandAddress ** ** Description This function set the random address for the APP ** ** Parameters rand_addr: the random address whith should be setting ** p_set_rand_addr_cback: complete callback ** Returns void ** ** *******************************************************************************/ extern void BTA_DmSetRandAddress(BD_ADDR rand_addr, tBTA_SET_RAND_ADDR_CBACK *p_set_rand_addr_cback) { tBTA_DM_APT_SET_DEV_ADDR *p_msg; APPL_TRACE_API("set the random address "); if ((p_msg = (tBTA_DM_APT_SET_DEV_ADDR *) osi_malloc(sizeof(tBTA_DM_APT_SET_DEV_ADDR))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_APT_SET_DEV_ADDR)); memcpy(p_msg->address, rand_addr, BD_ADDR_LEN); p_msg->hdr.event = BTA_DM_API_SET_RAND_ADDR_EVT; p_msg->addr_type = BLE_ADDR_RANDOM; p_msg->p_set_rand_addr_cback = p_set_rand_addr_cback; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } } void BTA_DmClearRandAddress(void) { tBTA_DM_APT_CLEAR_ADDR *p_msg; if ((p_msg = (tBTA_DM_APT_CLEAR_ADDR *) osi_malloc(sizeof(tBTA_DM_APT_CLEAR_ADDR))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_APT_CLEAR_ADDR)); p_msg->hdr.event = BTA_DM_API_CLEAR_RAND_ADDR_EVT; bta_sys_sendmsg(p_msg); } } /******************************************************************************* ** ** Function BTA_VendorInit ** ** Description This function initializes vendor specific ** ** Returns void ** *******************************************************************************/ void BTA_VendorInit (void) { APPL_TRACE_API("BTA_VendorInit"); } /******************************************************************************* ** ** Function BTA_VendorCleanup ** ** Description This function frees up Broadcom specific VS specific dynamic memory ** ** Returns void ** *******************************************************************************/ void BTA_VendorCleanup (void) { tBTM_BLE_VSC_CB cmn_ble_vsc_cb; BTM_BleGetVendorCapabilities(&cmn_ble_vsc_cb); #if (BLE_INCLUDED == TRUE && BLE_ANDROID_CONTROLLER_SCAN_FILTER == TRUE) btm_ble_adv_filter_cleanup(); // when BLE_VND_INCLUDED is false, this function will be ignore, so move it out of "if" #if 0 //by TH, comment out temporarily if (cmn_ble_vsc_cb.max_filter > 0) { btm_ble_adv_filter_cleanup(); #if BLE_PRIVACY_SPT == TRUE btm_ble_resolving_list_cleanup (); #endif } #endif if (cmn_ble_vsc_cb.tot_scan_results_strg > 0) { btm_ble_batchscan_cleanup(); } #endif btm_ble_multi_adv_cleanup(); } #if (BLE_50_FEATURE_SUPPORT == TRUE) void BTA_DmBleGapReadPHY(BD_ADDR addr) { tBTA_DM_API_READ_PHY *p_msg; APPL_TRACE_API("%s, read phy.", __func__); if ((p_msg = (tBTA_DM_API_READ_PHY *) osi_malloc(sizeof(tBTA_DM_API_READ_PHY))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_READ_PHY)); p_msg->hdr.event = BTA_DM_API_READ_PHY_EVT; memcpy(p_msg->bd_addr, addr, BD_ADDR_LEN); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapSetPreferedDefaultPHY(tBTA_DM_BLE_GAP_PHY_MASK tx_phy_mask, tBTA_DM_BLE_GAP_PHY_MASK rx_phy_mask) { tBTA_DM_API_SET_PER_DEF_PHY *p_msg; APPL_TRACE_API("%s, Set prefered default phy.", __func__); if ((p_msg = (tBTA_DM_API_SET_PER_DEF_PHY *) osi_malloc(sizeof(tBTA_DM_API_SET_PER_DEF_PHY))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_SET_PER_DEF_PHY)); p_msg->hdr.event = BTA_DM_API_SET_PER_DEF_PHY_EVT; p_msg->tx_phy_mask = tx_phy_mask; p_msg->rx_phy_mask = rx_phy_mask; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapSetPreferedPHY(BD_ADDR addr, UINT8 all_phys, tBTA_DM_BLE_GAP_PHY_MASK tx_phy_mask, tBTA_DM_BLE_GAP_PHY_MASK rx_phy_mask, UINT16 phy_options) { tBTA_DM_API_SET_PER_PHY *p_msg; APPL_TRACE_API("%s, Set prefered phy.", __func__); if ((p_msg = (tBTA_DM_API_SET_PER_PHY *) osi_malloc(sizeof(tBTA_DM_API_SET_PER_PHY))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_SET_PER_PHY)); p_msg->hdr.event = BTA_DM_API_SET_PER_PHY_EVT; memcpy(p_msg->bd_addr, addr, BD_ADDR_LEN); p_msg->all_phys = all_phys; p_msg->tx_phy_mask = tx_phy_mask; p_msg->rx_phy_mask = rx_phy_mask; p_msg->phy_options = phy_options; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapExtAdvSetRandaddr(UINT16 instance, BD_ADDR addr) { tBTA_DM_API_EXT_ADV_SET_RAND_ADDR *p_msg; APPL_TRACE_API("%s, Set extended ADV parameters.", __func__); if ((p_msg = (tBTA_DM_API_EXT_ADV_SET_RAND_ADDR *) osi_malloc(sizeof(tBTA_DM_API_EXT_ADV_SET_RAND_ADDR))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_EXT_ADV_SET_RAND_ADDR)); p_msg->hdr.event = BTA_DM_API_SET_EXT_ADV_RAND_ADDR_EVT; p_msg->instance = instance; memcpy(&p_msg->rand_addr, addr, BD_ADDR_LEN); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapExtAdvSetParams(UINT16 instance, const tBTA_DM_BLE_GAP_EXT_ADV_PARAMS *params) { tBTA_DM_API_EXT_ADV_SET_PARAMS *p_msg; APPL_TRACE_API("%s, Set extended ADV parameters.", __func__); if ((p_msg = (tBTA_DM_API_EXT_ADV_SET_PARAMS *) osi_malloc(sizeof(tBTA_DM_API_EXT_ADV_SET_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_EXT_ADV_SET_PARAMS)); p_msg->hdr.event = BTA_DM_API_SET_EXT_ADV_PARAMS_EVT; p_msg->instance = instance; memcpy(&p_msg->params, params, sizeof(tBTA_DM_BLE_GAP_EXT_ADV_PARAMS)); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapConfigExtAdvDataRaw(BOOLEAN is_scan_rsp, UINT8 instance, UINT16 length, const UINT8 *data) { tBTA_DM_API_CFG_EXT_ADV_DATA *p_msg; APPL_TRACE_API("%s, Config extended %s data.", __func__, is_scan_rsp ? "Scan rsp" : "Adv"); if ((p_msg = (tBTA_DM_API_CFG_EXT_ADV_DATA *) osi_malloc(sizeof(tBTA_DM_API_CFG_EXT_ADV_DATA) + length)) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_CFG_EXT_ADV_DATA) + length); p_msg->hdr.event = BTA_DM_API_CFG_ADV_DATA_RAW_EVT; p_msg->is_scan_rsp = is_scan_rsp; p_msg->instance = instance; p_msg->length = length; p_msg->data = (UINT8 *)(p_msg + 1); if (data) { memcpy(p_msg->data, data, length); } //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapExtAdvEnable(BOOLEAN enable, UINT8 num, tBTA_DM_BLE_EXT_ADV *ext_adv) { tBTA_DM_API_BLE_EXT_ADV *p_msg; APPL_TRACE_API("%s, Start extended ADV", __func__); if ((p_msg = (tBTA_DM_API_BLE_EXT_ADV *) osi_malloc(sizeof(tBTA_DM_API_BLE_EXT_ADV) + sizeof(tBTA_DM_BLE_EXT_ADV)*num)) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_EXT_ADV) + sizeof(tBTA_DM_BLE_EXT_ADV)*num); p_msg->hdr.event = BTA_DM_API_EXT_ADV_ENABLE_EVT; p_msg->enable = enable; p_msg->num = num; p_msg->ext_adv = (tBTA_DM_BLE_EXT_ADV *)(p_msg + 1); if (ext_adv) { memcpy(p_msg->ext_adv, ext_adv, sizeof(tBTA_DM_BLE_EXT_ADV)*num); } //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapExtAdvSetRemove(UINT8 instance) { tBTA_DM_API_BLE_EXT_ADV_SET_REMOVE *p_msg; APPL_TRACE_API("%s, Remove extended ADV", __func__); if ((p_msg = (tBTA_DM_API_BLE_EXT_ADV_SET_REMOVE *) osi_malloc(sizeof(tBTA_DM_API_BLE_EXT_ADV_SET_REMOVE))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_EXT_ADV_SET_REMOVE)); p_msg->hdr.event = BTA_DM_API_EXT_ADV_SET_REMOVE_EVT; p_msg->instance = instance; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapExtAdvSetClear(void) { tBTA_DM_API_BLE_EXT_ADV_SET_CLEAR *p_msg; APPL_TRACE_API("%s, Clear extended ADV", __func__); if ((p_msg = (tBTA_DM_API_BLE_EXT_ADV_SET_CLEAR *) osi_malloc(sizeof(tBTA_DM_API_BLE_EXT_ADV_SET_CLEAR))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_EXT_ADV_SET_CLEAR)); p_msg->hdr.event = BTA_DM_API_EXT_ADV_SET_CLEAR_EVT; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvSetParams(UINT8 instance, tBTA_DM_BLE_Periodic_Adv_Params *params) { tBTA_DM_API_BLE_PERIODIC_ADV_SET_PARAMS *p_msg; APPL_TRACE_API("%s, Periodic ADV set parameters.", __func__); if ((p_msg = (tBTA_DM_API_BLE_PERIODIC_ADV_SET_PARAMS *) osi_malloc(sizeof(tBTA_DM_API_BLE_PERIODIC_ADV_SET_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_BLE_PERIODIC_ADV_SET_PARAMS)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_SET_PARAMS_EVT; p_msg->instance = instance; memcpy(&p_msg->params, params, sizeof(tBTA_DM_BLE_Periodic_Adv_Params)); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvCfgDataRaw(UINT8 instance, UINT16 length, const UINT8 *data) { tBTA_DM_API_CFG_PERIODIC_ADV_DATA *p_msg; APPL_TRACE_API("%s, Periodic ADV config data raw.", __func__); if ((p_msg = (tBTA_DM_API_CFG_PERIODIC_ADV_DATA *) osi_malloc(sizeof(tBTA_DM_API_CFG_PERIODIC_ADV_DATA) + length)) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_CFG_PERIODIC_ADV_DATA) + length); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_CFG_DATA_EVT; p_msg->instance = instance; p_msg->length = length; p_msg->data = (UINT8 *)(p_msg + 1); memcpy(p_msg->data, data, length); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvEnable(BOOLEAN enable, UINT8 instance) { tBTA_DM_API_ENABLE_PERIODIC_ADV *p_msg; APPL_TRACE_API("%s, Periodic ADV %s.", __func__, enable ? "start" : "stop"); if ((p_msg = (tBTA_DM_API_ENABLE_PERIODIC_ADV *) osi_malloc(sizeof(tBTA_DM_API_ENABLE_PERIODIC_ADV))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_ENABLE_PERIODIC_ADV)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_ENABLE_EVT; p_msg->instance = instance; p_msg->enable = enable; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvCreateSync(tBTA_DM_BLE_Periodic_Sync_Params *params) { tBTA_DM_API_PERIODIC_ADV_SYNC *p_msg; APPL_TRACE_API("%s, Periodic ADV create sync.", __func__); if ((p_msg = (tBTA_DM_API_PERIODIC_ADV_SYNC *) osi_malloc(sizeof(tBTA_DM_API_PERIODIC_ADV_SYNC))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_PERIODIC_ADV_SYNC)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_SYNC_EVT; memcpy(&p_msg->params, params, sizeof(tBTA_DM_BLE_Periodic_Sync_Params)); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvSyncCancel(void) { tBTA_DM_API_PERIODIC_ADV_SYNC_CANCEL *p_msg; APPL_TRACE_API("%s, Periodic ADV sync cancel.", __func__); if ((p_msg = (tBTA_DM_API_PERIODIC_ADV_SYNC_CANCEL *) osi_malloc(sizeof(tBTA_DM_API_PERIODIC_ADV_SYNC_CANCEL))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_PERIODIC_ADV_SYNC_CANCEL)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_SYNC_CANCEL_EVT; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvSyncTerm(UINT16 sync_handle) { tBTA_DM_API_PERIODIC_ADV_SYNC_TERM *p_msg; APPL_TRACE_API("%s, Periodic ADV sync terminat.", __func__); if ((p_msg = (tBTA_DM_API_PERIODIC_ADV_SYNC_TERM *) osi_malloc(sizeof(tBTA_DM_API_PERIODIC_ADV_SYNC_TERM))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_PERIODIC_ADV_SYNC_TERM)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_SYNC_TERMINATE_EVT; p_msg->sync_handle = sync_handle; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvAddDevToList(tBLE_ADDR_TYPE addr_type, BD_ADDR addr, UINT16 sid) { tBTA_DM_API_PERIODIC_ADV_ADD_DEV_TO_LIST *p_msg; APPL_TRACE_API("%s, Periodic ADV add device to list.", __func__); if ((p_msg = (tBTA_DM_API_PERIODIC_ADV_ADD_DEV_TO_LIST *) osi_malloc(sizeof(tBTA_DM_API_PERIODIC_ADV_ADD_DEV_TO_LIST))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_PERIODIC_ADV_ADD_DEV_TO_LIST)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_ADD_DEV_TO_LSIT_EVT; p_msg->addr_type = addr_type; p_msg->sid = sid; memcpy(p_msg->addr, addr, sizeof(BD_ADDR)); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvRemoveDevFromList(tBLE_ADDR_TYPE addr_type, BD_ADDR addr, UINT16 sid) { tBTA_DM_API_PERIODIC_ADV_REMOVE_DEV_FROM_LIST *p_msg; APPL_TRACE_API("%s, Periodic ADV remove device from list.", __func__); if ((p_msg = (tBTA_DM_API_PERIODIC_ADV_REMOVE_DEV_FROM_LIST *) osi_malloc(sizeof(tBTA_DM_API_PERIODIC_ADV_REMOVE_DEV_FROM_LIST))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_PERIODIC_ADV_REMOVE_DEV_FROM_LIST)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_REMOVE_DEV_FROM_LSIT_EVT; p_msg->addr_type = addr_type; p_msg->sid = sid; memcpy(p_msg->addr, addr, sizeof(BD_ADDR)); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPeriodicAdvClearDev(void) { tBTA_DM_API_PERIODIC_ADV_DEV_CLEAR *p_msg; APPL_TRACE_API("%s, Periodic ADV clear device from list.", __func__); if ((p_msg = (tBTA_DM_API_PERIODIC_ADV_DEV_CLEAR *) osi_malloc(sizeof(tBTA_DM_API_PERIODIC_ADV_DEV_CLEAR))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_PERIODIC_ADV_DEV_CLEAR)); p_msg->hdr.event = BTA_DM_API_PERIODIC_ADV_CLEAR_DEV_EVT; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapSetExtScanParams(tBTA_DM_BLE_EXT_SCAN_PARAMS *params) { tBTA_DM_API_SET_EXT_SCAN_PARAMS *p_msg; APPL_TRACE_API("%s, Set extended scan parameters.", __func__); if ((p_msg = (tBTA_DM_API_SET_EXT_SCAN_PARAMS *) osi_malloc(sizeof(tBTA_DM_API_SET_EXT_SCAN_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_SET_EXT_SCAN_PARAMS)); p_msg->hdr.event = BTA_DM_API_SET_EXT_SCAN_PARAMS_EVT; memcpy(&p_msg->params, params, sizeof(tBTA_DM_BLE_EXT_SCAN_PARAMS)); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapExtScan(BOOLEAN start, UINT32 duration, UINT16 period) { tBTA_DM_API_EXT_SCAN *p_msg; APPL_TRACE_API("%s, %s extended scan.", __func__, start ? "Start" : "Stop"); if ((p_msg = (tBTA_DM_API_EXT_SCAN *) osi_malloc(sizeof(tBTA_DM_API_EXT_SCAN))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_EXT_SCAN)); p_msg->hdr.event = BTA_DM_API_START_EXT_SCAN_EVT; p_msg->start = start; p_msg->duration = duration; p_msg->period = period; //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapPreferExtConnectParamsSet(BD_ADDR bd_addr, UINT8 phy_mask, const tBTA_DM_BLE_CONN_PARAMS *phy_1m_conn_params, const tBTA_DM_BLE_CONN_PARAMS *phy_2m_conn_params, const tBTA_DM_BLE_CONN_PARAMS *phy_coded_conn_params) { tBTA_DM_API_SET_PER_EXT_CONN_PARAMS *p_msg; APPL_TRACE_API("%s, Set prefer extended connection parameters.", __func__); if ((p_msg = (tBTA_DM_API_SET_PER_EXT_CONN_PARAMS *) osi_malloc(sizeof(tBTA_DM_API_SET_PER_EXT_CONN_PARAMS))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_SET_PER_EXT_CONN_PARAMS)); p_msg->hdr.event = BTA_DM_API_SET_PERF_EXT_CONN_PARAMS_EVT; p_msg->phy_mask = phy_mask; memcpy(p_msg->bd_addr, bd_addr, sizeof(BD_ADDR)); if (phy_1m_conn_params) { memcpy(&p_msg->phy_1m_conn_params, phy_1m_conn_params, sizeof(tBTA_DM_BLE_CONN_PARAMS)); } if (phy_2m_conn_params) { memcpy(&p_msg->phy_2m_conn_params, phy_2m_conn_params, sizeof(tBTA_DM_BLE_CONN_PARAMS)); } if (phy_coded_conn_params) { memcpy(&p_msg->phy_coded_conn_params, phy_coded_conn_params, sizeof(tBTA_DM_BLE_CONN_PARAMS)); } //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } void BTA_DmBleGapExtConnect(tBLE_ADDR_TYPE own_addr_type, const BD_ADDR peer_addr) { tBTA_DM_API_EXT_CONN *p_msg; APPL_TRACE_API("%s, Start Extended connect.", __func__); APPL_TRACE_API("%s, Set prefer extended connection parameters.", __func__); if ((p_msg = (tBTA_DM_API_EXT_CONN *) osi_malloc(sizeof(tBTA_DM_API_EXT_CONN))) != NULL) { memset(p_msg, 0, sizeof(tBTA_DM_API_EXT_CONN)); p_msg->hdr.event = BTA_DM_API_EXT_CONN_EVT; p_msg->own_addr_type = own_addr_type; memcpy(p_msg->peer_addr, peer_addr, sizeof(BD_ADDR)); //start sent the msg to the bta system control moudle bta_sys_sendmsg(p_msg); } else { APPL_TRACE_ERROR("%s malloc failed", __func__); } } #endif // #if (BLE_50_FEATURE_SUPPORT == TRUE) #if (BLE_FEAT_PERIODIC_ADV_SYNC_TRANSFER == TRUE) uint8_t BTA_DmBlePeriodicAdvSetInfoTrans(uint8_t addr[6], uint16_t service_data, uint8_t adv_handle) { BTM_BlePeriodicAdvSetInfoTrans(addr, service_data, adv_handle); return 0; } uint8_t BTA_DmBleSetPeriodicAdvSyncTransParams(uint8_t addr[6], uint8_t mode, uint16_t skip, uint16_t sync_timeout) { BTM_BleSetPeriodicAdvSyncTransParams(addr, mode, skip, sync_timeout, 0); return 0; } #endif // #if (BLE_FEAT_PERIODIC_ADV_SYNC_TRANSFER == TRUE) #endif