l2cdefs.h revision 5738f83aeb59361a0a2eda2460113f6dc9194271
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#ifndef L2CDEFS_H
20#define L2CDEFS_H
21
22/* L2CAP command codes
23*/
24#define L2CAP_CMD_REJECT                    0x01
25#define L2CAP_CMD_CONN_REQ                  0x02
26#define L2CAP_CMD_CONN_RSP                  0x03
27#define L2CAP_CMD_CONFIG_REQ                0x04
28#define L2CAP_CMD_CONFIG_RSP                0x05
29#define L2CAP_CMD_DISC_REQ                  0x06
30#define L2CAP_CMD_DISC_RSP                  0x07
31#define L2CAP_CMD_ECHO_REQ                  0x08
32#define L2CAP_CMD_ECHO_RSP                  0x09
33#define L2CAP_CMD_INFO_REQ                  0x0A
34#define L2CAP_CMD_INFO_RSP                  0x0B
35#define L2CAP_CMD_AMP_CONN_REQ              0x0C
36#define L2CAP_CMD_AMP_CONN_RSP              0x0D
37#define L2CAP_CMD_AMP_MOVE_REQ              0x0E
38#define L2CAP_CMD_AMP_MOVE_RSP              0x0F
39#define L2CAP_CMD_AMP_MOVE_CFM              0x10
40#define L2CAP_CMD_AMP_MOVE_CFM_RSP          0x11
41#define L2CAP_CMD_BLE_UPDATE_REQ            0x12
42#define L2CAP_CMD_BLE_UPDATE_RSP            0x13
43
44
45/* Define some packet and header lengths
46*/
47#define L2CAP_PKT_OVERHEAD      4           /* Length and CID                       */
48#define L2CAP_CMD_OVERHEAD      4           /* Cmd code, Id and length              */
49#define L2CAP_CMD_REJECT_LEN    2           /* Reason (data is optional)            */
50#define L2CAP_CONN_REQ_LEN      4           /* PSM and source CID                   */
51#define L2CAP_CONN_RSP_LEN      8           /* Dest CID, source CID, reason, status */
52#define L2CAP_CONFIG_REQ_LEN    4           /* Dest CID, flags (data is optional)   */
53#define L2CAP_CONFIG_RSP_LEN    6           /* Dest CID, flags, result,data optional*/
54#define L2CAP_DISC_REQ_LEN      4           /* Dest CID, source CID                 */
55#define L2CAP_DISC_RSP_LEN      4           /* Dest CID, source CID                 */
56#define L2CAP_ECHO_REQ_LEN      0           /* Data is optional                     */
57#define L2CAP_ECHO_RSP_LEN      0           /* Data is optional                     */
58#define L2CAP_INFO_REQ_LEN      2           /* Info type                            */
59#define L2CAP_INFO_RSP_LEN      4           /* Info type, result (data is optional) */
60#define L2CAP_BCST_OVERHEAD     2           /* Additional broadcast packet overhead */
61#define L2CAP_UCD_OVERHEAD      2           /* Additional connectionless packet overhead */
62
63#define L2CAP_AMP_CONN_REQ_LEN  5           /* PSM, CID, and remote controller ID   */
64#define L2CAP_AMP_MOVE_REQ_LEN  3           /* CID and remote controller ID         */
65#define L2CAP_AMP_MOVE_RSP_LEN  4           /* CID and result                       */
66#define L2CAP_AMP_MOVE_CFM_LEN  4           /* CID and result                       */
67#define L2CAP_AMP_MOVE_CFM_RSP_LEN  2       /* CID                                  */
68
69#define L2CAP_CMD_BLE_UPD_REQ_LEN   8       /* Min and max interval, latency, tout  */
70#define L2CAP_CMD_BLE_UPD_RSP_LEN   2       /* Result                               */
71
72
73/* Define the packet boundary flags
74*/
75#if (L2CAP_NON_FLUSHABLE_PB_INCLUDED == TRUE)
76#define L2CAP_PKT_START_FLUSHABLE       2
77#define L2CAP_PKT_START_NON_FLUSHABLE   0
78#endif
79#define L2CAP_COMPLETE_AMP_PKT          3       /* complete L2CAP packet on AMP HCI */
80#define L2CAP_PKT_START                 2
81#define L2CAP_PKT_CONTINUE              1
82#define L2CAP_MASK_FLAG            0x0FFF
83#define L2CAP_PKT_TYPE_SHIFT            12
84#define L2CAP_PKT_TYPE_MASK             3
85
86
87/* Define the L2CAP connection result codes
88*/
89#define L2CAP_CONN_OK                0
90#define L2CAP_CONN_PENDING           1
91#define L2CAP_CONN_NO_PSM            2
92#define L2CAP_CONN_SECURITY_BLOCK    3
93#define L2CAP_CONN_NO_RESOURCES      4
94#define L2CAP_CONN_BAD_CTLR_ID       5              /* AMP related */
95#define L2CAP_CONN_TIMEOUT           0xEEEE
96#define L2CAP_CONN_AMP_FAILED        254
97#define L2CAP_CONN_NO_LINK           255        /* Add a couple of our own for internal use */
98#define L2CAP_CONN_CANCEL            256        /* L2CAP connection cancelled */
99
100
101/* Define L2CAP Move Channel Response result codes
102*/
103#define L2CAP_MOVE_OK                   0
104#define L2CAP_MOVE_PENDING              1
105#define L2CAP_MOVE_CTRL_ID_NOT_SUPPORT  2
106#define L2CAP_MOVE_SAME_CTRLR_ID        3
107#define L2CAP_MOVE_CONFIG_NOT_SUPPORTED 4
108#define L2CAP_MOVE_CHAN_COLLISION       5
109#define L2CAP_MOVE_NOT_ALLOWED          6
110
111
112/* Define L2CAP Move Channel Confirmation result codes
113*/
114#define L2CAP_MOVE_CFM_OK               0
115#define L2CAP_MOVE_CFM_REFUSED          1
116
117
118/* Define the L2CAP command reject reason codes
119*/
120#define L2CAP_CMD_REJ_NOT_UNDERSTOOD    0
121#define L2CAP_CMD_REJ_MTU_EXCEEDED      1
122#define L2CAP_CMD_REJ_INVALID_CID       2
123
124
125/* L2CAP Predefined CIDs  (0x0004-0x003E Reserved)
126*/
127#define L2CAP_SIGNALLING_CID            1
128#define L2CAP_CONNECTIONLESS_CID        2
129#define L2CAP_AMP_CID                   3
130#define L2CAP_ATT_CID                   4
131#define L2CAP_BLE_SIGNALLING_CID        5
132#define L2CAP_SMP_CID                   6
133#define L2CAP_AMP_TEST_CID              0x003F
134#define L2CAP_BASE_APPL_CID             0x0040
135
136/* Fixed Channels mask bits
137*/
138#define L2CAP_FIXED_CHNL_SIG_BIT        (1 << L2CAP_SIGNALLING_CID)     /* Signal Channel Supported (Mandatory) */
139#define L2CAP_FIXED_CHNL_CNCTLESS_BIT   (1 << L2CAP_CONNECTIONLESS_CID) /* Connectionless Reception             */
140#define L2CAP_FIXED_CHNL_AMP_BIT        (1 << L2CAP_AMP_CID)            /* AMP Manager Supported                */
141#define L2CAP_FIXED_CHNL_ATT_BIT        (1 << L2CAP_ATT_CID)            /* Attribute protocol Supported         */
142#define L2CAP_FIXED_CHNL_BLE_SIG_BIT    (1 << L2CAP_BLE_SIGNALLING_CID) /* BLE Signalling Supported             */
143#define L2CAP_FIXED_CHNL_SMP_BIT        (1 << L2CAP_SMP_CID)            /* BLE Security Manager Supported       */
144
145
146
147/* Define the L2CAP configuration result codes
148*/
149#define L2CAP_CFG_OK                    0
150#define L2CAP_CFG_UNACCEPTABLE_PARAMS   1
151#define L2CAP_CFG_FAILED_NO_REASON      2
152#define L2CAP_CFG_UNKNOWN_OPTIONS       3
153#define L2CAP_CFG_PENDING               4
154#define L2CAP_CFG_FLOW_SPEC_REJECTED    5
155
156
157/* Define the L2CAP configuration option types
158*/
159#define L2CAP_CFG_TYPE_MTU              0x01
160#define L2CAP_CFG_TYPE_FLUSH_TOUT       0x02
161#define L2CAP_CFG_TYPE_QOS              0x03
162#define L2CAP_CFG_TYPE_FCR              0x04
163#define L2CAP_CFG_TYPE_FCS              0x05
164#define L2CAP_CFG_TYPE_EXT_FLOW         0x06
165#define L2CAP_CFG_TYPE_EXT_WIN_SIZE     0x07
166
167#define L2CAP_CFG_MTU_OPTION_LEN        2           /* MTU option length    */
168#define L2CAP_CFG_FLUSH_OPTION_LEN      2           /* Flush option len     */
169#define L2CAP_CFG_QOS_OPTION_LEN        22          /* QOS option length    */
170#define L2CAP_CFG_FCR_OPTION_LEN        9           /* FCR option length    */
171#define L2CAP_CFG_FCS_OPTION_LEN        1           /* FCR option length    */
172#define L2CAP_CFG_EXT_FLOW_OPTION_LEN   16          /* Extended Flow Spec   */
173#define L2CAP_CFG_EXT_WIN_SIZE_LEN      2           /* Ext window size length */
174#define L2CAP_CFG_OPTION_OVERHEAD       2           /* Type and length      */
175
176/* Configuration Cmd/Rsp Flags mask
177*/
178#define L2CAP_CFG_FLAGS_MASK_CONT       0x0001      /* Flags mask: Continuation */
179
180/* FCS Check Option values
181*/
182#define L2CAP_CFG_FCS_BYPASS            0       /* Bypass the FCS in streaming or ERTM modes */
183#define L2CAP_CFG_FCS_USE               1       /* Use the FCS in streaming or ERTM modes [default] */
184
185/* Default values for configuration
186*/
187#define L2CAP_NO_AUTOMATIC_FLUSH        0xFFFF
188#define L2CAP_NO_RETRANSMISSION         0x0001
189
190#define L2CAP_DEFAULT_MTU               (672)
191#define L2CAP_DEFAULT_FLUSH_TO          L2CAP_NO_AUTOMATIC_FLUSH
192#define L2CAP_DEFAULT_SERV_TYPE         1
193#define L2CAP_DEFAULT_TOKEN_RATE        0
194#define L2CAP_DEFAULT_BUCKET_SIZE       0
195#define L2CAP_DEFAULT_PEAK_BANDWIDTH    0
196#define L2CAP_DEFAULT_LATENCY           0xFFFFFFFF
197#define L2CAP_DEFAULT_DELAY             0xFFFFFFFF
198#define L2CAP_DEFAULT_FCS               L2CAP_CFG_FCS_USE
199
200
201/* Define the L2CAP disconnect result codes
202*/
203#define L2CAP_DISC_OK                   0
204#define L2CAP_DISC_TIMEOUT              0xEEEE
205
206/* Define the L2CAP info resp result codes
207*/
208#define L2CAP_INFO_RESP_RESULT_SUCCESS          0
209#define L2CAP_INFO_RESP_RESULT_NOT_SUPPORTED    1
210
211/* Define the info-type fields of information request & response
212*/
213#define L2CAP_CONNLESS_MTU_INFO_TYPE      0x0001
214#define L2CAP_EXTENDED_FEATURES_INFO_TYPE 0x0002    /* Used in Information Req/Response */
215#define L2CAP_FIXED_CHANNELS_INFO_TYPE    0x0003    /* Used in AMP                      */
216
217#define L2CAP_CONNLESS_MTU_INFO_SIZE           2    /* Connectionless MTU size          */
218#define L2CAP_EXTENDED_FEATURES_ARRAY_SIZE     4    /* Extended features array size     */
219#define L2CAP_FIXED_CHNL_ARRAY_SIZE            8    /* Fixed channel array size         */
220
221/* Extended features mask bits
222*/
223#define L2CAP_EXTFEA_RTRANS         0x00000001    /* Retransmission Mode (Not Supported)    */
224#define L2CAP_EXTFEA_FC             0x00000002    /* Flow Control Mode   (Not Supported)    */
225#define L2CAP_EXTFEA_QOS            0x00000004
226#define L2CAP_EXTFEA_ENH_RETRANS    0x00000008    /* Enhanced retransmission mode           */
227#define L2CAP_EXTFEA_STREAM_MODE    0x00000010    /* Streaming Mode                         */
228#define L2CAP_EXTFEA_NO_CRC         0x00000020    /* Optional FCS (if set No FCS desired)   */
229#define L2CAP_EXTFEA_EXT_FLOW_SPEC  0x00000040    /* Extended flow spec                     */
230#define L2CAP_EXTFEA_FIXED_CHNLS    0x00000080    /* Fixed channels                         */
231#define L2CAP_EXTFEA_EXT_WINDOW     0x00000100    /* Extended Window Size                   */
232#define L2CAP_EXTFEA_UCD_RECEPTION  0x00000200    /* Unicast Connectionless Data Reception  */
233
234/* Mask for locally supported features used in Information Response (default to none) */
235#ifndef L2CAP_EXTFEA_SUPPORTED_MASK
236#define L2CAP_EXTFEA_SUPPORTED_MASK 0
237#endif
238
239/* Mask for LE supported features used in Information Response (default to none) */
240#ifndef L2CAP_BLE_EXTFEA_MASK
241#define L2CAP_BLE_EXTFEA_MASK 0
242#endif
243
244/* Define a value that tells L2CAP to use the default HCI ACL buffer pool */
245#define L2CAP_DEFAULT_ERM_POOL_ID       0xFF
246/* Define a value that tells L2CAP to use the default MPS */
247#define L2CAP_DEFAULT_ERM_MPS           0x0000
248
249#define L2CAP_FCR_OVERHEAD         2   /* Control word                 */
250#define L2CAP_FCS_LEN              2   /* FCS takes 2 bytes */
251#define L2CAP_SDU_LEN_OVERHEAD     2   /* SDU length field is 2 bytes */
252#define L2CAP_SDU_LEN_OFFSET       2   /* SDU length offset is 2 bytes */
253#define L2CAP_EXT_CONTROL_OVERHEAD 4   /* Extended Control Field       */
254#define L2CAP_MAX_HEADER_FCS       (L2CAP_PKT_OVERHEAD + L2CAP_EXT_CONTROL_OVERHEAD + L2CAP_SDU_LEN_OVERHEAD + L2CAP_FCS_LEN)
255                                   /* length(2), channel(2), control(4), SDU length(2) FCS(2) */
256/* Part of L2CAP_MIN_OFFSET that is not part of L2CAP
257*/
258#define L2CAP_OFFSET_WO_L2HDR  (L2CAP_MIN_OFFSET-(L2CAP_PKT_OVERHEAD+L2CAP_FCR_OVERHEAD))
259
260/* SAR bits in the control word
261*/
262#define L2CAP_FCR_UNSEG_SDU    0x0000   /* Control word to begin with for unsegmented PDU*/
263#define L2CAP_FCR_START_SDU    0x4000   /* ...for Starting PDU of a semented SDU */
264#define L2CAP_FCR_END_SDU      0x8000   /* ...for ending PDU of a segmented SDU */
265#define L2CAP_FCR_CONT_SDU     0xc000   /* ...for continuation PDU of a segmented SDU */
266
267/* Supervisory frame types
268*/
269#define L2CAP_FCR_SUP_RR        0x0000   /* Supervisory frame - RR                          */
270#define L2CAP_FCR_SUP_REJ       0x0001   /* Supervisory frame - REJ                         */
271#define L2CAP_FCR_SUP_RNR       0x0002   /* Supervisory frame - RNR                         */
272#define L2CAP_FCR_SUP_SREJ      0x0003   /* Supervisory frame - SREJ                        */
273
274#define L2CAP_FCR_SAR_BITS           0xC000    /* Mask to get the SAR bits from control word */
275#define L2CAP_FCR_SAR_BITS_SHIFT     14        /* Bits to shift right to get the SAR bits from ctrl-word */
276
277#define L2CAP_FCR_S_FRAME_BIT         0x0001   /* Mask to check if a PDU is S-frame */
278#define L2CAP_FCR_REQ_SEQ_BITS        0x3F00   /* Mask to get the req-seq from control word */
279#define L2CAP_FCR_REQ_SEQ_BITS_SHIFT  8        /* Bits to shift right to get the req-seq from ctrl-word */
280#define L2CAP_FCR_TX_SEQ_BITS         0x007E   /* Mask on get the tx-seq from control word */
281#define L2CAP_FCR_TX_SEQ_BITS_SHIFT   1        /* Bits to shift right to get the tx-seq from ctrl-word */
282
283#define L2CAP_FCR_F_BIT               0x0080   /* F-bit in the control word (Sup and I frames)  */
284#define L2CAP_FCR_P_BIT               0x0010   /* P-bit in the control word (Sup frames only)   */
285
286#define L2CAP_FCR_F_BIT_SHIFT         7
287#define L2CAP_FCR_P_BIT_SHIFT         4
288
289#define L2CAP_FCR_SEG_BITS            0xC000   /* Mask to get the segmentation bits from ctrl-word */
290#define L2CAP_FCR_SUP_SHIFT           2        /* Bits to shift right to get the S-bits from ctrl-word */
291#define L2CAP_FCR_SUP_BITS            0x000C   /* Mask to get the supervisory bits from ctrl-word */
292
293#define L2CAP_FCR_INIT_CRC            0   /* Initial state of the CRC register */
294#define L2CAP_FCR_SEQ_MODULO          0x3F     /* Mask for sequence numbers (range 0 - 63) */
295
296/*************************************************************************************************
297** The following definitions are only used for internal testing of ERTM at the application level
298*************************************************************************************************/
299/* L2CA_SetupErtmTest() corruption test types */
300#define L2CAP_FCR_TTYPE_CORR_IFRAME     0       /* Corrupt one or more I-frames, based on count   */
301#define L2CAP_FCR_TTYPE_CORR_SFRAME     1       /* Corrupt an S-frame, (acknowledgement) */
302#define L2CAP_FCR_TTYPE_STOP_TEST       2       /* Used when turning off a test */
303#define L2CAP_FCR_TTYPE_GET_CID         3       /* Returns RFCOMM cid when '0' is passed in cid argument */
304
305/* L2CA_SetupErtmTest() Freq */
306#define L2CAP_FCR_FREQ_NORMAL           0       /* A single test is run */
307#define L2CAP_FCR_FREQ_RANDOM           1       /* Randomly loses or corrupts a packet */
308
309#endif
310