| /****************************************************************************** |
| * |
| * Copyright 1999-2012 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 file contains the Bluetooth Manager (BTM) API function external |
| * definitions. |
| * |
| ******************************************************************************/ |
| #ifndef BTM_API_H |
| #define BTM_API_H |
| |
| #include "bt_target.h" |
| #include "device/include/esco_parameters.h" |
| #include "hcidefs.h" |
| #include "sdp_api.h" |
| |
| #include "smp_api.h" |
| |
| #include "btm_api_types.h" |
| |
| /***************************************************************************** |
| * DEVICE CONTROL and COMMON |
| ****************************************************************************/ |
| |
| /***************************************************************************** |
| * EXTERNAL FUNCTION DECLARATIONS |
| ****************************************************************************/ |
| |
| /***************************************************************************** |
| * DEVICE CONTROL and COMMON FUNCTIONS |
| ****************************************************************************/ |
| |
| /******************************************************************************* |
| * |
| * Function BTM_DeviceReset |
| * |
| * Description This function is called to reset the controller. The |
| * Callback function if provided is called when startup of the |
| * device has completed. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_DeviceReset(tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_IsDeviceUp |
| * |
| * Description This function is called to check if the device is up. |
| * |
| * Returns true if device is up, else false |
| * |
| ******************************************************************************/ |
| extern bool BTM_IsDeviceUp(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetLocalDeviceName |
| * |
| * Description This function is called to set the local device name. |
| * |
| * Returns BTM_CMD_STARTED if successful, otherwise an error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetLocalDeviceName(char* p_name); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetDeviceClass |
| * |
| * Description This function is called to set the local device class |
| * |
| * Returns BTM_SUCCESS if successful, otherwise an error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetDeviceClass(DEV_CLASS dev_class); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadLocalDeviceName |
| * |
| * Description This function is called to read the local device name. |
| * |
| * Returns status of the operation |
| * If success, BTM_SUCCESS is returned and p_name points stored |
| * local device name |
| * If BTM doesn't store local device name, BTM_NO_RESOURCES is |
| * is returned and p_name is set to NULL |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadLocalDeviceName(char** p_name); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadLocalDeviceNameFromController |
| * |
| * Description Get local device name from controller. Do not use cached |
| * name (used to get chip-id prior to btm reset complete). |
| * |
| * Returns BTM_CMD_STARTED if successful, otherwise an error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadLocalDeviceNameFromController( |
| tBTM_CMPL_CB* p_rln_cmpl_cback); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadDeviceClass |
| * |
| * Description This function is called to read the local device class |
| * |
| * Returns pointer to the device class |
| * |
| ******************************************************************************/ |
| extern uint8_t* BTM_ReadDeviceClass(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadLocalFeatures |
| * |
| * Description This function is called to read the local features |
| * |
| * Returns pointer to the local features string |
| * |
| ******************************************************************************/ |
| extern uint8_t* BTM_ReadLocalFeatures(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_RegisterForDeviceStatusNotif |
| * |
| * Description This function is called to register for device status |
| * change notifications. |
| * |
| * Returns pointer to previous caller's callback function or NULL if |
| * first registration. |
| * |
| ******************************************************************************/ |
| extern tBTM_DEV_STATUS_CB* BTM_RegisterForDeviceStatusNotif( |
| tBTM_DEV_STATUS_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_RegisterForVSEvents |
| * |
| * Description This function is called to register/deregister for vendor |
| * specific HCI events. |
| * |
| * If is_register=true, then the function will be registered; |
| * otherwise the function will be deregistered. |
| * |
| * Returns BTM_SUCCESS if successful, |
| * BTM_BUSY if maximum number of callbacks have already been |
| * registered. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_RegisterForVSEvents(tBTM_VS_EVT_CB* p_cb, |
| bool is_register); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_VendorSpecificCommand |
| * |
| * Description Send a vendor specific HCI command to the controller. |
| * |
| ******************************************************************************/ |
| extern void BTM_VendorSpecificCommand(uint16_t opcode, uint8_t param_len, |
| uint8_t* p_param_buf, |
| tBTM_VSC_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_AllocateSCN |
| * |
| * Description Look through the Server Channel Numbers for a free one to be |
| * used with an RFCOMM connection. |
| * |
| * Returns Allocated SCN number or 0 if none. |
| * |
| ******************************************************************************/ |
| extern uint8_t BTM_AllocateSCN(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_TryAllocateSCN |
| * |
| * Description Try to allocate a fixed server channel |
| * |
| * Returns Returns true if server channel was available |
| * |
| ******************************************************************************/ |
| extern bool BTM_TryAllocateSCN(uint8_t scn); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_FreeSCN |
| * |
| * Description Free the specified SCN. |
| * |
| * Returns true if successful, false if SCN is not in use or invalid |
| * |
| ******************************************************************************/ |
| extern bool BTM_FreeSCN(uint8_t scn); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetTraceLevel |
| * |
| * Description This function sets the trace level for BTM. If called with |
| * a value of 0xFF, it simply returns the current trace level. |
| * |
| * Returns The new or current trace level |
| * |
| ******************************************************************************/ |
| extern uint8_t BTM_SetTraceLevel(uint8_t new_level); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_WritePageTimeout |
| * |
| * Description Send HCI Wite Page Timeout. |
| * |
| ******************************************************************************/ |
| extern void BTM_WritePageTimeout(uint16_t timeout); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_WriteVoiceSettings |
| * |
| * Description Send HCI Write Voice Settings command. |
| * See hcidefs.h for settings bitmask values. |
| * |
| ******************************************************************************/ |
| extern void BTM_WriteVoiceSettings(uint16_t settings); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_EnableTestMode |
| * |
| * Description Send HCI the enable device under test command. |
| * |
| * Note: Controller can only be taken out of this mode by |
| * resetting the controller. |
| * |
| * Returns |
| * BTM_SUCCESS Command sent. |
| * BTM_NO_RESOURCES If out of resources to send the command. |
| * |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_EnableTestMode(void); |
| |
| /******************************************************************************* |
| * DEVICE DISCOVERY FUNCTIONS - Inquiry, Remote Name, Discovery, Class of Device |
| ******************************************************************************/ |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetDiscoverability |
| * |
| * Description This function is called to set the device into or out of |
| * discoverable mode. Discoverable mode means inquiry |
| * scans are enabled. If a value of '0' is entered for window |
| * or interval, the default values are used. |
| * |
| * Returns BTM_SUCCESS if successful |
| * BTM_BUSY if a setting of the filter is already in progress |
| * BTM_NO_RESOURCES if couldn't get a memory pool buffer |
| * BTM_ILLEGAL_VALUE if a bad parameter was detected |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetDiscoverability(uint16_t inq_mode, uint16_t window, |
| uint16_t interval); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadDiscoverability |
| * |
| * Description This function is called to read the current discoverability |
| * mode of the device. |
| * |
| * Output Params: p_window - current inquiry scan duration |
| * p_interval - current inquiry scan interval |
| * |
| * Returns BTM_NON_DISCOVERABLE, BTM_LIMITED_DISCOVERABLE, or |
| * BTM_GENERAL_DISCOVERABLE |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_ReadDiscoverability(uint16_t* p_window, |
| uint16_t* p_interval); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetPeriodicInquiryMode |
| * |
| * Description This function is called to set the device periodic inquiry |
| * mode. If the duration is zero, the periodic inquiry mode is |
| * cancelled. |
| * |
| * Parameters: p_inqparms - pointer to the inquiry information |
| * mode - GENERAL or LIMITED inquiry |
| * duration - length in 1.28 sec intervals (If '0', the |
| * inquiry is CANCELLED) |
| * max_resps - maximum amount of devices to search for |
| * before ending the inquiry |
| * filter_cond_type - BTM_CLR_INQUIRY_FILTER, |
| * BTM_FILTER_COND_DEVICE_CLASS, or |
| * BTM_FILTER_COND_BD_ADDR |
| * filter_cond - value for the filter (based on |
| * filter_cond_type) |
| * |
| * max_delay - maximum amount of time between successive |
| * inquiries |
| * min_delay - minimum amount of time between successive |
| * inquiries |
| * p_results_cb - callback returning pointer to results |
| * (tBTM_INQ_RESULTS) |
| * |
| * Returns BTM_CMD_STARTED if successfully started |
| * BTM_ILLEGAL_VALUE if a bad parameter is detected |
| * BTM_NO_RESOURCES if could not allocate a message buffer |
| * BTM_SUCCESS - if cancelling the periodic inquiry |
| * BTM_BUSY - if an inquiry is already active |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetPeriodicInquiryMode( |
| tBTM_INQ_PARMS* p_inqparms, uint16_t max_delay, uint16_t min_delay, |
| tBTM_INQ_RESULTS_CB* p_results_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_StartInquiry |
| * |
| * Description This function is called to start an inquiry. |
| * |
| * Parameters: p_inqparms - pointer to the inquiry information |
| * mode - GENERAL or LIMITED inquiry |
| * duration - length in 1.28 sec intervals (If '0', the |
| * inquiry is CANCELLED) |
| * max_resps - maximum amount of devices to search for |
| * before ending the inquiry |
| * filter_cond_type - BTM_CLR_INQUIRY_FILTER, |
| * BTM_FILTER_COND_DEVICE_CLASS, or |
| * BTM_FILTER_COND_BD_ADDR |
| * filter_cond - value for the filter (based on |
| * filter_cond_type) |
| * |
| * p_results_cb - Pointer to the callback routine which gets |
| * called upon receipt of an inquiry result. If |
| * this field is NULL, the application is not |
| * notified. |
| * |
| * p_cmpl_cb - Pointer to the callback routine which gets |
| * called upon completion. If this field is |
| * NULL, the application is not notified when |
| * completed. |
| * Returns tBTM_STATUS |
| * BTM_CMD_STARTED if successfully initiated |
| * BTM_BUSY if already in progress |
| * BTM_ILLEGAL_VALUE if parameter(s) are out of range |
| * BTM_NO_RESOURCES if could not allocate resources to start |
| * the command |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_StartInquiry(tBTM_INQ_PARMS* p_inqparms, |
| tBTM_INQ_RESULTS_CB* p_results_cb, |
| tBTM_CMPL_CB* p_cmpl_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_IsInquiryActive |
| * |
| * Description Return a bit mask of the current inquiry state |
| * |
| * Returns BTM_INQUIRY_INACTIVE if inactive (0) |
| * BTM_LIMITED_INQUIRY_ACTIVE if a limted inquiry is active |
| * BTM_GENERAL_INQUIRY_ACTIVE if a general inquiry is active |
| * BTM_PERIODIC_INQUIRY_ACTIVE if a periodic inquiry is active |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_IsInquiryActive(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_CancelInquiry |
| * |
| * Description This function cancels an inquiry if active |
| * |
| * Returns BTM_SUCCESS if successful |
| * BTM_NO_RESOURCES if could not allocate a message buffer |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_CancelInquiry(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_CancelPeriodicInquiry |
| * |
| * Description This function cancels a periodic inquiry |
| * |
| * Returns |
| * BTM_NO_RESOURCES if could not allocate a message buffer |
| * BTM_SUCCESS - if cancelling the periodic inquiry |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_CancelPeriodicInquiry(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetConnectability |
| * |
| * Description This function is called to set the device into or out of |
| * connectable mode. Discoverable mode means page scans are |
| * enabled. |
| * |
| * Returns BTM_SUCCESS if successful |
| * BTM_ILLEGAL_VALUE if a bad parameter is detected |
| * BTM_NO_RESOURCES if could not allocate a message buffer |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetConnectability(uint16_t page_mode, uint16_t window, |
| uint16_t interval); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadConnectability |
| * |
| * Description This function is called to read the current discoverability |
| * mode of the device. |
| * Output Params p_window - current page scan duration |
| * p_interval - current time between page scans |
| * |
| * Returns BTM_NON_CONNECTABLE or BTM_CONNECTABLE |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_ReadConnectability(uint16_t* p_window, |
| uint16_t* p_interval); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetInquiryMode |
| * |
| * Description This function is called to set standard, with RSSI |
| * mode or extended of the inquiry for local device. |
| * |
| * Input Params: BTM_INQ_RESULT_STANDARD, BTM_INQ_RESULT_WITH_RSSI or |
| * BTM_INQ_RESULT_EXTENDED |
| * |
| * Returns BTM_SUCCESS if successful |
| * BTM_NO_RESOURCES if couldn't get a memory pool buffer |
| * BTM_ILLEGAL_VALUE if a bad parameter was detected |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetInquiryMode(uint8_t mode); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetInquiryScanType |
| * |
| * Description This function is called to set the iquiry scan-type to |
| * standard or interlaced. |
| * |
| * Input Params: BTM_SCAN_TYPE_STANDARD or BTM_SCAN_TYPE_INTERLACED |
| * |
| * Returns BTM_SUCCESS if successful |
| * BTM_MODE_UNSUPPORTED if not a 1.2 device |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetInquiryScanType(uint16_t scan_type); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetPageScanType |
| * |
| * Description This function is called to set the page scan-type to |
| * standard or interlaced. |
| * |
| * Input Params: BTM_SCAN_TYPE_STANDARD or BTM_SCAN_TYPE_INTERLACED |
| * |
| * Returns BTM_SUCCESS if successful |
| * BTM_MODE_UNSUPPORTED if not a 1.2 device |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| |
| extern tBTM_STATUS BTM_SetPageScanType(uint16_t scan_type); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadRemoteDeviceName |
| * |
| * Description This function initiates a remote device HCI command to the |
| * controller and calls the callback when the process has |
| * completed. |
| * |
| * Input Params: remote_bda - device address of name to retrieve |
| * p_cb - callback function called when |
| * BTM_CMD_STARTED is returned. |
| * A pointer to tBTM_REMOTE_DEV_NAME is |
| * passed to the callback. |
| * |
| * Returns |
| * BTM_CMD_STARTED is returned if the request was successfully |
| * sent to HCI. |
| * BTM_BUSY if already in progress |
| * BTM_UNKNOWN_ADDR if device address is bad |
| * BTM_NO_RESOURCES if resources could not be allocated to |
| * start the command |
| * BTM_WRONG_MODE if the device is not up. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadRemoteDeviceName(const RawAddress& remote_bda, |
| tBTM_CMPL_CB* p_cb, |
| tBT_TRANSPORT transport); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_CancelRemoteDeviceName |
| * |
| * Description This function initiates the cancel request for the specified |
| * remote device. |
| * |
| * Input Params: None |
| * |
| * Returns |
| * BTM_CMD_STARTED is returned if the request was successfully |
| * sent to HCI. |
| * BTM_NO_RESOURCES if resources could not be allocated to |
| * start the command |
| * BTM_WRONG_MODE if there is no active remote name request. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_CancelRemoteDeviceName(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadRemoteVersion |
| * |
| * Description This function is called to read a remote device's version |
| * |
| * Returns BTM_SUCCESS if successful, otherwise an error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadRemoteVersion(const RawAddress& addr, |
| uint8_t* lmp_version, |
| uint16_t* manufacturer, |
| uint16_t* lmp_sub_version); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadRemoteFeatures |
| * |
| * Description This function is called to read a remote device's |
| * supported features mask (features mask located at page 0) |
| * |
| * Note: The size of device features mask page is |
| * BTM_FEATURE_BYTES_PER_PAGE bytes. |
| * |
| * Returns pointer to the remote supported features mask |
| * |
| ******************************************************************************/ |
| extern uint8_t* BTM_ReadRemoteFeatures(const RawAddress& addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadRemoteExtendedFeatures |
| * |
| * Description This function is called to read a specific extended features |
| * page of the remote device |
| * |
| * Note1: The size of device features mask page is |
| * BTM_FEATURE_BYTES_PER_PAGE bytes. |
| * Note2: The valid device features mask page number depends on |
| * the remote device capabilities. It is expected to be in the |
| * range [0 - BTM_EXT_FEATURES_PAGE_MAX]. |
| |
| * Returns pointer to the remote extended features mask |
| * or NULL if page_number is not valid |
| * |
| ******************************************************************************/ |
| extern uint8_t* BTM_ReadRemoteExtendedFeatures(const RawAddress& addr, |
| uint8_t page_number); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadNumberRemoteFeaturesPages |
| * |
| * Description This function is called to retrieve the number of feature |
| * pages read from the remote device |
| * |
| * Returns number of features pages read from the remote device |
| * |
| ******************************************************************************/ |
| extern uint8_t BTM_ReadNumberRemoteFeaturesPages(const RawAddress& addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadAllRemoteFeatures |
| * |
| * Description Read all the features of the remote device |
| * |
| * Returns pointer to the byte[0] of the page[0] of the remote device |
| * feature mask. |
| * |
| * Note: the function returns the pointer to the array of the size |
| * BTM_FEATURE_BYTES_PER_PAGE * (BTM_EXT_FEATURES_PAGE_MAX + 1) |
| * |
| ******************************************************************************/ |
| extern uint8_t* BTM_ReadAllRemoteFeatures(const RawAddress& addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_InqDbRead |
| * |
| * Description This function looks through the inquiry database for a match |
| * based on Bluetooth Device Address. This is the application's |
| * interface to get the inquiry details of a specific BD |
| * address. |
| * |
| * Returns pointer to entry, or NULL if not found |
| * |
| ******************************************************************************/ |
| extern tBTM_INQ_INFO* BTM_InqDbRead(const RawAddress& p_bda); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_InqDbFirst |
| * |
| * Description This function looks through the inquiry database for the |
| * first used entry, and returns that. This is used in |
| * conjunction with BTM_InqDbNext by applications as a way to |
| * walk through the inquiry database. |
| * |
| * Returns pointer to first in-use entry, or NULL if DB is empty |
| * |
| ******************************************************************************/ |
| extern tBTM_INQ_INFO* BTM_InqDbFirst(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_InqDbNext |
| * |
| * Description This function looks through the inquiry database for the |
| * next used entry, and returns that. If the input parameter |
| * is NULL, the first entry is returned. |
| * |
| * Returns pointer to next in-use entry, or NULL if no more found. |
| * |
| ******************************************************************************/ |
| extern tBTM_INQ_INFO* BTM_InqDbNext(tBTM_INQ_INFO* p_cur); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ClearInqDb |
| * |
| * Description This function is called to clear out a device or all devices |
| * from the inquiry database. |
| * |
| * Parameter p_bda - (input) BD_ADDR -> Address of device to clear |
| * (NULL clears all entries) |
| * |
| * Returns BTM_BUSY if an inquiry, get remote name, or event filter |
| * is active, otherwise BTM_SUCCESS |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ClearInqDb(const RawAddress* p_bda); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadInquiryRspTxPower |
| * |
| * Description This command will read the inquiry Transmit Power level used |
| * to transmit the FHS and EIR data packets. |
| * This can be used directly in the Tx Power Level EIR data |
| * type. |
| * |
| * Returns BTM_SUCCESS if successful |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadInquiryRspTxPower(tBTM_CMPL_CB* p_cb); |
| |
| /***************************************************************************** |
| * ACL CHANNEL MANAGEMENT FUNCTIONS |
| ****************************************************************************/ |
| /******************************************************************************* |
| * |
| * Function BTM_SetLinkPolicy |
| * |
| * Description Create and send HCI "Write Policy Set" command |
| * |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetLinkPolicy(const RawAddress& remote_bda, |
| uint16_t* settings); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetDefaultLinkPolicy |
| * |
| * Description Set the default value for HCI "Write Policy Set" command |
| * to use when an ACL link is created. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_SetDefaultLinkPolicy(uint16_t settings); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetDefaultLinkSuperTout |
| * |
| * Description Set the default value for HCI "Write Link Supervision |
| * Timeout" command to use when an ACL link is created. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_SetDefaultLinkSuperTout(uint16_t timeout); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetLinkSuperTout |
| * |
| * Description Create and send HCI "Write Link Supervision Timeout" command |
| * |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetLinkSuperTout(const RawAddress& remote_bda, |
| uint16_t timeout); |
| /******************************************************************************* |
| * |
| * Function BTM_GetLinkSuperTout |
| * |
| * Description Read the link supervision timeout value of the connection |
| * |
| * Returns status of the operation |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_GetLinkSuperTout(const RawAddress& remote_bda, |
| uint16_t* p_timeout); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_IsAclConnectionUp |
| * |
| * Description This function is called to check if an ACL connection exists |
| * to a specific remote BD Address. |
| * |
| * Returns true if connection is up, else false. |
| * |
| ******************************************************************************/ |
| extern bool BTM_IsAclConnectionUp(const RawAddress& remote_bda, |
| tBT_TRANSPORT transport); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetRole |
| * |
| * Description This function is called to get the role of the local device |
| * for the ACL connection with the specified remote device |
| * |
| * Returns BTM_SUCCESS if connection exists. |
| * BTM_UNKNOWN_ADDR if no active link with bd addr specified |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_GetRole(const RawAddress& remote_bd_addr, |
| uint8_t* p_role); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SwitchRole |
| * |
| * Description This function is called to switch role between master and |
| * slave. If role is already set it will do nothing. If the |
| * command was initiated, the callback function is called upon |
| * completion. |
| * |
| * Returns BTM_SUCCESS if already in specified role. |
| * BTM_CMD_STARTED if command issued to controller. |
| * BTM_NO_RESOURCES if memory couldn't be allocated to issue |
| * the command |
| * BTM_UNKNOWN_ADDR if no active link with bd addr specified |
| * BTM_MODE_UNSUPPORTED if the local device does not support |
| * role switching |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SwitchRole(const RawAddress& remote_bd_addr, |
| uint8_t new_role, tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadRSSI |
| * |
| * Description This function is called to read the link policy settings. |
| * The address of link policy results are returned in the |
| * callback. (tBTM_RSSI_RESULT) |
| * |
| * Returns BTM_CMD_STARTED if command issued to controller. |
| * BTM_NO_RESOURCES if memory couldn't be allocated to issue |
| * the command |
| * BTM_UNKNOWN_ADDR if no active link with bd addr specified |
| * BTM_BUSY if command is already in progress |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadRSSI(const RawAddress& remote_bda, |
| tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadFailedContactCounter |
| * |
| * Description This function is called to read the failed contact counter. |
| * The result is returned in the callback. |
| * (tBTM_FAILED_CONTACT_COUNTER_RESULT) |
| * |
| * Returns BTM_CMD_STARTED if command issued to controller. |
| * BTM_NO_RESOURCES if memory couldn't be allocated to issue |
| * the command |
| * BTM_UNKNOWN_ADDR if no active link with bd addr specified |
| * BTM_BUSY if command is already in progress |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadFailedContactCounter(const RawAddress& remote_bda, |
| tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadAutomaticFlushTimeout |
| * |
| * Description This function is called to read the automatic flush timeout. |
| * The result is returned in the callback. |
| * (tBTM_AUTOMATIC_FLUSH_TIMEOUT_RESULT) |
| * |
| * Returns BTM_CMD_STARTED if command issued to controller. |
| * BTM_NO_RESOURCES if memory couldn't be allocated to issue |
| * the command |
| * BTM_UNKNOWN_ADDR if no active link with bd addr specified |
| * BTM_BUSY if command is already in progress |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadAutomaticFlushTimeout(const RawAddress& remote_bda, |
| tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadTxPower |
| * |
| * Description This function is called to read the current connection |
| * TX power of the connection. The TX power level results |
| * are returned in the callback. |
| * (tBTM_RSSI_RESULT) |
| * |
| * Returns BTM_CMD_STARTED if command issued to controller. |
| * BTM_NO_RESOURCES if memory couldn't be allocated to issue |
| * the command |
| * BTM_UNKNOWN_ADDR if no active link with bd addr specified |
| * BTM_BUSY if command is already in progress |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadTxPower(const RawAddress& remote_bda, |
| tBT_TRANSPORT transport, tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadLinkQuality |
| * |
| * Description This function is called to read the link quality. |
| * The value of the link quality is returned in the callback. |
| * (tBTM_LINK_QUALITY_RESULT) |
| * |
| * Returns BTM_CMD_STARTED if command issued to controller. |
| * BTM_NO_RESOURCES if memory couldn't be allocated to issue |
| * the command |
| * BTM_UNKNOWN_ADDR if no active link with bd addr specified |
| * BTM_BUSY if command is already in progress |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadLinkQuality(const RawAddress& remote_bda, |
| tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_RegBusyLevelNotif |
| * |
| * Description This function is called to register a callback to receive |
| * busy level change events. |
| * |
| * Returns BTM_SUCCESS if successfully registered, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_RegBusyLevelNotif(tBTM_BL_CHANGE_CB* p_cb, |
| uint8_t* p_level, |
| tBTM_BL_EVENT_MASK evt_mask); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_AclRegisterForChanges |
| * |
| * Description This function is called to register a callback to receive |
| * ACL database change events, i.e. new connection or removed. |
| * |
| * Returns BTM_SUCCESS if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_AclRegisterForChanges(tBTM_ACL_DB_CHANGE_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetNumAclLinks |
| * |
| * Description This function is called to count the number of |
| * ACL links that are active. |
| * |
| * Returns uint16_t Number of active ACL links |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_GetNumAclLinks(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetQoS |
| * |
| * Description This function is called to setup QoS |
| * |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetQoS(const RawAddress& bd, FLOW_SPEC* p_flow, |
| tBTM_CMPL_CB* p_cb); |
| |
| /***************************************************************************** |
| * (e)SCO CHANNEL MANAGEMENT FUNCTIONS |
| ****************************************************************************/ |
| /******************************************************************************* |
| * |
| * Function BTM_CreateSco |
| * |
| * Description This function is called to create an SCO connection. If the |
| * "is_orig" flag is true, the connection will be originated, |
| * otherwise BTM will wait for the other side to connect. |
| * |
| * Returns BTM_UNKNOWN_ADDR if the ACL connection is not up |
| * BTM_BUSY if another SCO being set up to |
| * the same BD address |
| * BTM_NO_RESOURCES if the max SCO limit has been reached |
| * BTM_CMD_STARTED if the connection establishment is started. |
| * In this case, "*p_sco_inx" is filled in |
| * with the sco index used for the connection. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_CreateSco(const RawAddress* remote_bda, bool is_orig, |
| uint16_t pkt_types, uint16_t* p_sco_inx, |
| tBTM_SCO_CB* p_conn_cb, |
| tBTM_SCO_CB* p_disc_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_RemoveSco |
| * |
| * Description This function is called to remove a specific SCO connection. |
| * |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_RemoveSco(uint16_t sco_inx); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetScoPacketTypes |
| * |
| * Description This function is called to set the packet types used for |
| * a specific SCO connection, |
| * |
| * Parameters pkt_types - One or more of the following |
| * BTM_SCO_PKT_TYPES_MASK_HV1 |
| * BTM_SCO_PKT_TYPES_MASK_HV2 |
| * BTM_SCO_PKT_TYPES_MASK_HV3 |
| * BTM_SCO_PKT_TYPES_MASK_EV3 |
| * BTM_SCO_PKT_TYPES_MASK_EV4 |
| * BTM_SCO_PKT_TYPES_MASK_EV5 |
| * |
| * BTM_SCO_LINK_ALL_MASK - enables all supported types |
| * |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetScoPacketTypes(uint16_t sco_inx, uint16_t pkt_types); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadScoPacketTypes |
| * |
| * Description This function is read the packet types used for a specific |
| * SCO connection. |
| * |
| * Returns One or more of the following (bitmask) |
| * BTM_SCO_PKT_TYPES_MASK_HV1 |
| * BTM_SCO_PKT_TYPES_MASK_HV2 |
| * BTM_SCO_PKT_TYPES_MASK_HV3 |
| * BTM_SCO_PKT_TYPES_MASK_EV3 |
| * BTM_SCO_PKT_TYPES_MASK_EV4 |
| * BTM_SCO_PKT_TYPES_MASK_EV5 |
| * |
| * Returns packet types supported for the connection |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_ReadScoPacketTypes(uint16_t sco_inx); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadDeviceScoPacketTypes |
| * |
| * Description This function is read the SCO packet types that |
| * the device supports. |
| * |
| * Returns packet types supported by the device. |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_ReadDeviceScoPacketTypes(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadScoHandle |
| * |
| * Description Reead the HCI handle used for a specific SCO connection, |
| * |
| * Returns handle for the connection, or 0xFFFF if invalid SCO index. |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_ReadScoHandle(uint16_t sco_inx); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadScoBdAddr |
| * |
| * Description This function is read the remote BD Address for a specific |
| * SCO connection, |
| * |
| * Returns pointer to BD address or NULL if not known |
| * |
| ******************************************************************************/ |
| extern const RawAddress* BTM_ReadScoBdAddr(uint16_t sco_inx); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadScoDiscReason |
| * |
| * Description This function is returns the reason why an (e)SCO connection |
| * has been removed. It contains the value until read, or until |
| * another (e)SCO connection has disconnected. |
| * |
| * Returns HCI reason or BTM_INVALID_SCO_DISC_REASON if not set. |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_ReadScoDiscReason(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetEScoMode |
| * |
| * Description This function sets up the negotiated parameters for SCO or |
| * eSCO, and sets as the default mode used for calls to |
| * BTM_CreateSco. It can be called only when there are no |
| * active (e)SCO links. |
| * |
| * Returns BTM_SUCCESS if the successful. |
| * BTM_BUSY if there are one or more active (e)SCO links. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetEScoMode(enh_esco_params_t* p_parms); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetWBSCodec |
| * |
| * Description This function sends command to the controller to setup |
| * WBS codec for the upcoming eSCO connection. |
| * |
| * Returns BTM_SUCCESS. |
| * |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetWBSCodec(tBTM_SCO_CODEC_TYPE codec_type); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_RegForEScoEvts |
| * |
| * Description This function registers a SCO event callback with the |
| * specified instance. It should be used to received |
| * connection indication events and change of link parameter |
| * events. |
| * |
| * Returns BTM_SUCCESS if the successful. |
| * BTM_ILLEGAL_VALUE if there is an illegal sco_inx |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_RegForEScoEvts(uint16_t sco_inx, |
| tBTM_ESCO_CBACK* p_esco_cback); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadEScoLinkParms |
| * |
| * Description This function returns the current eSCO link parameters for |
| * the specified handle. This can be called anytime a |
| * connection is active, but is typically called after |
| * receiving the SCO opened callback. |
| * |
| * Note: If called over a 1.1 controller, only the packet types |
| * field has meaning. |
| * Note: If the upper layer doesn't know the current sco index, |
| * BTM_FIRST_ACTIVE_SCO_INDEX can be used as the first |
| * parameter to find the first active SCO index |
| * |
| * Returns BTM_SUCCESS if returned data is valid connection. |
| * BTM_ILLEGAL_VALUE if no connection for specified sco_inx. |
| * BTM_MODE_UNSUPPORTED if local controller does not support |
| * 1.2 specification. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadEScoLinkParms(uint16_t sco_inx, |
| tBTM_ESCO_DATA* p_parms); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ChangeEScoLinkParms |
| * |
| * Description This function requests renegotiation of the parameters on |
| * the current eSCO Link. If any of the changes are accepted |
| * by the controllers, the BTM_ESCO_CHG_EVT event is sent in |
| * the tBTM_ESCO_CBACK function with the current settings of |
| * the link. The callback is registered through the call to |
| * BTM_SetEScoMode. |
| * |
| * |
| * Returns BTM_CMD_STARTED if command is successfully initiated. |
| * BTM_ILLEGAL_VALUE if no connection for specified sco_inx. |
| * BTM_NO_RESOURCES - not enough resources to initiate command. |
| * BTM_MODE_UNSUPPORTED if local controller does not support |
| * 1.2 specification. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ChangeEScoLinkParms(uint16_t sco_inx, |
| tBTM_CHG_ESCO_PARAMS* p_parms); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_EScoConnRsp |
| * |
| * Description This function is called upon receipt of an (e)SCO connection |
| * request event (BTM_ESCO_CONN_REQ_EVT) to accept or reject |
| * the request. Parameters used to negotiate eSCO links. |
| * If p_parms is NULL, then values set through BTM_SetEScoMode |
| * are used. |
| * If the link type of the incoming request is SCO, then only |
| * the tx_bw, max_latency, content format, and packet_types are |
| * valid. The hci_status parameter should be |
| * ([0x0] to accept, [0x0d..0x0f] to reject) |
| * |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_EScoConnRsp(uint16_t sco_inx, uint8_t hci_status, |
| enh_esco_params_t* p_parms); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetNumScoLinks |
| * |
| * Description This function returns the number of active SCO links. |
| * |
| * Returns uint8_t |
| * |
| ******************************************************************************/ |
| extern uint8_t BTM_GetNumScoLinks(void); |
| |
| /***************************************************************************** |
| * SECURITY MANAGEMENT FUNCTIONS |
| ****************************************************************************/ |
| /******************************************************************************* |
| * |
| * Function BTM_SecRegister |
| * |
| * Description Application manager calls this function to register for |
| * security services. There can be one and only one |
| * application saving link keys. BTM allows only first |
| * registration. |
| * |
| * Returns true if registered OK, else false |
| * |
| ******************************************************************************/ |
| extern bool BTM_SecRegister(const tBTM_APPL_INFO* p_cb_info); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecRegisterLinkKeyNotificationCallback |
| * |
| * Description Profiles can register to be notified when a new Link Key |
| * is generated per connection. |
| * |
| * Returns true if registered OK, else false |
| * |
| ******************************************************************************/ |
| extern bool BTM_SecRegisterLinkKeyNotificationCallback( |
| tBTM_LINK_KEY_CALLBACK* p_callback); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecAddRmtNameNotifyCallback |
| * |
| * Description Profiles can register to be notified when name of the |
| * remote device is resolved (up to |
| * BTM_SEC_MAX_RMT_NAME_CALLBACKS). |
| * |
| * Returns true if registered OK, else false |
| * |
| ******************************************************************************/ |
| extern bool BTM_SecAddRmtNameNotifyCallback(tBTM_RMT_NAME_CALLBACK* p_callback); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecDeleteRmtNameNotifyCallback |
| * |
| * Description A profile can deregister notification when a new Link Key |
| * is generated per connection. |
| * |
| * Returns true if OK, else false |
| * |
| ******************************************************************************/ |
| extern bool BTM_SecDeleteRmtNameNotifyCallback( |
| tBTM_RMT_NAME_CALLBACK* p_callback); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetSecurityFlags |
| * |
| * Description Get security flags for the device |
| * |
| * Returns bool true or false is device found |
| * |
| ******************************************************************************/ |
| extern bool BTM_GetSecurityFlags(const RawAddress& bd_addr, |
| uint8_t* p_sec_flags); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetSecurityFlagsByTransport |
| * |
| * Description Get security flags for the device on a particular transport |
| * |
| * Parameters bd_addr: BD address of remote device |
| * p_sec_flags : Out parameter to be filled with security |
| * flags for the connection |
| * transport : Physical transport of the connection |
| * (BR/EDR or LE) |
| * |
| * Returns bool true or false is device found |
| * |
| ******************************************************************************/ |
| extern bool BTM_GetSecurityFlagsByTransport(const RawAddress& bd_addr, |
| uint8_t* p_sec_flags, |
| tBT_TRANSPORT transport); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadTrustedMask |
| * |
| * Description Get trusted mask for the device |
| * |
| * Returns NULL, if the device record is not found. |
| * otherwise, the trusted mask |
| * |
| ******************************************************************************/ |
| extern uint32_t* BTM_ReadTrustedMask(const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetPinType |
| * |
| * Description Set PIN type for the device. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_SetPinType(uint8_t pin_type, PIN_CODE pin_code, |
| uint8_t pin_code_len); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetPairableMode |
| * |
| * Description Enable or disable pairing |
| * |
| * Parameters allow_pairing - (true or false) whether or not the device |
| * allows pairing. |
| * connect_only_paired - (true or false) whether or not to |
| * only allow paired devices to connect. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_SetPairableMode(bool allow_pairing, bool connect_only_paired); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetSecureConnectionsOnly |
| * |
| * Description Enable or disable default treatment for Mode 4 Level 0 |
| * services |
| * |
| * Parameter secure_connections_only_mode - (true or false) |
| * true means that the device should treat Mode 4 Level 0 |
| * services as services of other levels. |
| * false means that the device should provide default |
| * treatment for Mode 4 Level 0 services. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_SetSecureConnectionsOnly(bool secure_connections_only_mode); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetSecurityLevel |
| * |
| * Description Register service security level with Security Manager. Each |
| * service must register its requirements regardless of the |
| * security level that is used. This API is called once for |
| * originators and again for acceptors of connections. |
| * |
| * Returns true if registered OK, else false |
| * |
| ******************************************************************************/ |
| extern bool BTM_SetSecurityLevel(bool is_originator, const char* p_name, |
| uint8_t service_id, uint16_t sec_level, |
| uint16_t psm, uint32_t mx_proto_id, |
| uint32_t mx_chan_id); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetOutService |
| * |
| * Description This function is called to set the service for |
| * outgoing connection. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_SetOutService(const RawAddress& bd_addr, uint8_t service_id, |
| uint32_t mx_chan_id); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecClrService |
| * |
| * Description Removes specified service record(s) from the security |
| * database. All service records with the specified name are |
| * removed. Typically used only by devices with limited RAM |
| * so that it can reuse an old security service record. |
| * |
| * Returns Number of records that were freed. |
| * |
| ******************************************************************************/ |
| extern uint8_t BTM_SecClrService(uint8_t service_id); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecAddDevice |
| * |
| * Description Add/modify device. This function will be normally called |
| * during host startup to restore all required information |
| * stored in the NVRAM. |
| * dev_class, bd_name, link_key, and features are NULL if |
| * unknown |
| * |
| * Returns true if added OK, else false |
| * |
| ******************************************************************************/ |
| extern bool BTM_SecAddDevice(const RawAddress& bd_addr, DEV_CLASS dev_class, |
| BD_NAME bd_name, uint8_t* features, |
| uint32_t trusted_mask[], LINK_KEY link_key, |
| uint8_t key_type, tBTM_IO_CAP io_cap, |
| uint8_t pin_length); |
| |
| /** Free resources associated with the device associated with |bd_addr| address. |
| * |
| * *** WARNING *** |
| * tBTM_SEC_DEV_REC associated with bd_addr becomes invalid after this function |
| * is called, also any of it's fields. i.e. if you use p_dev_rec->bd_addr, it is |
| * no longer valid! |
| * *** WARNING *** |
| * |
| * Returns true if removed OK, false if not found or ACL link is active. |
| */ |
| extern bool BTM_SecDeleteDevice(const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecClearSecurityFlags |
| * |
| * Description Reset the security flags (mark as not-paired) for a given |
| * remove device. |
| * |
| ******************************************************************************/ |
| extern void BTM_SecClearSecurityFlags(const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecGetDeviceLinkKey |
| * |
| * Description This function is called to obtain link key for the device |
| * it returns BTM_SUCCESS if link key is available, or |
| * BTM_UNKNOWN_ADDR if Security Manager does not know about |
| * the device or device record does not contain link key info |
| * |
| * Returns BTM_SUCCESS if successful, otherwise error code |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SecGetDeviceLinkKey(const RawAddress& bd_addr, |
| LINK_KEY link_key); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecGetDeviceLinkKeyType |
| * |
| * Description This function is called to obtain link key type for the |
| * device. |
| * it returns BTM_SUCCESS if link key is available, or |
| * BTM_UNKNOWN_ADDR if Security Manager does not know about |
| * the device or device record does not contain link key info |
| * |
| * Returns BTM_LKEY_TYPE_IGNORE if link key is unknown, link type |
| * otherwise. |
| * |
| ******************************************************************************/ |
| extern tBTM_LINK_KEY_TYPE BTM_SecGetDeviceLinkKeyType( |
| const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_PINCodeReply |
| * |
| * Description This function is called after Security Manager submitted |
| * PIN code request to the UI. |
| * |
| * Parameters: bd_addr - Address of the device for which PIN was |
| * requested |
| * res - result of the operation BTM_SUCCESS if |
| * success |
| * pin_len - length in bytes of the PIN Code |
| * p_pin - pointer to array with the PIN Code |
| * trusted_mask - bitwise OR of trusted services |
| * (array of uint32_t) |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_PINCodeReply(const RawAddress& bd_addr, uint8_t res, |
| uint8_t pin_len, uint8_t* p_pin, |
| uint32_t trusted_mask[]); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecBond |
| * |
| * Description This function is called to perform bonding with peer device. |
| * |
| * Parameters: bd_addr - Address of the device to bond |
| * pin_len - length in bytes of the PIN Code |
| * p_pin - pointer to array with the PIN Code |
| * trusted_mask - bitwise OR of trusted services |
| * (array of uint32_t) |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SecBond(const RawAddress& bd_addr, uint8_t pin_len, |
| uint8_t* p_pin, uint32_t trusted_mask[]); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecBondByTransport |
| * |
| * Description Perform bonding by designated transport |
| * |
| * Parameters: bd_addr - Address of the device to bond |
| * pin_len - length in bytes of the PIN Code |
| * p_pin - pointer to array with the PIN Code |
| * trusted_mask - bitwise OR of trusted services |
| * (array of uint32_t) |
| * transport : Physical transport to use for bonding |
| * (BR/EDR or LE) |
| * |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SecBondByTransport(const RawAddress& bd_addr, |
| tBT_TRANSPORT transport, |
| uint8_t pin_len, uint8_t* p_pin, |
| uint32_t trusted_mask[]); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecBondCancel |
| * |
| * Description This function is called to cancel ongoing bonding process |
| * with peer device. |
| * |
| * Returns BTM_CMD_STARTED if successfully initiated, otherwise error |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SecBondCancel(const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetEncryption |
| * |
| * 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 - Link transport |
| * p_callback - Pointer to callback function called if |
| * this function returns PENDING after required |
| * procedures are completed. Can be set to |
| * NULL if status is not desired. |
| * p_ref_data - pointer to any data the caller wishes to |
| * receive in the callback function upon |
| * completion. |
| * can be set to NULL if not used. |
| * sec_act - LE security action, unused for BR/EDR |
| * |
| * Returns BTM_SUCCESS - already encrypted |
| * BTM_PENDING - command will be returned in the callback |
| * BTM_WRONG_MODE- connection not up. |
| * BTM_BUSY - security procedures are currently active |
| * BTM_MODE_UNSUPPORTED - if security manager not linked in. |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetEncryption(const RawAddress& bd_addr, |
| tBT_TRANSPORT transport, |
| tBTM_SEC_CBACK* p_callback, |
| void* p_ref_data, |
| tBTM_BLE_SEC_ACT sec_act); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ConfirmReqReply |
| * |
| * Description This function is called to confirm the numeric value for |
| * Simple Pairing in response to BTM_SP_CFM_REQ_EVT |
| * |
| * Parameters: res - result of the operation BTM_SUCCESS if |
| * success |
| * bd_addr - Address of the peer device |
| * |
| ******************************************************************************/ |
| extern void BTM_ConfirmReqReply(tBTM_STATUS res, const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_PasskeyReqReply |
| * |
| * Description This function is called to provide the passkey for |
| * Simple Pairing in response to BTM_SP_KEY_REQ_EVT |
| * |
| * Parameters: res - result of the operation BTM_SUCCESS if |
| * success |
| * bd_addr - Address of the peer device |
| * passkey - numeric value in the range of |
| * 0 - 999999(0xF423F). |
| * |
| ******************************************************************************/ |
| extern void BTM_PasskeyReqReply(tBTM_STATUS res, const RawAddress& bd_addr, |
| uint32_t passkey); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SendKeypressNotif |
| * |
| * Description This function is used during the passkey entry model |
| * by a device with KeyboardOnly IO capabilities |
| * (very likely to be a HID Device). |
| * It is called by a HID Device to inform the remote device |
| * when a key has been entered or erased. |
| * |
| * Parameters: bd_addr - Address of the peer device |
| * type - notification type |
| * |
| ******************************************************************************/ |
| extern void BTM_SendKeypressNotif(const RawAddress& bd_addr, |
| tBTM_SP_KEY_TYPE type); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_IoCapRsp |
| * |
| * Description This function is called in response to BTM_SP_IO_REQ_EVT |
| * When the event data io_req.oob_data is set to |
| * BTM_OOB_UNKNOWN by the tBTM_SP_CALLBACK implementation, this |
| * function is called to provide the actual response |
| * |
| * Parameters: bd_addr - Address of the peer device |
| * io_cap - The IO capability of local device. |
| * oob - BTM_OOB_NONE or BTM_OOB_PRESENT. |
| * auth_req- MITM protection required or not. |
| * |
| ******************************************************************************/ |
| extern void BTM_IoCapRsp(const RawAddress& bd_addr, tBTM_IO_CAP io_cap, |
| tBTM_OOB_DATA oob, tBTM_AUTH_REQ auth_req); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadLocalOobData |
| * |
| * Description This function is called to read the local OOB data from |
| * LM |
| * |
| ******************************************************************************/ |
| extern void BTM_ReadLocalOobData(void); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_RemoteOobDataReply |
| * |
| * Description This function is called to provide the remote OOB data for |
| * Simple Pairing in response to BTM_SP_RMT_OOB_EVT |
| * |
| * Parameters: bd_addr - Address of the peer device |
| * c - simple pairing Hash C. |
| * r - simple pairing Randomizer C. |
| * |
| ******************************************************************************/ |
| extern void BTM_RemoteOobDataReply(tBTM_STATUS res, const RawAddress& bd_addr, |
| BT_OCTET16 c, BT_OCTET16 r); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_BuildOobData |
| * |
| * Description This function is called to build the OOB data payload to |
| * be sent over OOB (non-Bluetooth) link |
| * |
| * Parameters: p_data - the location for OOB data |
| * max_len - p_data size. |
| * c - simple pairing Hash C. |
| * r - simple pairing Randomizer C. |
| * name_len- 0, local device name would not be included. |
| * otherwise, the local device name is included for |
| * up to this specified length |
| * |
| * Returns Number of bytes in p_data. |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_BuildOobData(uint8_t* p_data, uint16_t max_len, |
| BT_OCTET16 c, BT_OCTET16 r, uint8_t name_len); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_BothEndsSupportSecureConnections |
| * |
| * Description This function is called to check if both the local device |
| * and the peer device specified by bd_addr support BR/EDR |
| * Secure Connections. |
| * |
| * Parameters: bd_addr - address of the peer |
| * |
| * Returns true if BR/EDR Secure Connections are supported by both |
| * local and the remote device. |
| * else false. |
| * |
| ******************************************************************************/ |
| extern bool BTM_BothEndsSupportSecureConnections(const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_PeerSupportsSecureConnections |
| * |
| * Description This function is called to check if the peer supports |
| * BR/EDR Secure Connections. |
| * |
| * Parameters: bd_addr - address of the peer |
| * |
| * Returns true if BR/EDR Secure Connections are supported by the peer, |
| * else false. |
| * |
| ******************************************************************************/ |
| extern bool BTM_PeerSupportsSecureConnections(const RawAddress& bd_addr); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadOobData |
| * |
| * Description This function is called to parse the OOB data payload |
| * received over OOB (non-Bluetooth) link |
| * |
| * Parameters: p_data - the location for OOB data |
| * eir_tag - The associated EIR tag to read the data. |
| * *p_len(output) - the length of the data with the given tag. |
| * |
| * Returns the beginning of the data with the given tag. |
| * NULL, if the tag is not found. |
| * |
| ******************************************************************************/ |
| extern uint8_t* BTM_ReadOobData(uint8_t* p_data, uint8_t eir_tag, |
| uint8_t* p_len); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SecReadDevName |
| * |
| * Description Looks for the device name in the security database for the |
| * specified BD address. |
| * |
| * Returns Pointer to the name or NULL |
| * |
| ******************************************************************************/ |
| extern char* BTM_SecReadDevName(const RawAddress& bd_addr); |
| |
| /***************************************************************************** |
| * POWER MANAGEMENT FUNCTIONS |
| ****************************************************************************/ |
| /******************************************************************************* |
| * |
| * Function BTM_PmRegister |
| * |
| * Description register or deregister with power manager |
| * |
| * Returns BTM_SUCCESS if successful, |
| * BTM_NO_RESOURCES if no room to hold registration |
| * BTM_ILLEGAL_VALUE |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_PmRegister(uint8_t mask, uint8_t* p_pm_id, |
| tBTM_PM_STATUS_CBACK* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetPowerMode |
| * |
| * Description store the mode in control block or |
| * alter ACL connection behavior. |
| * |
| * Returns BTM_SUCCESS if successful, |
| * BTM_UNKNOWN_ADDR if bd addr is not active or bad |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetPowerMode(uint8_t pm_id, const RawAddress& remote_bda, |
| const tBTM_PM_PWR_MD* p_mode); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_ReadPowerMode |
| * |
| * Description This returns the current mode for a specific |
| * ACL connection. |
| * |
| * Input Param remote_bda - device address of desired ACL connection |
| * |
| * Output Param p_mode - address where the current mode is copied into. |
| * BTM_ACL_MODE_NORMAL |
| * BTM_ACL_MODE_HOLD |
| * BTM_ACL_MODE_SNIFF |
| * BTM_ACL_MODE_PARK |
| * (valid only if return code is BTM_SUCCESS) |
| * |
| * Returns BTM_SUCCESS if successful, |
| * BTM_UNKNOWN_ADDR if bd addr is not active or bad |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ReadPowerMode(const RawAddress& remote_bda, |
| tBTM_PM_MODE* p_mode); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetSsrParams |
| * |
| * Description This sends the given SSR parameters for the given ACL |
| * connection if it is in ACTIVE mode. |
| * |
| * Input Param remote_bda - device address of desired ACL connection |
| * max_lat - maximum latency (in 0.625ms)(0-0xFFFE) |
| * min_rmt_to - minimum remote timeout |
| * min_loc_to - minimum local timeout |
| * |
| * |
| * Returns BTM_SUCCESS if the HCI command is issued successful, |
| * BTM_UNKNOWN_ADDR if bd addr is not active or bad |
| * BTM_CMD_STORED if the command is stored |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_SetSsrParams(const RawAddress& remote_bda, |
| uint16_t max_lat, uint16_t min_rmt_to, |
| uint16_t min_loc_to); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetHCIConnHandle |
| * |
| * Description This function is called to get the handle for an ACL |
| * connection to a specific remote BD Address. |
| * |
| * Returns the handle of the connection, or 0xFFFF if none. |
| * |
| ******************************************************************************/ |
| extern uint16_t BTM_GetHCIConnHandle(const RawAddress& remote_bda, |
| tBT_TRANSPORT transport); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_DeleteStoredLinkKey |
| * |
| * Description This function is called to delete link key for the specified |
| * device addresses from the NVRAM storage attached to the |
| * Bluetooth controller. |
| * |
| * Parameters: bd_addr - Addresses of the devices |
| * p_cb - Call back function to be called to return |
| * the results |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_DeleteStoredLinkKey(const RawAddress* bd_addr, |
| tBTM_CMPL_CB* p_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_WriteEIR |
| * |
| * Description This function is called to write EIR data to controller. |
| * |
| * Parameters p_buff - allocated HCI command buffer including extended |
| * inquriry response |
| * |
| * Returns BTM_SUCCESS - if successful |
| * BTM_MODE_UNSUPPORTED - if local device cannot support it |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_WriteEIR(BT_HDR* p_buff); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_HasEirService |
| * |
| * Description This function is called to know if UUID in bit map of UUID. |
| * |
| * Parameters p_eir_uuid - bit map of UUID list |
| * uuid16 - UUID 16-bit |
| * |
| * Returns true - if found |
| * false - if not found |
| * |
| ******************************************************************************/ |
| extern bool BTM_HasEirService(const uint32_t* p_eir_uuid, uint16_t uuid16); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_HasInquiryEirService |
| * |
| * Description Return if a UUID is in the bit map of a UUID list. |
| * |
| * Parameters p_results - inquiry results |
| * uuid16 - UUID 16-bit |
| * |
| * Returns BTM_EIR_FOUND - if found |
| * BTM_EIR_NOT_FOUND - if not found and it is a complete list |
| * BTM_EIR_UNKNOWN - if not found and it is not complete list |
| * |
| ******************************************************************************/ |
| extern tBTM_EIR_SEARCH_RESULT BTM_HasInquiryEirService( |
| tBTM_INQ_RESULTS* p_results, uint16_t uuid16); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_AddEirService |
| * |
| * Description This function is called to add a service in the bit map UUID |
| * list. |
| * |
| * Parameters p_eir_uuid - bit mask of UUID list for EIR |
| * uuid16 - UUID 16-bit |
| * |
| * Returns None |
| * |
| ******************************************************************************/ |
| extern void BTM_AddEirService(uint32_t* p_eir_uuid, uint16_t uuid16); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_RemoveEirService |
| * |
| * Description This function is called to remove a service from the bit map |
| * UUID list. |
| * |
| * Parameters p_eir_uuid - bit mask of UUID list for EIR |
| * uuid16 - UUID 16-bit |
| * |
| * Returns None |
| * |
| ******************************************************************************/ |
| extern void BTM_RemoveEirService(uint32_t* p_eir_uuid, uint16_t uuid16); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetEirSupportedServices |
| * |
| * Description This function is called to get UUID list from bit map UUID |
| * list. |
| * |
| * Parameters p_eir_uuid - bit mask of UUID list for EIR |
| * p - reference of current pointer of EIR |
| * max_num_uuid16 - max number of UUID can be written in EIR |
| * num_uuid16 - number of UUID have been written in EIR |
| * |
| * Returns BTM_EIR_MORE_16BITS_UUID_TYPE, if it has more than max |
| * BTM_EIR_COMPLETE_16BITS_UUID_TYPE, otherwise |
| * |
| ******************************************************************************/ |
| extern uint8_t BTM_GetEirSupportedServices(uint32_t* p_eir_uuid, uint8_t** p, |
| uint8_t max_num_uuid16, |
| uint8_t* p_num_uuid16); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_GetEirUuidList |
| * |
| * Description This function parses EIR and returns UUID list. |
| * |
| * Parameters p_eir - EIR |
| * eirl_len - EIR len |
| * uuid_size - Uuid::kNumBytes16, Uuid::kNumBytes32, |
| * Uuid::kNumBytes128 |
| * p_num_uuid - return number of UUID in found list |
| * p_uuid_list - return UUID 16-bit list |
| * max_num_uuid - maximum number of UUID to be returned |
| * |
| * Returns 0 - if not found |
| * BTM_EIR_COMPLETE_16BITS_UUID_TYPE |
| * BTM_EIR_MORE_16BITS_UUID_TYPE |
| * BTM_EIR_COMPLETE_32BITS_UUID_TYPE |
| * BTM_EIR_MORE_32BITS_UUID_TYPE |
| * BTM_EIR_COMPLETE_128BITS_UUID_TYPE |
| * BTM_EIR_MORE_128BITS_UUID_TYPE |
| * |
| ******************************************************************************/ |
| extern uint8_t BTM_GetEirUuidList(uint8_t* p_eir, size_t eir_len, |
| uint8_t uuid_size, uint8_t* p_num_uuid, |
| uint8_t* p_uuid_list, uint8_t max_num_uuid); |
| |
| /***************************************************************************** |
| * SCO OVER HCI |
| ****************************************************************************/ |
| /******************************************************************************* |
| * |
| * Function BTM_ConfigScoPath |
| * |
| * Description This function enable/disable SCO over HCI and registers SCO |
| * data callback if SCO over HCI is enabled. |
| * |
| * Parameter path: SCO or HCI |
| * p_sco_data_cb: callback function or SCO data if path is set |
| * to transport. |
| * p_pcm_param: pointer to the PCM interface parameter. If a |
| * NULL pointer is used, the PCM parameter |
| * maintained in the control block will be used; |
| * otherwise update the control block value. |
| * err_data_rpt: Lisbon feature to enable the erronous data |
| * report or not. |
| * |
| * Returns BTM_SUCCESS if the successful. |
| * BTM_NO_RESOURCES: no rsource to start the command. |
| * BTM_ILLEGAL_VALUE: invalid callback function pointer. |
| * BTM_CMD_STARTED : Command sent. Waiting for command |
| * complete event. |
| * |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_ConfigScoPath(esco_data_path_t path, |
| tBTM_SCO_DATA_CB* p_sco_data_cb, |
| tBTM_SCO_PCM_PARAM* p_pcm_param, |
| bool err_data_rpt); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_WriteScoData |
| * |
| * Description This function write SCO data to a specified instance. The |
| * data to be written p_buf needs to carry an offset of |
| * HCI_SCO_PREAMBLE_SIZE bytes, and the data length can not |
| * exceed BTM_SCO_DATA_SIZE_MAX bytes, whose default value is |
| * set to 60 and is configurable. Data longer than the maximum |
| * bytes will be truncated. |
| * |
| * Returns BTM_SUCCESS: data write is successful |
| * BTM_ILLEGAL_VALUE: SCO data contains illegal offset value. |
| * BTM_SCO_BAD_LENGTH: SCO data length exceeds the max SCO |
| * packet size. |
| * BTM_NO_RESOURCES: no resources. |
| * BTM_UNKNOWN_ADDR: unknown SCO connection handle, or SCO is |
| * not routed via HCI. |
| * |
| * |
| ******************************************************************************/ |
| extern tBTM_STATUS BTM_WriteScoData(uint16_t sco_inx, BT_HDR* p_buf); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_SetARCMode |
| * |
| * Description Send Audio Routing Control command. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_SetARCMode(uint8_t iface, uint8_t arc_mode, |
| tBTM_VSC_CMPL_CB* p_arc_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_PCM2Setup_Write |
| * |
| * Description Send PCM2_Setup write command. |
| * |
| * Returns void |
| * |
| ******************************************************************************/ |
| extern void BTM_PCM2Setup_Write(bool clk_master, tBTM_VSC_CMPL_CB* p_arc_cb); |
| |
| /******************************************************************************* |
| * |
| * Function BTM_PM_ReadControllerState |
| * |
| * Description This function is called to obtain the controller state |
| * |
| * Returns Controller state (BTM_CONTRL_ACTIVE, BTM_CONTRL_SCAN, and |
| * BTM_CONTRL_IDLE) |
| * |
| ******************************************************************************/ |
| extern tBTM_CONTRL_STATE BTM_PM_ReadControllerState(void); |
| |
| #endif /* BTM_API_H */ |