bta_ag_int.h revision ad1e23d50e431fb82ff1b8d3ce02f64ca0c5a940
1/******************************************************************************
2 *
3 *  Copyright (C) 2003-2012 Broadcom Corporation
4 *
5 *  Licensed under the Apache License, Version 2.0 (the "License");
6 *  you may not use this file except in compliance with the License.
7 *  You may obtain a copy of the License at:
8 *
9 *  http://www.apache.org/licenses/LICENSE-2.0
10 *
11 *  Unless required by applicable law or agreed to in writing, software
12 *  distributed under the License is distributed on an "AS IS" BASIS,
13 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 *  See the License for the specific language governing permissions and
15 *  limitations under the License.
16 *
17 ******************************************************************************/
18
19/******************************************************************************
20 *
21 *  This is the private interface file for the BTA audio gateway.
22 *
23 ******************************************************************************/
24#ifndef BTA_AG_INT_H
25#define BTA_AG_INT_H
26
27#include "bta_ag_api.h"
28#include "bta_ag_at.h"
29#include "bta_api.h"
30#include "bta_sys.h"
31
32/*****************************************************************************
33 *  Constants
34 ****************************************************************************/
35/* Number of SCBs (AG service instances that can be registered) */
36#ifndef BTA_AG_NUM_SCB
37#define BTA_AG_NUM_SCB 2
38#endif
39
40/* Time to wait for retry in case of collision */
41#ifndef BTA_AG_COLLISION_TIMEOUT_MS
42#define BTA_AG_COLLISION_TIMEOUT_MS (2 * 1000) /* 2 seconds */
43#endif
44
45/* RFCOMM MTU SIZE */
46#define BTA_AG_MTU 256
47
48/* Max number of peer and local HF indicators */
49#define BTA_AG_MAX_NUM_PEER_HF_IND 20
50#define BTA_AG_MAX_NUM_LOCAL_HF_IND 4
51
52/* Internal profile indexes */
53#define BTA_AG_HSP 0     /* index for HSP */
54#define BTA_AG_HFP 1     /* index for HFP */
55#define BTA_AG_NUM_IDX 2 /* number of profile indexes */
56
57/* profile role for connection */
58#define BTA_AG_ACP 0 /* accepted connection */
59#define BTA_AG_INT 1 /* initiating connection */
60
61/* feature mask that matches spec */
62#define BTA_AG_BSRF_FEAT_SPEC                                   \
63  (BTA_AG_FEAT_3WAY | BTA_AG_FEAT_ECNR | BTA_AG_FEAT_VREC |     \
64   BTA_AG_FEAT_INBAND | BTA_AG_FEAT_VTAG | BTA_AG_FEAT_REJECT | \
65   BTA_AG_FEAT_ECS | BTA_AG_FEAT_ECC | BTA_AG_FEAT_EXTERR |     \
66   BTA_AG_FEAT_CODEC | BTA_AG_FEAT_HF_IND | BTA_AG_FEAT_ESCO |  \
67   BTA_AG_FEAT_VOIP)
68
69#define BTA_AG_SDP_FEAT_SPEC                                \
70  (BTA_AG_FEAT_3WAY | BTA_AG_FEAT_ECNR | BTA_AG_FEAT_VREC | \
71   BTA_AG_FEAT_INBAND | BTA_AG_FEAT_VTAG)
72
73enum {
74  /* these events are handled by the state machine */
75  BTA_AG_API_REGISTER_EVT = BTA_SYS_EVT_START(BTA_ID_AG),
76  BTA_AG_API_DEREGISTER_EVT,
77  BTA_AG_API_OPEN_EVT,
78  BTA_AG_API_CLOSE_EVT,
79  BTA_AG_API_AUDIO_OPEN_EVT,
80  BTA_AG_API_AUDIO_CLOSE_EVT,
81  BTA_AG_API_RESULT_EVT,
82  BTA_AG_API_SETCODEC_EVT,
83  BTA_AG_RFC_OPEN_EVT,
84  BTA_AG_RFC_CLOSE_EVT,
85  BTA_AG_RFC_SRV_CLOSE_EVT,
86  BTA_AG_RFC_DATA_EVT,
87  BTA_AG_SCO_OPEN_EVT,
88  BTA_AG_SCO_CLOSE_EVT,
89  BTA_AG_DISC_ACP_RES_EVT,
90  BTA_AG_DISC_INT_RES_EVT,
91  BTA_AG_DISC_OK_EVT,
92  BTA_AG_DISC_FAIL_EVT,
93  BTA_AG_CI_RX_WRITE_EVT,
94  BTA_AG_RING_TIMEOUT_EVT,
95  BTA_AG_SVC_TIMEOUT_EVT,
96  BTA_AG_CI_SCO_DATA_EVT,
97  BTA_AG_CI_SLC_READY_EVT,
98  BTA_AG_MAX_EVT,
99
100  /* these events are handled outside of the state machine */
101  BTA_AG_API_ENABLE_EVT,
102  BTA_AG_API_DISABLE_EVT
103};
104
105/* Actions to perform after a SCO event */
106enum {
107  BTA_AG_POST_SCO_NONE,      /* no action */
108  BTA_AG_POST_SCO_CLOSE_RFC, /* close RFCOMM channel after SCO closes */
109  BTA_AG_POST_SCO_RING,      /* send RING result code after SCO opens */
110  BTA_AG_POST_SCO_CALL_CONN, /* send call indicators after SCO opens/closes */
111  BTA_AG_POST_SCO_CALL_ORIG, /* send call indicators after SCO closes */
112  BTA_AG_POST_SCO_CALL_END,  /* send call indicators after SCO closes */
113  BTA_AG_POST_SCO_CALL_END_INCALL /* send call indicators for end call &
114                                     incoming call after SCO closes */
115};
116
117/* sco states */
118enum {
119  BTA_AG_SCO_SHUTDOWN_ST, /* no sco listening, all sco connections closed */
120  BTA_AG_SCO_LISTEN_ST,   /* sco listening */
121#if (BTM_WBS_INCLUDED == TRUE)
122  BTA_AG_SCO_CODEC_ST, /* sco codec negotiation */
123#endif
124  BTA_AG_SCO_OPENING_ST,    /* sco connection opening */
125  BTA_AG_SCO_OPEN_CL_ST,    /* opening sco connection being closed */
126  BTA_AG_SCO_OPEN_XFER_ST,  /* opening sco connection being transferred */
127  BTA_AG_SCO_OPEN_ST,       /* sco open */
128  BTA_AG_SCO_CLOSING_ST,    /* sco closing */
129  BTA_AG_SCO_CLOSE_OP_ST,   /* closing sco being opened */
130  BTA_AG_SCO_CLOSE_XFER_ST, /* closing sco being transferred */
131  BTA_AG_SCO_SHUTTING_ST    /* sco shutting down */
132};
133
134/*****************************************************************************
135 *  Data types
136 ****************************************************************************/
137
138/* data type for BTA_AG_API_ENABLE_EVT */
139typedef struct {
140  BT_HDR hdr;
141  tBTA_AG_PARSE_MODE parse_mode;
142  tBTA_AG_CBACK* p_cback;
143} tBTA_AG_API_ENABLE;
144
145/* data type for BTA_AG_API_REGISTER_EVT */
146typedef struct {
147  BT_HDR hdr;
148  char p_name[2][BTA_SERVICE_NAME_LEN + 1];
149  tBTA_SERVICE_MASK services;
150  tBTA_SEC sec_mask;
151  tBTA_AG_FEAT features;
152  uint8_t app_id;
153} tBTA_AG_API_REGISTER;
154
155/* data type for BTA_AG_API_OPEN_EVT */
156typedef struct {
157  BT_HDR hdr;
158  BD_ADDR bd_addr;
159  tBTA_SERVICE_MASK services;
160  tBTA_SEC sec_mask;
161} tBTA_AG_API_OPEN;
162
163/* data type for BTA_AG_API_RESULT_EVT */
164typedef struct {
165  BT_HDR hdr;
166  tBTA_AG_RES result;
167  tBTA_AG_RES_DATA data;
168} tBTA_AG_API_RESULT;
169
170/* data type for BTA_AG_API_SETCODEC_EVT */
171typedef struct {
172  BT_HDR hdr;
173  tBTA_AG_PEER_CODEC codec;
174} tBTA_AG_API_SETCODEC;
175
176/* data type for BTA_AG_DISC_RESULT_EVT */
177typedef struct {
178  BT_HDR hdr;
179  uint16_t status;
180} tBTA_AG_DISC_RESULT;
181
182/* data type for RFCOMM events */
183typedef struct {
184  BT_HDR hdr;
185  uint16_t port_handle;
186} tBTA_AG_RFC;
187
188/* data type for BTA_AG_CI_RX_WRITE_EVT */
189typedef struct {
190  BT_HDR hdr;
191  //    char            p_data[BTA_AG_MTU+1];
192} tBTA_AG_CI_RX_WRITE;
193
194/* union of all event datatypes */
195typedef union {
196  BT_HDR hdr;
197  tBTA_AG_API_ENABLE api_enable;
198  tBTA_AG_API_REGISTER api_register;
199  tBTA_AG_API_OPEN api_open;
200  tBTA_AG_API_RESULT api_result;
201#if (BTM_WBS_INCLUDED == TRUE)
202  tBTA_AG_API_SETCODEC api_setcodec;
203#endif
204  tBTA_AG_DISC_RESULT disc_result;
205  tBTA_AG_RFC rfc;
206  tBTA_AG_CI_RX_WRITE ci_rx_write;
207} tBTA_AG_DATA;
208
209/* type for each profile */
210typedef struct {
211  uint32_t sdp_handle;
212  uint8_t scn;
213} tBTA_AG_PROFILE;
214
215#if (BTM_WBS_INCLUDED == TRUE)
216typedef enum {
217  BTA_AG_SCO_MSBC_SETTINGS_T2 = 0, /* preferred/default when codec is mSBC */
218  BTA_AG_SCO_MSBC_SETTINGS_T1,
219} tBTA_AG_SCO_MSBC_SETTINGS;
220#endif
221
222/* type for each service control block */
223typedef struct {
224  char clip[BTA_AG_AT_MAX_LEN + 1];     /* number string used for CLIP */
225  uint16_t serv_handle[BTA_AG_NUM_IDX]; /* RFCOMM server handles */
226  tBTA_AG_AT_CB at_cb;                  /* AT command interpreter */
227  BD_ADDR peer_addr;                    /* peer bd address */
228  tSDP_DISCOVERY_DB* p_disc_db;         /* pointer to discovery database */
229  tBTA_SERVICE_MASK reg_services;       /* services specified in register API */
230  tBTA_SERVICE_MASK open_services;      /* services specified in open API */
231  uint16_t conn_handle;                 /* RFCOMM handle of connected service */
232  tBTA_SEC serv_sec_mask;               /* server security mask */
233  tBTA_SEC cli_sec_mask;                /* client security mask */
234  tBTA_AG_FEAT features;                /* features registered by application */
235  tBTA_AG_PEER_FEAT peer_features;      /* peer device features */
236  uint16_t peer_version;                /* profile version of peer device */
237  uint16_t hsp_version;                 /* HSP profile version */
238  uint16_t sco_idx;                     /* SCO handle */
239  bool in_use;                          /* scb in use */
240  bool dealloc;                         /* true if service shutting down */
241  bool clip_enabled;        /* set to true if HF enables CLIP reporting */
242  bool ccwa_enabled;        /* set to true if HF enables CCWA reporting */
243  bool cmer_enabled;        /* set to true if HF enables CMER reporting */
244  bool cmee_enabled;        /* set to true if HF enables CME ERROR reporting */
245  bool inband_enabled;      /* set to true if inband ring enabled */
246  bool svc_conn;            /* set to true when service level connection up */
247  uint8_t state;            /* state machine state */
248  uint8_t conn_service;     /* connected service */
249  uint8_t peer_scn;         /* peer scn */
250  uint8_t app_id;           /* application id */
251  uint8_t role;             /* initiator/acceptor role */
252  uint8_t post_sco;         /* action to perform after sco event */
253  uint8_t call_ind;         /* CIEV call indicator value */
254  uint8_t callsetup_ind;    /* CIEV callsetup indicator value */
255  uint8_t service_ind;      /* CIEV service indicator value */
256  uint8_t signal_ind;       /* CIEV signal indicator value */
257  uint8_t roam_ind;         /* CIEV roam indicator value */
258  uint8_t battchg_ind;      /* CIEV battery charge indicator value */
259  uint8_t callheld_ind;     /* CIEV call held indicator value */
260  bool retry_with_sco_only; /* indicator to try with SCO only when eSCO fails */
261  uint32_t bia_masked_out;  /* indicators HF does not want us to send */
262  alarm_t* collision_timer;
263  alarm_t* ring_timer;
264#if (BTM_WBS_INCLUDED == TRUE)
265  alarm_t* codec_negotiation_timer;
266  tBTA_AG_PEER_CODEC peer_codecs; /* codecs for eSCO supported by the peer */
267  tBTA_AG_PEER_CODEC sco_codec;   /* codec to be used for eSCO connection */
268  tBTA_AG_PEER_CODEC
269      inuse_codec;     /* codec being used for the current SCO connection */
270  bool codec_updated;  /* set to true whenever the app updates codec type */
271  bool codec_fallback; /* If sco nego fails for mSBC, fallback to CVSD */
272  tBTA_AG_SCO_MSBC_SETTINGS
273      codec_msbc_settings; /* settings to be used for the impending eSCO */
274#endif
275
276  tBTA_AG_HF_IND
277      peer_hf_indicators[BTA_AG_MAX_NUM_PEER_HF_IND]; /* Peer supported
278                                                  HF indicators */
279  tBTA_AG_HF_IND
280      local_hf_indicators[BTA_AG_MAX_NUM_LOCAL_HF_IND]; /* Local supported
281                                                    HF indicators */
282} tBTA_AG_SCB;
283
284/* type for sco data */
285typedef struct {
286  tBTM_ESCO_CONN_REQ_EVT_DATA conn_data; /* SCO data for pending conn request */
287  tBTA_AG_SCB* p_curr_scb; /* SCB associated with SCO connection */
288  tBTA_AG_SCB* p_xfer_scb; /* SCB associated with SCO transfer */
289  uint16_t cur_idx;        /* SCO handle */
290  uint8_t state;           /* SCO state variable */
291  bool param_updated;      /* if params were updated to non-default */
292  tBTM_ESCO_PARAMS params; /* ESCO parameters */
293} tBTA_AG_SCO_CB;
294
295/* type for AG control block */
296typedef struct {
297  tBTA_AG_SCB scb[BTA_AG_NUM_SCB];         /* service control blocks */
298  tBTA_AG_PROFILE profile[BTA_AG_NUM_IDX]; /* profile-specific data */
299  tBTA_AG_SCO_CB sco;                      /* SCO data */
300  tBTA_AG_CBACK* p_cback;                  /* application callback */
301  tBTA_AG_PARSE_MODE parse_mode;           /* parse/pass-through mode */
302} tBTA_AG_CB;
303
304/*****************************************************************************
305 *  Global data
306 ****************************************************************************/
307
308/* constant lookup tables */
309extern const uint16_t bta_ag_uuid[BTA_AG_NUM_IDX];
310extern const uint8_t bta_ag_sec_id[BTA_AG_NUM_IDX];
311extern const tBTA_AG_AT_CMD* bta_ag_at_tbl[BTA_AG_NUM_IDX];
312
313/* control block declaration */
314extern tBTA_AG_CB bta_ag_cb;
315
316/* config struct */
317extern tBTA_AG_CFG* p_bta_ag_cfg;
318extern const tBTA_AG_HF_IND bta_ag_local_hf_ind_cfg[];
319
320/*****************************************************************************
321 *  Function prototypes
322 ****************************************************************************/
323
324/* main functions */
325extern void bta_ag_scb_dealloc(tBTA_AG_SCB* p_scb);
326extern uint16_t bta_ag_scb_to_idx(tBTA_AG_SCB* p_scb);
327extern tBTA_AG_SCB* bta_ag_scb_by_idx(uint16_t idx);
328extern uint8_t bta_ag_service_to_idx(tBTA_SERVICE_MASK services);
329extern uint16_t bta_ag_idx_by_bdaddr(BD_ADDR peer_addr);
330extern bool bta_ag_other_scb_open(tBTA_AG_SCB* p_curr_scb);
331extern bool bta_ag_scb_open(tBTA_AG_SCB* p_curr_scb);
332extern tBTA_AG_SCB* bta_ag_get_other_idle_scb(tBTA_AG_SCB* p_curr_scb);
333extern void bta_ag_sm_execute(tBTA_AG_SCB* p_scb, uint16_t event,
334                              tBTA_AG_DATA* p_data);
335extern bool bta_ag_hdl_event(BT_HDR* p_msg);
336extern void bta_ag_collision_cback(tBTA_SYS_CONN_STATUS status, uint8_t id,
337                                   uint8_t app_id, BD_ADDR peer_addr);
338extern void bta_ag_resume_open(tBTA_AG_SCB* p_scb);
339
340/* SDP functions */
341extern bool bta_ag_add_record(uint16_t service_uuid, char* p_service_name,
342                              uint8_t scn, tBTA_AG_FEAT features,
343                              uint32_t sdp_handle);
344extern void bta_ag_create_records(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
345extern void bta_ag_del_records(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
346extern bool bta_ag_sdp_find_attr(tBTA_AG_SCB* p_scb, tBTA_SERVICE_MASK service);
347extern void bta_ag_do_disc(tBTA_AG_SCB* p_scb, tBTA_SERVICE_MASK service);
348extern void bta_ag_free_db(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
349
350/* RFCOMM functions */
351extern void bta_ag_start_servers(tBTA_AG_SCB* p_scb,
352                                 tBTA_SERVICE_MASK services);
353extern void bta_ag_close_servers(tBTA_AG_SCB* p_scb,
354                                 tBTA_SERVICE_MASK services);
355extern bool bta_ag_is_server_closed(tBTA_AG_SCB* p_scb);
356extern void bta_ag_rfc_do_close(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
357extern void bta_ag_rfc_do_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
358
359/* SCO functions */
360extern bool bta_ag_sco_is_open(tBTA_AG_SCB* p_scb);
361extern bool bta_ag_sco_is_opening(tBTA_AG_SCB* p_scb);
362extern void bta_ag_sco_conn_rsp(tBTA_AG_SCB* p_scb,
363                                tBTM_ESCO_CONN_REQ_EVT_DATA* p_data);
364
365/* AT command functions */
366extern void bta_ag_at_hsp_cback(tBTA_AG_SCB* p_scb, uint16_t cmd,
367                                uint8_t arg_type, char* p_arg, int16_t int_arg);
368extern void bta_ag_at_hfp_cback(tBTA_AG_SCB* p_scb, uint16_t cmd,
369                                uint8_t arg_type, char* p_arg, int16_t int_arg);
370extern void bta_ag_at_err_cback(tBTA_AG_SCB* p_scb, bool unknown, char* p_arg);
371extern bool bta_ag_inband_enabled(tBTA_AG_SCB* p_scb);
372extern void bta_ag_send_call_inds(tBTA_AG_SCB* p_scb, tBTA_AG_RES result);
373
374/* Action functions */
375extern void bta_ag_register(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
376extern void bta_ag_deregister(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
377extern void bta_ag_start_dereg(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
378extern void bta_ag_start_close(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
379extern void bta_ag_start_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
380extern void bta_ag_disc_int_res(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
381extern void bta_ag_disc_acp_res(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
382extern void bta_ag_disc_fail(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
383extern void bta_ag_open_fail(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
384extern void bta_ag_rfc_fail(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
385extern void bta_ag_rfc_close(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
386extern void bta_ag_rfc_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
387extern void bta_ag_rfc_acp_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
388extern void bta_ag_rfc_data(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
389extern void bta_ag_sco_listen(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
390extern void bta_ag_sco_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
391extern void bta_ag_sco_close(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
392#if (BTM_WBS_INCLUDED == TRUE)
393extern void bta_ag_sco_codec_nego(tBTA_AG_SCB* p_scb, bool result);
394extern void bta_ag_codec_negotiate(tBTA_AG_SCB* p_scb);
395#endif
396extern void bta_ag_sco_shutdown(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
397extern void bta_ag_sco_conn_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
398extern void bta_ag_sco_conn_close(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
399extern void bta_ag_post_sco_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
400extern void bta_ag_post_sco_close(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
401extern void bta_ag_svc_conn_open(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
402extern void bta_ag_result(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
403extern void bta_ag_setcodec(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
404#if (BTM_WBS_INCLUDED == TRUE)
405extern void bta_ag_send_bcs(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
406#endif
407extern void bta_ag_send_ring(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
408extern void bta_ag_ci_sco_data(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
409extern void bta_ag_set_esco_param(bool set_reset, tBTM_ESCO_PARAMS* param);
410extern void bta_ag_ci_rx_data(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
411extern void bta_ag_rcvd_slc_ready(tBTA_AG_SCB* p_scb, tBTA_AG_DATA* p_data);
412
413#endif /* BTA_AG_INT_H */
414