Bluetooth: Use macro for L2CAP hint mask on receiving config request
[pandora-kernel.git] / include / net / bluetooth / l2cap.h
1 /* 
2    BlueZ - Bluetooth protocol stack for Linux
3    Copyright (C) 2000-2001 Qualcomm Incorporated
4
5    Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License version 2 as
9    published by the Free Software Foundation;
10
11    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
12    OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
13    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
14    IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
15    CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES 
16    WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 
17    ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 
18    OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19
20    ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS, 
21    COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS 
22    SOFTWARE IS DISCLAIMED.
23 */
24
25 #ifndef __L2CAP_H
26 #define __L2CAP_H
27
28 /* L2CAP defaults */
29 #define L2CAP_DEFAULT_MTU       672
30 #define L2CAP_DEFAULT_FLUSH_TO  0xFFFF
31
32 #define L2CAP_CONN_TIMEOUT      (40000) /* 40 seconds */
33 #define L2CAP_INFO_TIMEOUT      (4000)  /*  4 seconds */
34
35 /* L2CAP socket address */
36 struct sockaddr_l2 {
37         sa_family_t     l2_family;
38         __le16          l2_psm;
39         bdaddr_t        l2_bdaddr;
40         __le16          l2_cid;
41 };
42
43 /* L2CAP socket options */
44 #define L2CAP_OPTIONS   0x01
45 struct l2cap_options {
46         __u16 omtu;
47         __u16 imtu;
48         __u16 flush_to;
49         __u8  mode;
50 };
51
52 #define L2CAP_CONNINFO  0x02
53 struct l2cap_conninfo {
54         __u16 hci_handle;
55         __u8  dev_class[3];
56 };
57
58 #define L2CAP_LM        0x03
59 #define L2CAP_LM_MASTER         0x0001
60 #define L2CAP_LM_AUTH           0x0002
61 #define L2CAP_LM_ENCRYPT        0x0004
62 #define L2CAP_LM_TRUSTED        0x0008
63 #define L2CAP_LM_RELIABLE       0x0010
64 #define L2CAP_LM_SECURE         0x0020
65
66 /* L2CAP command codes */
67 #define L2CAP_COMMAND_REJ 0x01
68 #define L2CAP_CONN_REQ    0x02
69 #define L2CAP_CONN_RSP    0x03
70 #define L2CAP_CONF_REQ    0x04
71 #define L2CAP_CONF_RSP    0x05
72 #define L2CAP_DISCONN_REQ 0x06
73 #define L2CAP_DISCONN_RSP 0x07
74 #define L2CAP_ECHO_REQ    0x08
75 #define L2CAP_ECHO_RSP    0x09
76 #define L2CAP_INFO_REQ    0x0a
77 #define L2CAP_INFO_RSP    0x0b
78
79 /* L2CAP structures */
80 struct l2cap_hdr {
81         __le16     len;
82         __le16     cid;
83 } __attribute__ ((packed));
84 #define L2CAP_HDR_SIZE          4
85
86 struct l2cap_cmd_hdr {
87         __u8       code;
88         __u8       ident;
89         __le16     len;
90 } __attribute__ ((packed));
91 #define L2CAP_CMD_HDR_SIZE      4
92
93 struct l2cap_cmd_rej {
94         __le16     reason;
95 } __attribute__ ((packed));
96
97 struct l2cap_conn_req {
98         __le16     psm;
99         __le16     scid;
100 } __attribute__ ((packed));
101
102 struct l2cap_conn_rsp {
103         __le16     dcid;
104         __le16     scid;
105         __le16     result;
106         __le16     status;
107 } __attribute__ ((packed));
108
109 /* channel indentifier */
110 #define L2CAP_CID_SIGNALING     0x0001
111 #define L2CAP_CID_CONN_LESS     0x0002
112 #define L2CAP_CID_DYN_START     0x0040
113 #define L2CAP_CID_DYN_END       0xffff
114
115 /* connect result */
116 #define L2CAP_CR_SUCCESS    0x0000
117 #define L2CAP_CR_PEND       0x0001
118 #define L2CAP_CR_BAD_PSM    0x0002
119 #define L2CAP_CR_SEC_BLOCK  0x0003
120 #define L2CAP_CR_NO_MEM     0x0004
121
122 /* connect status */
123 #define L2CAP_CS_NO_INFO      0x0000
124 #define L2CAP_CS_AUTHEN_PEND  0x0001
125 #define L2CAP_CS_AUTHOR_PEND  0x0002
126
127 struct l2cap_conf_req {
128         __le16     dcid;
129         __le16     flags;
130         __u8       data[0];
131 } __attribute__ ((packed));
132
133 struct l2cap_conf_rsp {
134         __le16     scid;
135         __le16     flags;
136         __le16     result;
137         __u8       data[0];
138 } __attribute__ ((packed));
139
140 #define L2CAP_CONF_SUCCESS      0x0000
141 #define L2CAP_CONF_UNACCEPT     0x0001
142 #define L2CAP_CONF_REJECT       0x0002
143 #define L2CAP_CONF_UNKNOWN      0x0003
144
145 struct l2cap_conf_opt {
146         __u8       type;
147         __u8       len;
148         __u8       val[0];
149 } __attribute__ ((packed));
150 #define L2CAP_CONF_OPT_SIZE     2
151
152 #define L2CAP_CONF_HINT         0x80
153
154 #define L2CAP_CONF_MTU          0x01
155 #define L2CAP_CONF_FLUSH_TO     0x02
156 #define L2CAP_CONF_QOS          0x03
157 #define L2CAP_CONF_RFC          0x04
158
159 #define L2CAP_CONF_MAX_SIZE     22
160
161 struct l2cap_conf_rfc {
162         __u8       mode;
163         __u8       txwin_size;
164         __u8       max_transmit;
165         __le16     retrans_timeout;
166         __le16     monitor_timeout;
167         __le16     max_pdu_size;
168 } __attribute__ ((packed));
169
170 #define L2CAP_MODE_BASIC        0x00
171 #define L2CAP_MODE_RETRANS      0x01
172 #define L2CAP_MODE_FLOWCTL      0x02
173
174 struct l2cap_disconn_req {
175         __le16     dcid;
176         __le16     scid;
177 } __attribute__ ((packed));
178
179 struct l2cap_disconn_rsp {
180         __le16     dcid;
181         __le16     scid;
182 } __attribute__ ((packed));
183
184 struct l2cap_info_req {
185         __le16      type;
186 } __attribute__ ((packed));
187
188 struct l2cap_info_rsp {
189         __le16      type;
190         __le16      result;
191         __u8        data[0];
192 } __attribute__ ((packed));
193
194 /* info type */
195 #define L2CAP_IT_CL_MTU     0x0001
196 #define L2CAP_IT_FEAT_MASK  0x0002
197 #define L2CAP_IT_FIXED_CHAN 0x0003
198
199 /* info result */
200 #define L2CAP_IR_SUCCESS    0x0000
201 #define L2CAP_IR_NOTSUPP    0x0001
202
203 /* ----- L2CAP connections ----- */
204 struct l2cap_chan_list {
205         struct sock     *head;
206         rwlock_t        lock;
207         long            num;
208 };
209
210 struct l2cap_conn {
211         struct hci_conn *hcon;
212
213         bdaddr_t        *dst;
214         bdaddr_t        *src;
215
216         unsigned int    mtu;
217
218         __u32           feat_mask;
219
220         __u8            info_state;
221         __u8            info_ident;
222
223         struct timer_list info_timer;
224
225         spinlock_t      lock;
226
227         struct sk_buff *rx_skb;
228         __u32           rx_len;
229         __u8            rx_ident;
230         __u8            tx_ident;
231
232         __u8            disc_reason;
233
234         struct l2cap_chan_list chan_list;
235 };
236
237 #define L2CAP_INFO_CL_MTU_REQ_SENT      0x01
238 #define L2CAP_INFO_FEAT_MASK_REQ_SENT   0x04
239 #define L2CAP_INFO_FEAT_MASK_REQ_DONE   0x08
240
241 /* ----- L2CAP channel and socket info ----- */
242 #define l2cap_pi(sk) ((struct l2cap_pinfo *) sk)
243
244 struct l2cap_pinfo {
245         struct bt_sock  bt;
246         __le16          psm;
247         __u16           dcid;
248         __u16           scid;
249
250         __u16           imtu;
251         __u16           omtu;
252         __u16           flush_to;
253         __u8            sec_level;
254         __u8            role_switch;
255         __u8            force_reliable;
256
257         __u8            conf_req[64];
258         __u8            conf_len;
259         __u8            conf_state;
260         __u8            conf_retry;
261
262         __u8            ident;
263
264         __le16          sport;
265
266         struct l2cap_conn       *conn;
267         struct sock             *next_c;
268         struct sock             *prev_c;
269 };
270
271 #define L2CAP_CONF_REQ_SENT     0x01
272 #define L2CAP_CONF_INPUT_DONE   0x02
273 #define L2CAP_CONF_OUTPUT_DONE  0x04
274 #define L2CAP_CONF_CONNECT_PEND 0x80
275
276 #define L2CAP_CONF_MAX_RETRIES  2
277
278 void l2cap_load(void);
279
280 #endif /* __L2CAP_H */