blob: 414d42d506b121105d7c524aa2b19a9114f812c9 [file] [log] [blame]
/******************************************************************************
*
* 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 public interface file for the HeaLth device profile (HL)
* subsystem of BTA, Broadcom's Bluetooth application layer for mobile
* phones.
*
******************************************************************************/
#ifndef BTA_HL_API_H
#define BTA_HL_API_H
#include "bta_api.h"
#include "btm_api.h"
#include "mca_api.h"
/*****************************************************************************
* Constants and data types
****************************************************************************/
/* Extra Debug Code */
#ifndef BTA_HL_DEBUG
#define BTA_HL_DEBUG TRUE
#endif
#ifndef BTA_HL_NUM_APPS
#define BTA_HL_NUM_APPS 12
#endif
#ifndef BTA_HL_NUM_MDEPS
#define BTA_HL_NUM_MDEPS 13
#endif
#ifndef BTA_HL_NUM_MCLS
#define BTA_HL_NUM_MCLS 7
#endif
#ifndef BTA_HL_NUM_MDLS_PER_MDEP
#define BTA_HL_NUM_MDLS_PER_MDEP 4
#endif
#ifndef BTA_HL_NUM_MDLS_PER_MCL
#define BTA_HL_NUM_MDLS_PER_MCL 10
#endif
#ifndef BTA_HL_NUM_DATA_TYPES
#define BTA_HL_NUM_DATA_TYPES \
5 /* maximum number of data types can be supported \
per MDEP ID */
#endif
#define BTA_HL_MCAP_RSP_TOUT 2 /* 2 seconds */
#ifndef BTA_HL_CCH_NUM_FILTER_ELEMS
#define BTA_HL_CCH_NUM_FILTER_ELEMS 3
#endif
#ifndef BTA_HL_NUM_SDP_CBACKS
#define BTA_HL_NUM_SDP_CBACKS 7
#endif
#ifndef BTA_HL_NUM_SDP_RECS
#define BTA_HL_NUM_SDP_RECS 5
#endif
#ifndef BTA_HL_NUM_SDP_MDEPS
#define BTA_HL_NUM_SDP_MDEPS 12
#endif
#ifndef BTA_HL_NUM_SVC_ELEMS
#define BTA_HL_NUM_SVC_ELEMS 2
#endif
#ifndef BTA_HL_NUM_PROTO_ELEMS
#define BTA_HL_NUM_PROTO_ELEMS 2
#endif
#define BTA_HL_VERSION 0x0101
#define BTA_HL_NUM_ADD_PROTO_LISTS 1
#define BTA_HL_NUM_ADD_PROTO_ELEMS 2
#define BTA_HL_MDEP_SEQ_SIZE 20
#define BTA_HL_VAL_ARRY_SIZE 320
#ifndef BTA_HL_NUM_MDL_CFGS
#define BTA_HL_NUM_MDL_CFGS \
16 /* numer of MDL cfg saved in the persistent memory*/
#endif
#define BTA_HL_NUM_TIMERS 7
#define BTA_HL_CCH_RSP_TOUT 2000
#define BTA_HL_MAX_TIME 255
#define BTA_HL_MIN_TIME 1
#define BTA_HL_INVALID_APP_HANDLE 0xFF
#define BTA_HL_INVALID_MCL_HANDLE 0xFF
#define BTA_HL_INVALID_MDL_HANDLE 0xFFFF
#define BTA_HL_STATUS_OK 0
#define BTA_HL_STATUS_FAIL 1 /* Used to pass all other errors */
#define BTA_HL_STATUS_ABORTED 2
#define BTA_HL_STATUS_NO_RESOURCE 3
#define BTA_HL_STATUS_LAST_ITEM 4
#define BTA_HL_STATUS_DUPLICATE_APP_ID 5
#define BTA_HL_STATUS_INVALID_APP_HANDLE 6
#define BTA_HL_STATUS_INVALID_MCL_HANDLE 7
#define BTA_HL_STATUS_MCAP_REG_FAIL 8
#define BTA_HL_STATUS_MDEP_CO_FAIL 9
#define BTA_HL_STATUS_ECHO_CO_FAIL 10
#define BTA_HL_STATUS_MDL_CFG_CO_FAIL 11
#define BTA_HL_STATUS_SDP_NO_RESOURCE 12
#define BTA_HL_STATUS_SDP_FAIL 13
#define BTA_HL_STATUS_NO_CCH 14
#define BTA_HL_STATUS_NO_MCL 15
#define BTA_HL_STATUS_NO_FIRST_RELIABLE 17
#define BTA_HL_STATUS_INVALID_DCH_CFG 18
#define BTA_HL_STATUS_INVALID_MDL_HANDLE 19
#define BTA_HL_STATUS_INVALID_BD_ADDR 20
#define BTA_HL_STATUS_INVALID_RECONNECT_CFG 21
#define BTA_HL_STATUS_ECHO_TEST_BUSY 22
#define BTA_HL_STATUS_INVALID_LOCAL_MDEP_ID 23
#define BTA_HL_STATUS_INVALID_MDL_ID 24
#define BTA_HL_STATUS_NO_MDL_ID_FOUND 25
#define BTA_HL_STATUS_DCH_BUSY 26 /* DCH is congested*/
#define BTA_HL_STATUS_INVALID_CTRL_PSM 27
#define BTA_HL_STATUS_DUPLICATE_CCH_OPEN 28
typedef uint8_t tBTA_HL_STATUS;
typedef tMCA_HANDLE tBTA_HL_APP_HANDLE;
typedef tMCA_CL tBTA_HL_MCL_HANDLE;
typedef tMCA_DL tBTA_HL_MDL_HANDLE;
enum {
BTA_HL_DEVICE_TYPE_SINK,
BTA_HL_DEVICE_TYPE_SOURCE,
BTA_HL_DEVICE_TYPE_DUAL
};
typedef uint8_t tBTA_HL_DEVICE_TYPE;
#define BTA_HL_SDP_IEEE_11073_20601 0x01
#define BTA_HL_MCAP_SUP_RECONNECT_MASK_INIT 2 /* 0x02 */
#define BTA_HL_MCAP_SUP_RECONNECT_MASK_ACCEPT 4 /* 0x04 */
#define BTA_HL_MCAP_SUP_CSP_MASK_SYNC_SLAVE 0 /* 0x08 */
#define BTA_HL_MCAP_SUP_CSP_MASK_SYNC_MASTER 0 /* 0x10 */
#define BTA_HL_MCAP_SUP_PROC_MASK \
(BTA_HL_MCAP_SUP_RECONNECT_MASK_INIT | \
BTA_HL_MCAP_SUP_RECONNECT_MASK_ACCEPT | \
BTA_HL_MCAP_SUP_CSP_MASK_SYNC_SLAVE | BTA_HL_MCAP_SUP_CSP_MASK_SYNC_MASTER)
#define BTA_HL_MDEP_ROLE_SOURCE 0x00
#define BTA_HL_MDEP_ROLE_SINK 0x01
typedef uint8_t tBTA_HL_MDEP_ROLE;
#define BTA_HL_MDEP_ROLE_MASK_SOURCE 0x01 /* bit mask */
#define BTA_HL_MDEP_ROLE_MASK_SINK 0x02
typedef uint8_t tBTA_HL_MDEP_ROLE_MASK;
#define BTA_HL_ECHO_TEST_MDEP_ID 0
#define BTA_HL_ECHO_TEST_MDEP_CFG_IDX 0
#define BTA_HL_INVALID_MDEP_ID 0xFF
typedef tMCA_DEP tBTA_HL_MDEP_ID; /* 0 is for echo test,
0x01-0x7F availave for use,
0x80-0xFF reserved*/
#define BTA_HL_DELETE_ALL_MDL_IDS 0xFFFF
#define BTA_HL_MAX_MDL_VAL 0xFEFF
typedef uint16_t tBTA_HL_MDL_ID; /* 0x0000 reserved,
0x0001-0xFEFF dynamic range,
0xFF00-0xFFFE reserved,
0xFFFF indicates all MDLs*/
#define BTA_HL_MDEP_DESP_LEN 35
#define BTA_HL_DCH_MODE_RELIABLE 0
#define BTA_HL_DCH_MODE_STREAMING 1
typedef uint8_t tBTA_HL_DCH_MODE;
#define BTA_HL_DCH_CFG_NO_PREF 0
#define BTA_HL_DCH_CFG_RELIABLE 1
#define BTA_HL_DCH_CFG_STREAMING 2
#define BTA_HL_DCH_CFG_UNKNOWN 0xFF
typedef uint8_t tBTA_HL_DCH_CFG;
/* The Default DCH CFG for the echo test when the device is a Source */
#define BTA_HL_DEFAULT_ECHO_TEST_SRC_DCH_CFG BTA_HL_DCH_CFG_RELIABLE
#define BTA_HL_DCH_CREATE_RSP_SUCCESS 0
#define BTA_HL_DCH_CREATE_RSP_CFG_REJ 1
typedef uint8_t tBTA_HL_DCH_CREATE_RSP;
#define BTA_HL_MCAP_SUP_PROC_RECONNECT_INIT 0x02
#define BTA_HL_MCAP_SUP_PROC_RECONNECT_APT 0x04
#define BTA_HL_MCAP_SUP_PROC_CSP_SLAVE 0x08
#define BTA_HL_MCAP_SUP_PROC_CSP_MASTER 0x10
typedef uint8_t tBTA_HL_SUP_PROC_MASK;
typedef struct {
uint16_t max_rx_apdu_size; /* local rcv MTU */
uint16_t max_tx_apdu_size; /* maximum TX APDU size*/
} tBTA_HL_ECHO_CFG;
typedef struct {
uint16_t data_type;
uint16_t max_rx_apdu_size; /* local rcv MTU */
uint16_t max_tx_apdu_size; /* maximum TX APDU size*/
char desp[BTA_HL_MDEP_DESP_LEN + 1];
} tBTA_HL_MDEP_DATA_TYPE_CFG;
typedef struct {
tBTA_HL_MDEP_ROLE mdep_role;
uint8_t num_of_mdep_data_types;
tBTA_HL_MDEP_DATA_TYPE_CFG data_cfg[BTA_HL_NUM_DATA_TYPES];
} tBTA_HL_MDEP_CFG;
typedef struct {
tBTA_HL_MDEP_ID mdep_id; /* MDEP ID 0x01-0x7F */
tBTA_HL_MDEP_CFG mdep_cfg;
uint8_t ori_app_id;
} tBTA_HL_MDEP;
typedef struct {
tBTA_HL_MDEP mdep[BTA_HL_NUM_MDEPS];
tBTA_HL_ECHO_CFG echo_cfg;
tBTA_HL_MDEP_ROLE_MASK app_role_mask;
bool advertize_source_sdp;
uint8_t num_of_mdeps;
} tBTA_HL_SUP_FEATURE;
typedef struct {
bool delete_req_pending;
tBTA_HL_MDL_ID mdl_id;
tBTA_HL_MCL_HANDLE mcl_handle;
} tBTA_HL_DELETE_MDL;
typedef struct {
uint8_t time;
uint16_t mtu;
tBTA_HL_MDL_ID mdl_id;
tBTA_HL_MDEP_ID local_mdep_id;
tBTA_HL_MDEP_ROLE local_mdep_role;
bool active; /* true if this item is in use */
tBTA_HL_DCH_MODE dch_mode;
uint8_t fcs;
RawAddress peer_bd_addr;
} tBTA_HL_MDL_CFG;
/* Maximum number of supported feature list items (list_elem in
* tSDP_SUP_FEATURE_ELEM) */
#define BTA_HL_NUM_SUP_FEATURE_ELEMS 13
#define BTA_HL_SUP_FEATURE_SDP_BUF_SIZE 512
/* This structure is used to add supported feature lists and find supported
* feature elements */
typedef struct {
uint8_t mdep_id;
uint16_t data_type;
tBTA_HL_MDEP_ROLE mdep_role;
char* p_mdep_desp;
} tBTA_HL_SUP_FEATURE_ELEM;
typedef struct {
uint16_t num_elems;
tBTA_HL_SUP_FEATURE_ELEM list_elem[BTA_HL_NUM_SUP_FEATURE_ELEMS];
} tBTA_HL_SUP_FEATURE_LIST_ELEM;
typedef struct {
tBTA_HL_DEVICE_TYPE dev_type; /* sink, source or dual roles */
tBTA_SEC sec_mask; /* security mask for accepting conenction*/
const char*
p_srv_name; /* service name to be used in the SDP; null terminated*/
const char* p_srv_desp; /* service description to be used in the SDP; null
terminated */
const char*
p_provider_name; /* provide name to be used in the SDP; null terminated */
} tBTA_HL_REG_PARAM;
typedef struct {
uint16_t ctrl_psm;
RawAddress bd_addr; /* Address of peer device */
tBTA_SEC sec_mask; /* security mask for initiating connection*/
} tBTA_HL_CCH_OPEN_PARAM;
typedef struct {
uint16_t ctrl_psm;
tBTA_HL_MDEP_ID local_mdep_id; /* local MDEP ID */
tBTA_HL_MDEP_ID peer_mdep_id; /* peer mdep id */
tBTA_HL_DCH_CFG local_cfg;
tBTA_SEC sec_mask; /* security mask for initiating connection*/
} tBTA_HL_DCH_OPEN_PARAM;
typedef struct {
uint16_t ctrl_psm;
tBTA_HL_MDL_ID mdl_id;
} tBTA_HL_DCH_RECONNECT_PARAM;
typedef struct {
uint16_t ctrl_psm;
uint16_t pkt_size;
tBTA_HL_DCH_CFG local_cfg;
} tBTA_HL_DCH_ECHO_TEST_PARAM;
typedef struct {
uint16_t buf_size;
uint8_t p_buf; /* buffer pointer */
} tBTA_HL_DCH_BUF_INFO;
typedef struct {
tBTA_HL_MDEP_ID local_mdep_id; /* local MDEP ID */
tBTA_HL_MDL_ID mdl_id;
tBTA_HL_DCH_CREATE_RSP rsp_code;
tBTA_HL_DCH_CFG cfg_rsp;
} tBTA_HL_DCH_CREATE_RSP_PARAM;
typedef struct {
uint16_t data_type;
uint8_t mdep_id;
tBTA_HL_MDEP_ROLE mdep_role;
char mdep_desp[BTA_HL_MDEP_DESP_LEN + 1];
} tBTA_HL_SDP_MDEP_CFG;
typedef struct {
uint16_t ctrl_psm;
uint16_t data_psm;
uint8_t mcap_sup_proc;
uint8_t num_mdeps; /* number of mdep elements from SDP*/
char srv_name[BTA_SERVICE_NAME_LEN + 1];
char srv_desp[BTA_SERVICE_DESP_LEN + 1];
char provider_name[BTA_PROVIDER_NAME_LEN + 1];
tBTA_HL_SDP_MDEP_CFG mdep_cfg[BTA_HL_NUM_SDP_MDEPS];
} tBTA_HL_SDP_REC;
typedef struct {
uint8_t num_recs;
tBTA_HL_SDP_REC sdp_rec[BTA_HL_NUM_SDP_RECS];
} tBTA_HL_SDP;
/* HL control callback function events */
enum { BTA_HL_CTRL_ENABLE_CFM_EVT = 0, BTA_HL_CTRL_DISABLE_CFM_EVT };
typedef uint8_t tBTA_HL_CTRL_EVT;
/* Structure associated with BTA_HL_ENABLE_EVT
BTA_HL_DISABLE_EVT */
typedef struct { tBTA_HL_STATUS status; } tBTA_HL_CTRL_ENABLE_DISABLE;
typedef union {
tBTA_HL_CTRL_ENABLE_DISABLE enable_cfm;
tBTA_HL_CTRL_ENABLE_DISABLE disable_cfm;
} tBTA_HL_CTRL;
/* HL instance callback function events */
enum {
BTA_HL_REGISTER_CFM_EVT = 0,
BTA_HL_DEREGISTER_CFM_EVT,
BTA_HL_CCH_OPEN_IND_EVT,
BTA_HL_CCH_OPEN_CFM_EVT,
BTA_HL_CCH_CLOSE_IND_EVT,
BTA_HL_CCH_CLOSE_CFM_EVT,
BTA_HL_DCH_CREATE_IND_EVT,
BTA_HL_DCH_OPEN_IND_EVT,
BTA_HL_DCH_OPEN_CFM_EVT,
BTA_HL_DCH_CLOSE_IND_EVT,
BTA_HL_DCH_CLOSE_CFM_EVT,
BTA_HL_DCH_RECONNECT_IND_EVT,
BTA_HL_DCH_RECONNECT_CFM_EVT,
BTA_HL_DCH_ABORT_IND_EVT,
BTA_HL_DCH_ABORT_CFM_EVT,
BTA_HL_DELETE_MDL_IND_EVT,
BTA_HL_DELETE_MDL_CFM_EVT,
BTA_HL_DCH_SEND_DATA_CFM_EVT,
BTA_HL_DCH_RCV_DATA_IND_EVT,
BTA_HL_CONG_CHG_IND_EVT,
BTA_HL_DCH_ECHO_TEST_CFM_EVT,
BTA_HL_SDP_QUERY_CFM_EVT,
BTA_HL_SDP_INFO_IND_EVT
};
typedef uint8_t tBTA_HL_EVT;
typedef struct {
tBTA_HL_STATUS status; /* start status */
uint8_t app_id;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_REGISTER_CFM;
typedef struct {
tBTA_HL_STATUS status; /* start status */
uint8_t app_id;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_DEREGISTER_CFM;
typedef struct {
bool intentional;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_CCH_CLOSE_IND;
typedef struct {
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_MCL_IND;
typedef struct {
tBTA_HL_STATUS status; /* connection status */
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_MCL_CFM;
typedef struct {
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
RawAddress bd_addr; /* address of peer device */
} tBTA_HL_CCH_OPEN_IND;
typedef struct {
tBTA_HL_STATUS status; /* connection status */
uint8_t app_id;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
RawAddress bd_addr; /* address of peer device */
} tBTA_HL_CCH_OPEN_CFM;
typedef struct {
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
tBTA_HL_MDEP_ID local_mdep_id;
tBTA_HL_MDL_ID mdl_id; /* MCAP data link ID for this
data channel conenction */
tBTA_HL_DCH_CFG cfg; /* dch cfg requested by the peer device */
RawAddress bd_addr; /* address of peer device */
} tBTA_HL_DCH_CREATE_IND;
typedef struct {
tBTA_HL_MDL_HANDLE mdl_handle;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
tBTA_HL_MDEP_ID local_mdep_id;
tBTA_HL_MDL_ID mdl_id; /* MCAP data link ID for this
data channel conenction */
tBTA_HL_DCH_MODE dch_mode; /* data channel mode - reliable or streaming*/
bool first_reliable; /* whether this is the first reliable data channel */
uint16_t mtu;
} tBTA_HL_DCH_OPEN_IND;
typedef struct {
tBTA_HL_STATUS status; /* connection status */
tBTA_HL_MDL_HANDLE mdl_handle;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
tBTA_HL_MDEP_ID local_mdep_id;
tBTA_HL_MDL_ID mdl_id; /* MCAP data link ID for this
data channel conenction */
tBTA_HL_DCH_MODE dch_mode; /* data channel mode - reliable or streaming*/
bool first_reliable; /* whether this is the first reliable data channel */
uint16_t mtu;
} tBTA_HL_DCH_OPEN_CFM;
typedef struct {
bool intentional;
tBTA_HL_MDL_HANDLE mdl_handle;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_DCH_CLOSE_IND;
typedef struct {
tBTA_HL_MDL_HANDLE mdl_handle;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_MDL_IND;
typedef struct {
tBTA_HL_STATUS status;
tBTA_HL_MDL_HANDLE mdl_handle;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
} tBTA_HL_MDL_CFM;
typedef struct {
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
tBTA_HL_MDL_ID mdl_id;
} tBTA_HL_DELETE_MDL_IND;
typedef struct {
tBTA_HL_STATUS status;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
tBTA_HL_MDL_ID mdl_id;
} tBTA_HL_DELETE_MDL_CFM;
typedef struct {
tBTA_HL_MDL_HANDLE mdl_handle;
tBTA_HL_MCL_HANDLE mcl_handle;
tBTA_HL_APP_HANDLE app_handle;
bool cong;
} tBTA_HL_DCH_CONG_IND;
typedef struct {
tBTA_HL_APP_HANDLE app_handle;
uint16_t ctrl_psm;
uint16_t data_psm;
uint8_t data_x_spec;
uint8_t mcap_sup_procs;
} tBTA_HL_SDP_INFO_IND;
typedef struct {
tBTA_HL_STATUS status;
uint8_t app_id;
tBTA_HL_APP_HANDLE app_handle;
RawAddress bd_addr;
tBTA_HL_SDP* p_sdp;
} tBTA_HL_SDP_QUERY_CFM;
typedef union {
tBTA_HL_REGISTER_CFM reg_cfm;
tBTA_HL_DEREGISTER_CFM dereg_cfm;
tBTA_HL_CCH_OPEN_IND cch_open_ind;
tBTA_HL_CCH_OPEN_CFM cch_open_cfm;
tBTA_HL_CCH_CLOSE_IND cch_close_ind;
tBTA_HL_MCL_CFM cch_close_cfm;
tBTA_HL_DCH_CREATE_IND dch_create_ind;
tBTA_HL_DCH_OPEN_IND dch_open_ind;
tBTA_HL_DCH_OPEN_CFM dch_open_cfm;
tBTA_HL_DCH_CLOSE_IND dch_close_ind;
tBTA_HL_MDL_CFM dch_close_cfm;
tBTA_HL_DCH_OPEN_IND dch_reconnect_ind;
tBTA_HL_DCH_OPEN_CFM dch_reconnect_cfm;
tBTA_HL_MCL_IND dch_abort_ind;
tBTA_HL_MCL_CFM dch_abort_cfm;
tBTA_HL_DELETE_MDL_IND delete_mdl_ind;
tBTA_HL_DELETE_MDL_CFM delete_mdl_cfm;
tBTA_HL_MDL_CFM dch_send_data_cfm;
tBTA_HL_MDL_IND dch_rcv_data_ind;
tBTA_HL_DCH_CONG_IND dch_cong_ind;
tBTA_HL_MCL_CFM echo_test_cfm;
tBTA_HL_SDP_QUERY_CFM sdp_query_cfm;
tBTA_HL_SDP_INFO_IND sdp_info_ind;
} tBTA_HL;
/* HL callback functions */
typedef void tBTA_HL_CTRL_CBACK(tBTA_HL_CTRL_EVT event, tBTA_HL_CTRL* p_data);
typedef void tBTA_HL_CBACK(tBTA_HL_EVT event, tBTA_HL* p_data);
/*****************************************************************************
* External Function Declarations
****************************************************************************/
/**************************
* API Functions
**************************/
/*******************************************************************************
*
* Function BTA_HlEnable
*
* Description Enable the HL subsystems. This function must be
* called before any other functions in the HL API are called.
* When the enable operation is completed the callback function
* will be called with an BTA_HL_CTRL_ENABLE_CFM_EVT event.
*
* Parameters p_cback - HL event call back function
*
* Returns void
*
******************************************************************************/
extern void BTA_HlEnable(tBTA_HL_CTRL_CBACK* p_ctrl_cback);
/*******************************************************************************
*
* Function BTA_HlDisable
*
* Description Disable the HL subsystem.
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDisable(void);
/*******************************************************************************
*
* Function BTA_HlUpdate
*
* Description Register an HDP application
*
* Parameters app_id - Application ID
* p_reg_param - non-platform related parameters for the
* HDP application
* p_cback - HL event callback fucntion
*
* Returns void
*
******************************************************************************/
extern void BTA_HlUpdate(uint8_t app_id, tBTA_HL_REG_PARAM* p_reg_param,
bool is_register, tBTA_HL_CBACK* p_cback);
/*******************************************************************************
*
* Function BTA_HlRegister
*
* Description Register a HDP application
*
*
* Parameters app_id - hdp application ID
* p_reg_param - non-platform related parameters for the
* HDP application
* p_cback - HL event callback fucntion
*
* Returns void
*
******************************************************************************/
extern void BTA_HlRegister(uint8_t app_id, tBTA_HL_REG_PARAM* p_reg_param,
tBTA_HL_CBACK* p_cback);
/*******************************************************************************
*
* Function BTA_HlDeregister
*
* Description Deregister an HDP application
*
* Parameters app_handle - Application handle
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDeregister(uint8_t app_id, tBTA_HL_APP_HANDLE app_handle);
/*******************************************************************************
*
* Function BTA_HlCchOpen
*
* Description Open a Control channel connection with the specified BD
* address and the control PSM value is used to select which
* HDP insatnce should be used in case the peer device support
* multiple HDP instances.
*
*
* Parameters app_handle - Application Handle
* p_open_param - parameters for opening a control channel
*
* Returns void
*
* Note: If the control PSM value is zero then the first HDP
* instance is used for the control channel setup
******************************************************************************/
extern void BTA_HlCchOpen(uint8_t app_id, tBTA_HL_APP_HANDLE app_handle,
tBTA_HL_CCH_OPEN_PARAM* p_open_param);
/*******************************************************************************
*
* Function BTA_HlCchClose
*
* Description Close a Control channel connection with the specified MCL
* handle
*
* Parameters mcl_handle - MCL handle
*
* Returns void
*
******************************************************************************/
extern void BTA_HlCchClose(tBTA_HL_MCL_HANDLE mcl_handle);
/*******************************************************************************
*
* Function BTA_HlDchOpen
*
* Description Open a data channel connection with the specified DCH
* parameters
*
* Parameters mcl_handle - MCL handle
* p_open_param - parameters for opening a data channel
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDchOpen(tBTA_HL_MCL_HANDLE mcl_handle,
tBTA_HL_DCH_OPEN_PARAM* p_open_param);
/*******************************************************************************
*
* Function BTA_HlDchReconnect
*
* Description Reconnect a data channel with the specified MDL_ID
*
* Parameters mcl_handle - MCL handle
*8 p_recon_param - parameters for reconnecting a data channel
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDchReconnect(tBTA_HL_MCL_HANDLE mcl_handle,
tBTA_HL_DCH_RECONNECT_PARAM* p_recon_param);
/*******************************************************************************
*
* Function BTA_HlDchClose
*
* Description Close a data channel with the specified MDL handle
*
* Parameters mdl_handle - MDL handle
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDchClose(tBTA_HL_MDL_HANDLE mdl_handle);
/*******************************************************************************
*
* Function BTA_HlDchAbort
*
* Description Abort the current data channel setup with the specified MCL
* handle
*
* Parameters mcl_handle - MCL handle
*
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDchAbort(tBTA_HL_MCL_HANDLE mcl_handle);
/*******************************************************************************
*
* Function BTA_HlSendData
*
* Description Send an APDU to the peer device
*
* Parameters mdl_handle - MDL handle
* pkt_size - size of the data packet to be sent
*
* Returns void
*
******************************************************************************/
extern void BTA_HlSendData(tBTA_HL_MDL_HANDLE mdl_handle, uint16_t pkt_size);
/*******************************************************************************
*
* Function BTA_HlDeleteMdl
*
* Description Delete the specified MDL_ID within the specified MCL handle
*
* Parameters mcl_handle - MCL handle
* mdl_id - MDL ID
*
* Returns void
*
* note: If mdl_id = 0xFFFF then this means to delete all MDLs
* and this value can only be used with DeleteMdl request
* only not other requests
*
******************************************************************************/
extern void BTA_HlDeleteMdl(tBTA_HL_MCL_HANDLE mcl_handle,
tBTA_HL_MDL_ID mdl_id);
/*******************************************************************************
*
* Function BTA_HlDchEchoTest
*
* Description Initiate an echo test with the specified MCL handle
*
* Parameters mcl_handle - MCL handle
*8 p_echo_test_param - parameters for echo testing
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDchEchoTest(tBTA_HL_MCL_HANDLE mcl_handle,
tBTA_HL_DCH_ECHO_TEST_PARAM* p_echo_test_param);
/*******************************************************************************
*
* Function BTA_HlSdpQuery
*
* Description SDP query request for the specified BD address
*
* Parameters app_id
app_handle - application handle
* bd_addr - BD address
*
* Returns void
*
******************************************************************************/
extern void BTA_HlSdpQuery(uint8_t app_id, tBTA_HL_APP_HANDLE app_handle,
const RawAddress& bd_addr);
/*******************************************************************************
*
* Function BTA_HlDchCreateMdlRsp
*
* Description Set the Response and configuration values for the Create MDL
* request
*
* Parameters mcl_handle - MCL handle
* p_rsp_param - parameters specified whether the request
* should be accepted or not and if it should be
* accepted then it also specified the
* configuration response value
*
* Returns void
*
******************************************************************************/
extern void BTA_HlDchCreateRsp(tBTA_HL_MCL_HANDLE mcl_handle,
tBTA_HL_DCH_CREATE_RSP_PARAM* p_rsp_param);
#endif /* BTA_HL_API_H */