/****************************************************************************** * * Copyright (C) 2009-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 is the interface file for the HL (HeaLth device profile) subsystem * call-out functions. * ******************************************************************************/ #ifndef BTA_HL_CO_H #define BTA_HL_CO_H #include "bta_api.h" #include "bta_hl_api.h" /***************************************************************************** * Constants and Data Types ****************************************************************************/ /************************** * Common Definitions **************************/ /******************************************************************************* * * Function bta_hl_co_get_num_of_mdep * * Description This function is called to get the number of MDEPs for this * application ID * * Parameters app_id - application ID * p_num_of_mdep (output) - number of MDEP configurations * supported * by the application * * Returns Bloolean - true success * ******************************************************************************/ extern bool bta_hl_co_get_num_of_mdep(uint8_t app_id, uint8_t* p_num_of_mdep); /******************************************************************************* * * Function bta_hl_co_advrtise_source_sdp * * Description This function is called to find out whether the SOURCE MDEP * configuration information should be advertize in the SDP or * not * * Parameters app_id - application ID * * Returns Bloolean - true advertise the SOURCE MDEP configuration * information * ******************************************************************************/ extern bool bta_hl_co_advrtise_source_sdp(uint8_t app_id); /******************************************************************************* * * Function bta_hl_co_get_mdep_config * * Description This function is called to get the supported feature * configuration for the specified mdep index and it also * assigns * the MDEP ID for the specified mdep index * * Parameters app_id - HDP application ID * mdep_idx - the mdep index * mdep_counter - mdep_counter * mdep_id - the assigned MDEP ID for the specified medp_idx * p_mdl_cfg (output) - pointer to the MDEP configuration * * * Returns Bloolean - true success ******************************************************************************/ extern bool bta_hl_co_get_mdep_config(uint8_t app_id, uint8_t mdep_idx, uint8_t mdep_counter, tBTA_HL_MDEP_ID mdep_id, tBTA_HL_MDEP_CFG* p_mdep_cfg); /******************************************************************************* * * Function bta_hl_co_get_echo_config * * Description This function is called to get the echo test * maximum APDU size configuration * * Parameters app_id - HDP application ID * p_echo_cfg (output) - pointer to the Echo test maximum APDU * size configuration * * Returns Bloolean - true success ******************************************************************************/ extern bool bta_hl_co_get_echo_config(uint8_t app_id, tBTA_HL_ECHO_CFG* p_echo_cfg); /******************************************************************************* * * Function bta_hl_co_save_mdl * * Description This function is called to save a MDL configuration item in * persistent storage * * Parameters app_id - HDP application ID * item_idx - the MDL configuration storage index * p_mdl_cfg - pointer to the MDL configuration data * * Returns void * ******************************************************************************/ extern void bta_hl_co_save_mdl(uint8_t app_id, uint8_t item_idx, tBTA_HL_MDL_CFG* p_mdl_cfg); /******************************************************************************* * * Function bta_hl_co_delete_mdl * * Description This function is called to delete a MDL configuration item in * persistent storage * * Parameters app_id - HDP application ID * item_idx - the MDL configuration storage index * * Returns void * ******************************************************************************/ extern void bta_hl_co_delete_mdl(uint8_t app_id, uint8_t item_idx); /******************************************************************************* * * Function bta_hl_co_get_mdl_config * * Description This function is called to get the MDL configuration * from teh persistent memory. This function shall only be *called *8 once after the device is powered up * * Parameters app_id - HDP application ID * buffer_size - the unit of the buffer size is *sizeof(tBTA_HL_MDL_CFG) * p_mdl_buf - Point to the starting location of the buffer * * Returns bool * * ******************************************************************************/ extern bool bta_hl_co_load_mdl_config(uint8_t app_id, uint8_t buffer_size, tBTA_HL_MDL_CFG* p_mdl_buf); /******************************************************************************* * * Function bta_hl_co_get_tx_data * * Description Get the data to be sent * * Parameters app_id - HDP application ID * mdl_handle - MDL handle * buf_size - the size of the buffer * p_buf - the buffer pointer * evt - the evt to be passed back to the HL in the * bta_hl_ci_get_tx_data call-in function * * Returns Void * ******************************************************************************/ extern void bta_hl_co_get_tx_data(uint8_t app_id, tBTA_HL_MDL_HANDLE mdl_handle, uint16_t buf_size, uint8_t* p_buf, uint16_t evt); /******************************************************************************* * * Function bta_hl_co_put_rx_data * * Description Put the received data * * Parameters app_id - HDP application ID * mdl_handle - MDL handle * data_size - the size of the data * p_data - the data pointer * evt - the evt to be passed back to the HL in the * bta_hl_ci_put_rx_data call-in function * * Returns Void * ******************************************************************************/ extern void bta_hl_co_put_rx_data(uint8_t app_id, tBTA_HL_MDL_HANDLE mdl_handle, uint16_t data_size, uint8_t* p_data, uint16_t evt); /******************************************************************************* * * Function bta_hl_co_get_tx_data * * Description Get the Echo data to be sent * * Parameters app_id - HDP application ID * mcl_handle - MCL handle * buf_size - the size of the buffer * p_buf - the buffer pointer * evt - the evt to be passed back to the HL in the * bta_hl_ci_get_tx_data call-in function * * Returns Void * ******************************************************************************/ extern void bta_hl_co_get_echo_data(uint8_t app_id, tBTA_HL_MCL_HANDLE mcl_handle, uint16_t buf_size, uint8_t* p_buf, uint16_t evt); /******************************************************************************* * * Function bta_hl_co_put_echo_data * * Description Put the received loopback echo data * * Parameters app_id - HDP application ID * mcl_handle - MCL handle * data_size - the size of the data * p_data - the data pointer * evt - the evt to be passed back to the HL in the * bta_hl_ci_put_echo_data call-in function * * Returns Void * ******************************************************************************/ extern void bta_hl_co_put_echo_data(uint8_t app_id, tBTA_HL_MCL_HANDLE mcl_handle, uint16_t data_size, uint8_t* p_data, uint16_t evt); #endif /* BTA_HL_CO_H */