/******************************************************************************
*
* 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 */