1 /******************************************************************************
2  *
3  *  Copyright (C) 1999-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 file contains definitions internal to the RFC unit
22  *
23  *****************************************************************************/
24 
25 #ifndef RFC_INT_H
26 #define RFC_INT_H
27 
28 #include "stack/l2c_api.h"
29 #include "port_int.h"
30 
31 /*
32 ** Define RFCOMM result codes
33 */
34 #define RFCOMM_SUCCESS          0
35 #define RFCOMM_ERROR            1
36 #define RFCOMM_LOW_RESOURCES    2
37 #define RFCOMM_TRY_LATER        3
38 
39 #define RFCOMM_USER_ERR         111
40 #define RFCOMM_SECURITY_ERR     112
41 
42 /*
43 ** Define max and min RFCOMM MTU (N1)
44 */
45 #define RFCOMM_MIN_MTU          23
46 #define RFCOMM_MAX_MTU          32767
47 
48 extern void RFCOMM_StartReq (tRFC_MCB *p_mcb);
49 extern void RFCOMM_StartRsp (tRFC_MCB *p_mcb, UINT16 result);
50 
51 extern void RFCOMM_DlcEstablishReq (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu);
52 extern void RFCOMM_DlcEstablishRsp (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu, UINT16 result);
53 
54 extern void RFCOMM_DataReq (tRFC_MCB *p_mcb, UINT8 dlci, BT_HDR *p_buf);
55 
56 extern void RFCOMM_DlcReleaseReq (tRFC_MCB *p_mcb, UINT8 dlci);
57 
58 extern void RFCOMM_ParNegReq (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu);
59 extern void RFCOMM_ParNegRsp (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu, UINT8 cl, UINT8 k);
60 
61 extern void RFCOMM_TestReq (UINT8 *p_data, UINT16 len);
62 
63 #define RFCOMM_FLOW_STATE_DISABLE       0
64 #define RFCOMM_FLOW_STATE_ENABLE        1
65 
66 extern void RFCOMM_FlowReq (tRFC_MCB *p_mcb, UINT8 dlci, UINT8 state);
67 
68 extern void RFCOMM_PortNegReq (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_STATE *p_pars);
69 extern void RFCOMM_PortNegRsp (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_STATE *p_pars, UINT16 param_mask);
70 
71 extern void RFCOMM_ControlReq (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_CTRL *p_pars);
72 extern void RFCOMM_ControlRsp (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_CTRL *p_pars);
73 
74 extern void RFCOMM_LineStatusReq (tRFC_MCB *p_mcb, UINT8 dlci, UINT8 line_status);
75 /*
76 ** Define logical struct used for sending and decoding MX frames
77 */
78 typedef struct {
79     UINT8   dlci;
80     UINT8   type;
81     UINT8   cr;
82     UINT8   ea;
83     UINT8   pf;
84     UINT8   credit;
85 
86     union {
87         struct {
88             UINT8 dlci;
89             UINT8 frame_type;
90             UINT8 conv_layer;
91             UINT8 priority;
92             UINT8 t1;
93             UINT16 mtu;
94             UINT8 n2;
95             UINT8 k;
96         } pn;
97         struct {
98             UINT8   *p_data;
99             UINT16  data_len;
100         } test;
101         struct {
102             UINT8 dlci;
103             UINT8 signals;
104             UINT8 break_present;
105             UINT8 break_duration;
106         } msc;
107         struct {
108             UINT8 ea;
109             UINT8 cr;
110             UINT8 type;
111         } nsc;
112         struct {
113             UINT8 dlci;
114             UINT8 is_request;
115             UINT8 baud_rate;
116             UINT8 byte_size;
117             UINT8 stop_bits;
118             UINT8 parity;
119             UINT8 parity_type;
120             UINT8 fc_type;
121             UINT8 xon_char;
122             UINT8 xoff_char;
123             UINT16 param_mask;
124         } rpn;
125         struct {
126             UINT8 dlci;
127             UINT8 line_status;
128         } rls;
129     } u;
130 } MX_FRAME;
131 
132 #define LINE_STATUS_NO_ERROR       0x00
133 #define LINE_STATUS_OVERRUN        0x02  /* Receive Overrun Error   */
134 #define LINE_STATUS_RXPARITY       0x04  /* Receive Parity Error    */
135 #define LINE_STATUS_FRAME          0x08  /* Receive Framing error   */
136 #define LINE_STATUS_FAILED         0x10  /* Connection Failed       */
137 
138 /*
139 ** Define states and events for the RFC multiplexer state machine
140 */
141 #define RFC_MX_STATE_IDLE           0
142 #define RFC_MX_STATE_WAIT_CONN_CNF  1
143 #define RFC_MX_STATE_CONFIGURE      2
144 #define RFC_MX_STATE_SABME_WAIT_UA  3
145 #define RFC_MX_STATE_WAIT_SABME     4
146 #define RFC_MX_STATE_CONNECTED      5
147 #define RFC_MX_STATE_DISC_WAIT_UA   6
148 
149 /*
150 ** Define port states
151 */
152 #define RFC_STATE_CLOSED                0
153 #define RFC_STATE_SABME_WAIT_UA         1
154 #define RFC_STATE_ORIG_WAIT_SEC_CHECK   2
155 #define RFC_STATE_TERM_WAIT_SEC_CHECK   3
156 #define RFC_STATE_OPENED                4
157 #define RFC_STATE_DISC_WAIT_UA          5
158 
159 /*
160 ** Events that can be received by multiplexer as well as port state machines
161 */
162 #define RFC_EVENT_SABME                 0
163 #define RFC_EVENT_UA                    1
164 #define RFC_EVENT_DM                    2
165 #define RFC_EVENT_DISC                  3
166 #define RFC_EVENT_UIH                   4
167 #define RFC_EVENT_TIMEOUT               5
168 #define RFC_EVENT_BAD_FRAME             50
169 /*
170 ** Multiplexer events
171 */
172 #define RFC_MX_EVENT_START_REQ          6
173 #define RFC_MX_EVENT_START_RSP          7
174 #define RFC_MX_EVENT_CLOSE_REQ          8
175 #define RFC_MX_EVENT_CONN_CNF           9
176 #define RFC_MX_EVENT_CONN_IND           10
177 #define RFC_MX_EVENT_CONF_CNF           11
178 #define RFC_MX_EVENT_CONF_IND           12
179 #define RFC_MX_EVENT_QOS_VIOLATION_IND  13
180 #define RFC_MX_EVENT_DISC_IND           14
181 #define RFC_MX_EVENT_TEST_CMD           15
182 #define RFC_MX_EVENT_TEST_RSP           16
183 #define RFC_MX_EVENT_FCON_CMD           17
184 #define RFC_MX_EVENT_FCOFF_CMD          18
185 #define RFC_MX_EVENT_NSC                19
186 #define RFC_MX_EVENT_NSC_RSP            20
187 
188 /*
189 ** Port events
190 */
191 #define RFC_EVENT_OPEN                  9
192 #define RFC_EVENT_ESTABLISH_RSP         11
193 #define RFC_EVENT_CLOSE                 12
194 #define RFC_EVENT_CLEAR                 13
195 #define RFC_EVENT_DATA                  14
196 #define RFC_EVENT_SEC_COMPLETE          15
197 
198 // btla-specific ++
199 #define RFC_T1_TIMEOUT                  20   /* seconds to wait for reply with Poll bit */
200 #define RFC_PORT_T1_TIMEOUT             60   /* seconds to wait for reply with Poll bit other than MX */
201 #define RFC_T2_TIMEOUT                  20   /* timeout to wait for Mx UIH */
202 // btla-specific --
203 #define RFC_DISC_TIMEOUT                3    /* If something goes wrong and we send DISC we should not wait for min */
204 #define RFC_CLOSE_TIMEOUT               10
205 #define RFCOMM_CONN_TIMEOUT            120   /* first connection to be established on Mx */
206 
207 
208 /* Define RFComm control block
209 */
210 typedef struct {
211     MX_FRAME  rx_frame;
212     tL2CAP_APPL_INFO  reg_info;              /* L2CAP Registration info */
213     tRFC_MCB *p_rfc_lcid_mcb[MAX_L2CAP_CHANNELS];     /* MCB based on the L2CAP's lcid */
214     BOOLEAN   peer_rx_disabled;              /* If TRUE peer sent FCOFF */
215     UINT8     last_mux;                      /* Last mux allocated */
216     UINT8     last_port;                     /* Last port allocated */
217 } tRFCOMM_CB;
218 
219 /* Main Control Block for the RFCOMM Layer (PORT and RFC) */
220 typedef struct {
221     tRFCOMM_CB  rfc;
222     tPORT_CB    port;
223     UINT8       trace_level;
224 } tRFC_CB;
225 
226 
227 #if RFC_DYNAMIC_MEMORY == FALSE
228 extern tRFC_CB  rfc_cb;
229 #else
230 extern tRFC_CB *rfc_cb_ptr;
231 #define rfc_cb (*rfc_cb_ptr)
232 #endif
233 
234 /* Timer running on the multiplexor channel while no DLCI connection is opened */
235 #define RFC_MCB_INIT_INACT_TIMER    60  /* in seconds */
236 
237 /* Timer running on the multiplexor channel after last DLCI is released */
238 #define RFC_MCB_RELEASE_INACT_TIMER 2   /* in seconds */
239 
240 /*
241 ** Define RFCOMM frame processing errors
242 */
243 #define RFCOMM_ERR_BAD_SABME        1
244 #define RFCOMM_ERR_BAD_UA           2
245 #define RFCOMM_ERR_BAD_DM           3
246 #define RFCOMM_ERR_BAD_DISC         4
247 #define RFCOMM_ERR_BAD_UIH          5
248 
249 #ifdef RFCOMM_PRECALC_FCS
250 
251 #define RFCOMM_SABME_FCS(p_data, cr, dlci) rfc_sabme_fcs[cr][dlci]
252 #define RFCOMM_UA_FCS(p_data, cr, dlci)    rfc_ua_fcs[cr][dlci]
253 #define RFCOMM_DM_FCS(p_data, cr, dlci)    rfc_dm_fcs[cr][dlci]
254 #define RFCOMM_DISC_FCS(p_data, cr, dlci)  rfc_disc_fcs[cr][dlci]
255 #define RFCOMM_UIH_FCS(p_data, dlci)       rfc_uih_fcs[dlci]
256 
257 #else
258 
259 extern  UINT8 rfc_calc_fcs (UINT16 len, UINT8 *p);
260 
261 #define RFCOMM_SABME_FCS(p_data, cr, dlci) rfc_calc_fcs(3, p_data)
262 #define RFCOMM_UA_FCS(p_data, cr, dlci)    rfc_calc_fcs(3, p_data)
263 #define RFCOMM_DM_FCS(p_data, cr, dlci)    rfc_calc_fcs(3, p_data)
264 #define RFCOMM_DISC_FCS(p_data, cr, dlci)  rfc_calc_fcs(3, p_data)
265 #define RFCOMM_UIH_FCS(p_data, dlci)       rfc_calc_fcs(2, p_data)
266 
267 #endif
268 
269 
270 #ifdef __cplusplus
271 extern "C" {
272 #endif
273 
274 extern void rfc_mx_sm_execute (tRFC_MCB *p_mcb, UINT16 event, void *p_data);
275 
276 /*
277 ** Functions provided by the rfc_port_fsm.c
278 */
279 extern void rfc_port_sm_execute (tPORT *p_port, UINT16 event, void *p_data);
280 
281 
282 extern void rfc_process_pn (tRFC_MCB *p_rfc_mcb, BOOLEAN is_command, MX_FRAME *p_frame);
283 extern void rfc_process_msc (tRFC_MCB *p_rfc_mcb, BOOLEAN is_command, MX_FRAME *p_frame);
284 extern void rfc_process_rpn (tRFC_MCB *p_rfc_mcb, BOOLEAN is_command, BOOLEAN is_request, MX_FRAME *p_frame);
285 extern void rfc_process_rls (tRFC_MCB *p_rfc_mcb, BOOLEAN is_command, MX_FRAME *p_frame);
286 extern void rfc_process_nsc (tRFC_MCB *p_rfc_mcb, MX_FRAME *p_frame);
287 extern void rfc_process_test_rsp (tRFC_MCB *p_rfc_mcb, BT_HDR *p_buf);
288 extern void rfc_process_fcon (tRFC_MCB *p_rfc_mcb, BOOLEAN is_command);
289 extern void rfc_process_fcoff (tRFC_MCB *p_rfc_mcb, BOOLEAN is_command);
290 extern void rfc_process_l2cap_congestion (tRFC_MCB *p_mcb, BOOLEAN is_congested);
291 
292 /*
293 ** Functions provided by the rfc_utils.c
294 */
295 tRFC_MCB  *rfc_alloc_multiplexer_channel (BD_ADDR bd_addr, BOOLEAN is_initiator);
296 extern void      rfc_release_multiplexer_channel (tRFC_MCB *p_rfc_mcb);
297 extern void      rfc_timer_start (tRFC_MCB *p_rfc_mcb, UINT16 timeout);
298 extern void      rfc_timer_stop (tRFC_MCB *p_rfc_mcb);
299 extern void      rfc_timer_free (tRFC_MCB *p_rfc_mcb);
300 extern void      rfc_port_timer_start (tPORT *p_port, UINT16 tout);
301 extern void      rfc_port_timer_stop (tPORT *p_port);
302 extern void      rfc_port_timer_free (tPORT *p_port);
303 
304 BOOLEAN   rfc_check_uih_fcs (UINT8 dlci, UINT8 received_fcs);
305 BOOLEAN   rfc_check_fcs (UINT16 len, UINT8 *p, UINT8 received_fcs);
306 tRFC_MCB  *rfc_find_lcid_mcb (UINT16 lcid);
307 extern void      rfc_save_lcid_mcb (tRFC_MCB *p_rfc_mcb, UINT16 lcid);
308 extern void      rfc_check_mcb_active (tRFC_MCB *p_mcb);
309 extern void      rfc_port_closed (tPORT *p_port);
310 extern void      rfc_sec_check_complete (BD_ADDR bd_addr, tBT_TRANSPORT transport, void *p_ref_data, UINT8 res);
311 extern void      rfc_inc_credit (tPORT *p_port, UINT8 credit);
312 extern void      rfc_dec_credit (tPORT *p_port);
313 extern void      rfc_check_send_cmd(tRFC_MCB *p_mcb, BT_HDR *p_buf);
314 
315 /*
316 ** Functions provided by the rfc_ts_frames.c
317 */
318 extern void     rfc_send_sabme (tRFC_MCB *p_rfc_mcb, UINT8 dlci);
319 extern void     rfc_send_ua (tRFC_MCB *p_rfc_mcb, UINT8 dlci);
320 extern void     rfc_send_dm (tRFC_MCB *p_rfc_mcb, UINT8 dlci, BOOLEAN pf);
321 extern void     rfc_send_disc (tRFC_MCB *p_rfc_mcb, UINT8 dlci);
322 extern void     rfc_send_pn (tRFC_MCB *p_mcb, UINT8 dlci, BOOLEAN is_command, UINT16 mtu,
323                              UINT8 cl, UINT8 k);
324 extern void     rfc_send_test (tRFC_MCB *p_rfc_mcb, BOOLEAN is_command, BT_HDR *p_buf);
325 extern void     rfc_send_msc (tRFC_MCB *p_mcb, UINT8 dlci, BOOLEAN is_command,
326                               tPORT_CTRL *p_pars);
327 extern void     rfc_send_rls (tRFC_MCB *p_mcb, UINT8 dlci, BOOLEAN is_command, UINT8 status);
328 extern void     rfc_send_rpn (tRFC_MCB *p_mcb, UINT8 dlci, BOOLEAN is_command,
329                               tPORT_STATE *p_pars, UINT16 mask);
330 extern void     rfc_send_fcon (tRFC_MCB *p_mcb, BOOLEAN is_command);
331 extern void     rfc_send_fcoff (tRFC_MCB *p_mcb, BOOLEAN is_command);
332 extern void     rfc_send_buf_uih (tRFC_MCB *p_rfc_mcb, UINT8 dlci, BT_HDR *p_buf);
333 extern void     rfc_send_credit(tRFC_MCB *p_mcb, UINT8 dlci, UINT8 credit);
334 extern void     rfc_process_mx_message (tRFC_MCB *p_rfc_mcb, BT_HDR *p_buf);
335 extern UINT8    rfc_parse_data (tRFC_MCB *p_rfc_mcb, MX_FRAME *p_frame, BT_HDR *p_buf);
336 
337 /*
338 ** Functions provided by the rfc_disp.c
339 */
340 
341 
342 
343 /* Call back functions from RFCOMM */
344 extern void rfcomm_l2cap_if_init (void);
345 
346 extern void PORT_StartInd (tRFC_MCB *p_mcb);
347 extern void PORT_StartCnf (tRFC_MCB *p_mcb, UINT16 result);
348 
349 extern void PORT_CloseInd (tRFC_MCB *p_mcb);
350 extern void Port_TimeOutCloseMux (tRFC_MCB *p_mcb);
351 
352 extern void PORT_DlcEstablishInd (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu);
353 extern void PORT_DlcEstablishCnf (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu, UINT16 result);
354 
355 extern void PORT_DataInd (tRFC_MCB *p_mcb, UINT8 dlci, BT_HDR *p_buf);
356 
357 extern void PORT_DlcReleaseInd (tRFC_MCB *p_mcb, UINT8 dlci);
358 
359 extern void PORT_ParNegInd (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu, UINT8 cl, UINT8 k);
360 extern void PORT_ParNegCnf (tRFC_MCB *p_mcb, UINT8 dlci, UINT16 mtu, UINT8 cl, UINT8 k);
361 
362 extern void PORT_TestCnf (tRFC_MCB *p_mcb, UINT8 *p_data, UINT16 len);
363 
364 extern void PORT_FlowInd (tRFC_MCB *p_mcb, UINT8 dlci, BOOLEAN fc);
365 
366 extern void PORT_PortNegInd (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_STATE *p_pars, UINT16 param_mask);
367 extern void PORT_PortNegCnf (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_STATE *p_pars, UINT16 result);
368 
369 extern void PORT_ControlInd (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_CTRL *p_pars);
370 extern void PORT_ControlCnf (tRFC_MCB *p_mcb, UINT8 dlci, tPORT_CTRL *p_pars);
371 
372 extern void PORT_LineStatusInd (tRFC_MCB *p_mcb, UINT8 dlci, UINT8 line_status);
373 
374 #ifdef __cplusplus
375 }
376 #endif
377 
378 #endif
379