• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 file contains interfaces which are internal to AVCTP.
22  *
23  ******************************************************************************/
24 #ifndef AVCT_INT_H
25 #define AVCT_INT_H
26 
27 #include "gki.h"
28 #include "avct_api.h"
29 #include "avct_defs.h"
30 #include "l2c_api.h"
31 
32 /*****************************************************************************
33 ** constants
34 *****************************************************************************/
35 
36 /* lcb state machine events */
37 enum {
38     AVCT_LCB_UL_BIND_EVT,
39     AVCT_LCB_UL_UNBIND_EVT,
40     AVCT_LCB_UL_MSG_EVT,
41     AVCT_LCB_INT_CLOSE_EVT,
42     AVCT_LCB_LL_OPEN_EVT,
43     AVCT_LCB_LL_CLOSE_EVT,
44     AVCT_LCB_LL_MSG_EVT,
45     AVCT_LCB_LL_CONG_EVT
46 };
47 
48 
49 /* "states" used for L2CAP channel */
50 #define AVCT_CH_IDLE    0       /* No connection */
51 #define AVCT_CH_CONN    1       /* Waiting for connection confirm */
52 #define AVCT_CH_CFG     2       /* Waiting for configuration complete */
53 #define AVCT_CH_OPEN    3       /* Channel opened */
54 
55 /* "no event" indicator used by ccb dealloc */
56 #define AVCT_NO_EVT     0xFF
57 
58 /*****************************************************************************
59 ** data types
60 *****************************************************************************/
61 /* sub control block type - common data members for tAVCT_LCB and tAVCT_BCB */
62 typedef struct {
63     UINT16              peer_mtu;	    /* peer l2c mtu */
64     UINT16              ch_result;      /* L2CAP connection result value */
65     UINT16              ch_lcid;        /* L2CAP channel LCID */
66     UINT8               allocated;      /* 0, not allocated. index+1, otherwise. */
67     UINT8               state;          /* The state machine state */
68     UINT8               ch_state;       /* L2CAP channel state */
69     UINT8               ch_flags;       /* L2CAP configuration flags */
70 } tAVCT_SCB;
71 
72 /* link control block type */
73 typedef struct {
74     UINT16              peer_mtu;	    /* peer l2c mtu */
75     UINT16              ch_result;      /* L2CAP connection result value */
76     UINT16              ch_lcid;        /* L2CAP channel LCID */
77     UINT8               allocated;      /* 0, not allocated. index+1, otherwise. */
78     UINT8               state;          /* The state machine state */
79     UINT8               ch_state;       /* L2CAP channel state */
80     UINT8               ch_flags;       /* L2CAP configuration flags */
81     BT_HDR              *p_rx_msg;      /* Message being reassembled */
82     UINT16              conflict_lcid;  /* L2CAP channel LCID */
83     BD_ADDR             peer_addr;      /* BD address of peer */
84     BUFFER_Q            tx_q;           /* Transmit data buffer queue       */
85     BOOLEAN             cong;           /* TRUE, if congested */
86 } tAVCT_LCB;
87 
88 /* browse control block type */
89 typedef struct {
90     UINT16              peer_mtu;	    /* peer l2c mtu */
91     UINT16              ch_result;      /* L2CAP connection result value */
92     UINT16              ch_lcid;        /* L2CAP channel LCID */
93     UINT8               allocated;      /* 0, not allocated. index+1, otherwise. */
94     UINT8               state;          /* The state machine state */
95     UINT8               ch_state;       /* L2CAP channel state */
96     UINT8               ch_flags;       /* L2CAP configuration flags */
97     BT_HDR              *p_tx_msg;      /* Message to be sent - in case the browsing channel is not open when MsgReg is called */
98     UINT8               ch_close;       /* CCB index+1, if CCB initiated channel close */
99 } tAVCT_BCB;
100 
101 #define AVCT_ALOC_LCB       0x01
102 #define AVCT_ALOC_BCB       0x02
103 /* connection control block */
104 typedef struct {
105     tAVCT_CC            cc;                 /* parameters from connection creation */
106     tAVCT_LCB           *p_lcb;             /* Associated LCB */
107     tAVCT_BCB           *p_bcb;             /* associated BCB */
108     BOOLEAN             ch_close;           /* Whether CCB initiated channel close */
109     UINT8               allocated;          /* Whether LCB/BCB is allocated */
110 } tAVCT_CCB;
111 
112 /* data type associated with UL_MSG_EVT */
113 typedef struct {
114     BT_HDR                  *p_buf;
115     tAVCT_CCB               *p_ccb;
116     UINT8                   label;
117     UINT8                   cr;
118 } tAVCT_UL_MSG;
119 
120 /* union associated with lcb state machine events */
121 typedef union {
122     tAVCT_UL_MSG            ul_msg;
123     BT_HDR                  *p_buf;
124     tAVCT_CCB               *p_ccb;
125     UINT16                  result;
126     BOOLEAN                 cong;
127     UINT8                   err_code;
128 } tAVCT_LCB_EVT;
129 
130 /* Control block for AVCT */
131 typedef struct {
132     tAVCT_LCB       lcb[AVCT_NUM_LINKS];    /* link control blocks */
133     tAVCT_BCB       bcb[AVCT_NUM_LINKS];    /* browse control blocks */
134     tAVCT_CCB       ccb[AVCT_NUM_CONN];     /* connection control blocks */
135     UINT16          mtu;                    /* our L2CAP MTU */
136     UINT16          mtu_br;                 /* our L2CAP MTU for the Browsing channel */
137     UINT8           trace_level;            /* trace level */
138 } tAVCT_CB;
139 
140 /*****************************************************************************
141 ** function declarations
142 *****************************************************************************/
143 
144 /* LCB function declarations */
145 extern void avct_lcb_event(tAVCT_LCB *p_lcb, UINT8 event, tAVCT_LCB_EVT *p_data);
146 #if (AVCT_BROWSE_INCLUDED == TRUE)
147 extern void avct_bcb_event(tAVCT_BCB *p_bcb, UINT8 event, tAVCT_LCB_EVT *p_data);
148 extern void avct_close_bcb(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
149 extern tAVCT_LCB *avct_lcb_by_bcb(tAVCT_BCB *p_bcb);
150 extern tAVCT_BCB *avct_bcb_by_lcb(tAVCT_LCB *p_lcb);
151 extern BOOLEAN avct_bcb_last_ccb(tAVCT_BCB *p_bcb, tAVCT_CCB *p_ccb_last);
152 extern tAVCT_BCB *avct_bcb_by_lcid(UINT16 lcid);
153 #endif
154 extern tAVCT_LCB *avct_lcb_by_bd(BD_ADDR bd_addr);
155 extern tAVCT_LCB *avct_lcb_alloc(BD_ADDR bd_addr);
156 extern void avct_lcb_dealloc(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
157 extern tAVCT_LCB *avct_lcb_by_lcid(UINT16 lcid);
158 extern tAVCT_CCB *avct_lcb_has_pid(tAVCT_LCB *p_lcb, UINT16 pid);
159 extern BOOLEAN avct_lcb_last_ccb(tAVCT_LCB *p_lcb, tAVCT_CCB *p_ccb_last);
160 
161 /* LCB action functions */
162 extern void avct_lcb_chnl_open(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
163 extern void avct_lcb_unbind_disc(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
164 extern void avct_lcb_open_ind(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
165 extern void avct_lcb_open_fail(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
166 extern void avct_lcb_close_ind(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
167 extern void avct_lcb_close_cfm(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
168 extern void avct_lcb_bind_conn(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
169 extern void avct_lcb_chk_disc(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
170 extern void avct_lcb_chnl_disc(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
171 extern void avct_lcb_bind_fail(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
172 extern void avct_lcb_cong_ind(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
173 extern void avct_lcb_discard_msg(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
174 extern void avct_lcb_send_msg(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
175 extern void avct_lcb_msg_ind(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
176 extern void avct_lcb_free_msg_ind(tAVCT_LCB *p_lcb, tAVCT_LCB_EVT *p_data);
177 
178 /* BCB action functions */
179 #if (AVCT_BROWSE_INCLUDED == TRUE)
180 typedef void (*tAVCT_BCB_ACTION)(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
181 extern void avct_bcb_chnl_open(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
182 extern void avct_bcb_unbind_disc(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
183 extern void avct_bcb_open_ind(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
184 extern void avct_bcb_open_fail(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
185 extern void avct_bcb_close_ind(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
186 extern void avct_bcb_close_cfm(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
187 extern void avct_bcb_bind_conn(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
188 extern void avct_bcb_chk_disc(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
189 extern void avct_bcb_chnl_disc(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
190 extern void avct_bcb_bind_fail(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
191 extern void avct_bcb_cong_ind(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
192 extern void avct_bcb_discard_msg(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
193 extern void avct_bcb_send_msg(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
194 extern void avct_bcb_msg_ind(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
195 extern void avct_bcb_free_msg_ind(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
196 
197 extern void avct_bcb_dealloc(tAVCT_BCB *p_bcb, tAVCT_LCB_EVT *p_data);
198 
199 extern const tAVCT_BCB_ACTION avct_bcb_action[];
200 extern const UINT8 avct_lcb_pkt_type_len[];
201 extern const tL2CAP_FCR_OPTS avct_l2c_br_fcr_opts_def;
202 #endif
203 
204 /* CCB function declarations */
205 extern tAVCT_CCB *avct_ccb_alloc(tAVCT_CC *p_cc);
206 extern void avct_ccb_dealloc(tAVCT_CCB *p_ccb, UINT8 event, UINT16 result, BD_ADDR bd_addr);
207 extern UINT8 avct_ccb_to_idx(tAVCT_CCB *p_ccb);
208 extern tAVCT_CCB *avct_ccb_by_idx(UINT8 idx);
209 
210 
211 /*****************************************************************************
212 ** global data
213 *****************************************************************************/
214 #ifdef __cplusplus
215 extern "C"
216 {
217 #endif
218 
219 /* Main control block */
220 #if AVCT_DYNAMIC_MEMORY == FALSE
221 extern tAVCT_CB avct_cb;
222 #else
223 extern tAVCT_CB *avct_cb_ptr;
224 #define avct_cb (*avct_cb_ptr)
225 #endif
226 
227 /* L2CAP callback registration structure */
228 extern const tL2CAP_APPL_INFO avct_l2c_appl;
229 #if (AVCT_BROWSE_INCLUDED == TRUE)
230 extern const tL2CAP_APPL_INFO avct_l2c_br_appl;
231 #endif
232 
233 #ifdef __cplusplus
234 }
235 #endif
236 
237 #endif /* AVCT_INT_H */
238