xref: /OK3568_Linux_fs/kernel/include/net/bluetooth/rfcomm.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun    RFCOMM implementation for Linux Bluetooth stack (BlueZ)
3*4882a593Smuzhiyun    Copyright (C) 2002 Maxim Krasnyansky <maxk@qualcomm.com>
4*4882a593Smuzhiyun    Copyright (C) 2002 Marcel Holtmann <marcel@holtmann.org>
5*4882a593Smuzhiyun 
6*4882a593Smuzhiyun    This program is free software; you can redistribute it and/or modify
7*4882a593Smuzhiyun    it under the terms of the GNU General Public License version 2 as
8*4882a593Smuzhiyun    published by the Free Software Foundation;
9*4882a593Smuzhiyun 
10*4882a593Smuzhiyun    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
11*4882a593Smuzhiyun    OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
12*4882a593Smuzhiyun    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
13*4882a593Smuzhiyun    IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
14*4882a593Smuzhiyun    CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
15*4882a593Smuzhiyun    WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16*4882a593Smuzhiyun    ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17*4882a593Smuzhiyun    OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun    ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
20*4882a593Smuzhiyun    COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
21*4882a593Smuzhiyun    SOFTWARE IS DISCLAIMED.
22*4882a593Smuzhiyun */
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun #include <linux/refcount.h>
25*4882a593Smuzhiyun #include <linux/android_kabi.h>
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun #ifndef __RFCOMM_H
28*4882a593Smuzhiyun #define __RFCOMM_H
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun #define RFCOMM_CONN_TIMEOUT (HZ * 30)
31*4882a593Smuzhiyun #define RFCOMM_DISC_TIMEOUT (HZ * 20)
32*4882a593Smuzhiyun #define RFCOMM_AUTH_TIMEOUT (HZ * 25)
33*4882a593Smuzhiyun #define RFCOMM_IDLE_TIMEOUT (HZ * 2)
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun #define RFCOMM_DEFAULT_MTU	127
36*4882a593Smuzhiyun #define RFCOMM_DEFAULT_CREDITS	7
37*4882a593Smuzhiyun 
38*4882a593Smuzhiyun #define RFCOMM_MAX_CREDITS	40
39*4882a593Smuzhiyun 
40*4882a593Smuzhiyun #define RFCOMM_SKB_HEAD_RESERVE	8
41*4882a593Smuzhiyun #define RFCOMM_SKB_TAIL_RESERVE	2
42*4882a593Smuzhiyun #define RFCOMM_SKB_RESERVE  (RFCOMM_SKB_HEAD_RESERVE + RFCOMM_SKB_TAIL_RESERVE)
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun #define RFCOMM_SABM	0x2f
45*4882a593Smuzhiyun #define RFCOMM_DISC	0x43
46*4882a593Smuzhiyun #define RFCOMM_UA	0x63
47*4882a593Smuzhiyun #define RFCOMM_DM	0x0f
48*4882a593Smuzhiyun #define RFCOMM_UIH	0xef
49*4882a593Smuzhiyun 
50*4882a593Smuzhiyun #define RFCOMM_TEST	0x08
51*4882a593Smuzhiyun #define RFCOMM_FCON	0x28
52*4882a593Smuzhiyun #define RFCOMM_FCOFF	0x18
53*4882a593Smuzhiyun #define RFCOMM_MSC	0x38
54*4882a593Smuzhiyun #define RFCOMM_RPN	0x24
55*4882a593Smuzhiyun #define RFCOMM_RLS	0x14
56*4882a593Smuzhiyun #define RFCOMM_PN	0x20
57*4882a593Smuzhiyun #define RFCOMM_NSC	0x04
58*4882a593Smuzhiyun 
59*4882a593Smuzhiyun #define RFCOMM_V24_FC	0x02
60*4882a593Smuzhiyun #define RFCOMM_V24_RTC	0x04
61*4882a593Smuzhiyun #define RFCOMM_V24_RTR	0x08
62*4882a593Smuzhiyun #define RFCOMM_V24_IC	0x40
63*4882a593Smuzhiyun #define RFCOMM_V24_DV	0x80
64*4882a593Smuzhiyun 
65*4882a593Smuzhiyun #define RFCOMM_RPN_BR_2400	0x0
66*4882a593Smuzhiyun #define RFCOMM_RPN_BR_4800	0x1
67*4882a593Smuzhiyun #define RFCOMM_RPN_BR_7200	0x2
68*4882a593Smuzhiyun #define RFCOMM_RPN_BR_9600	0x3
69*4882a593Smuzhiyun #define RFCOMM_RPN_BR_19200	0x4
70*4882a593Smuzhiyun #define RFCOMM_RPN_BR_38400	0x5
71*4882a593Smuzhiyun #define RFCOMM_RPN_BR_57600	0x6
72*4882a593Smuzhiyun #define RFCOMM_RPN_BR_115200	0x7
73*4882a593Smuzhiyun #define RFCOMM_RPN_BR_230400	0x8
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun #define RFCOMM_RPN_DATA_5	0x0
76*4882a593Smuzhiyun #define RFCOMM_RPN_DATA_6	0x1
77*4882a593Smuzhiyun #define RFCOMM_RPN_DATA_7	0x2
78*4882a593Smuzhiyun #define RFCOMM_RPN_DATA_8	0x3
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun #define RFCOMM_RPN_STOP_1	0
81*4882a593Smuzhiyun #define RFCOMM_RPN_STOP_15	1
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun #define RFCOMM_RPN_PARITY_NONE	0x0
84*4882a593Smuzhiyun #define RFCOMM_RPN_PARITY_ODD	0x1
85*4882a593Smuzhiyun #define RFCOMM_RPN_PARITY_EVEN	0x3
86*4882a593Smuzhiyun #define RFCOMM_RPN_PARITY_MARK	0x5
87*4882a593Smuzhiyun #define RFCOMM_RPN_PARITY_SPACE	0x7
88*4882a593Smuzhiyun 
89*4882a593Smuzhiyun #define RFCOMM_RPN_FLOW_NONE	0x00
90*4882a593Smuzhiyun 
91*4882a593Smuzhiyun #define RFCOMM_RPN_XON_CHAR	0x11
92*4882a593Smuzhiyun #define RFCOMM_RPN_XOFF_CHAR	0x13
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun #define RFCOMM_RPN_PM_BITRATE		0x0001
95*4882a593Smuzhiyun #define RFCOMM_RPN_PM_DATA		0x0002
96*4882a593Smuzhiyun #define RFCOMM_RPN_PM_STOP		0x0004
97*4882a593Smuzhiyun #define RFCOMM_RPN_PM_PARITY		0x0008
98*4882a593Smuzhiyun #define RFCOMM_RPN_PM_PARITY_TYPE	0x0010
99*4882a593Smuzhiyun #define RFCOMM_RPN_PM_XON		0x0020
100*4882a593Smuzhiyun #define RFCOMM_RPN_PM_XOFF		0x0040
101*4882a593Smuzhiyun #define RFCOMM_RPN_PM_FLOW		0x3F00
102*4882a593Smuzhiyun 
103*4882a593Smuzhiyun #define RFCOMM_RPN_PM_ALL		0x3F7F
104*4882a593Smuzhiyun 
105*4882a593Smuzhiyun struct rfcomm_hdr {
106*4882a593Smuzhiyun 	u8 addr;
107*4882a593Smuzhiyun 	u8 ctrl;
108*4882a593Smuzhiyun 	u8 len;    /* Actual size can be 2 bytes */
109*4882a593Smuzhiyun } __packed;
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun struct rfcomm_cmd {
112*4882a593Smuzhiyun 	u8 addr;
113*4882a593Smuzhiyun 	u8 ctrl;
114*4882a593Smuzhiyun 	u8 len;
115*4882a593Smuzhiyun 	u8 fcs;
116*4882a593Smuzhiyun } __packed;
117*4882a593Smuzhiyun 
118*4882a593Smuzhiyun struct rfcomm_mcc {
119*4882a593Smuzhiyun 	u8 type;
120*4882a593Smuzhiyun 	u8 len;
121*4882a593Smuzhiyun } __packed;
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun struct rfcomm_pn {
124*4882a593Smuzhiyun 	u8  dlci;
125*4882a593Smuzhiyun 	u8  flow_ctrl;
126*4882a593Smuzhiyun 	u8  priority;
127*4882a593Smuzhiyun 	u8  ack_timer;
128*4882a593Smuzhiyun 	__le16 mtu;
129*4882a593Smuzhiyun 	u8  max_retrans;
130*4882a593Smuzhiyun 	u8  credits;
131*4882a593Smuzhiyun } __packed;
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun struct rfcomm_rpn {
134*4882a593Smuzhiyun 	u8  dlci;
135*4882a593Smuzhiyun 	u8  bit_rate;
136*4882a593Smuzhiyun 	u8  line_settings;
137*4882a593Smuzhiyun 	u8  flow_ctrl;
138*4882a593Smuzhiyun 	u8  xon_char;
139*4882a593Smuzhiyun 	u8  xoff_char;
140*4882a593Smuzhiyun 	__le16 param_mask;
141*4882a593Smuzhiyun } __packed;
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun struct rfcomm_rls {
144*4882a593Smuzhiyun 	u8  dlci;
145*4882a593Smuzhiyun 	u8  status;
146*4882a593Smuzhiyun } __packed;
147*4882a593Smuzhiyun 
148*4882a593Smuzhiyun struct rfcomm_msc {
149*4882a593Smuzhiyun 	u8  dlci;
150*4882a593Smuzhiyun 	u8  v24_sig;
151*4882a593Smuzhiyun } __packed;
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun /* ---- Core structures, flags etc ---- */
154*4882a593Smuzhiyun 
155*4882a593Smuzhiyun struct rfcomm_session {
156*4882a593Smuzhiyun 	struct list_head list;
157*4882a593Smuzhiyun 	struct socket   *sock;
158*4882a593Smuzhiyun 	struct timer_list timer;
159*4882a593Smuzhiyun 	unsigned long    state;
160*4882a593Smuzhiyun 	unsigned long    flags;
161*4882a593Smuzhiyun 	int              initiator;
162*4882a593Smuzhiyun 
163*4882a593Smuzhiyun 	/* Default DLC parameters */
164*4882a593Smuzhiyun 	int    cfc;
165*4882a593Smuzhiyun 	uint   mtu;
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun 	struct list_head dlcs;
168*4882a593Smuzhiyun 
169*4882a593Smuzhiyun 	ANDROID_KABI_RESERVE(1);
170*4882a593Smuzhiyun };
171*4882a593Smuzhiyun 
172*4882a593Smuzhiyun struct rfcomm_dlc {
173*4882a593Smuzhiyun 	struct list_head      list;
174*4882a593Smuzhiyun 	struct rfcomm_session *session;
175*4882a593Smuzhiyun 	struct sk_buff_head   tx_queue;
176*4882a593Smuzhiyun 	struct timer_list     timer;
177*4882a593Smuzhiyun 
178*4882a593Smuzhiyun 	struct mutex  lock;
179*4882a593Smuzhiyun 	unsigned long state;
180*4882a593Smuzhiyun 	unsigned long flags;
181*4882a593Smuzhiyun 	refcount_t    refcnt;
182*4882a593Smuzhiyun 	u8            dlci;
183*4882a593Smuzhiyun 	u8            addr;
184*4882a593Smuzhiyun 	u8            priority;
185*4882a593Smuzhiyun 	u8            v24_sig;
186*4882a593Smuzhiyun 	u8            remote_v24_sig;
187*4882a593Smuzhiyun 	u8            mscex;
188*4882a593Smuzhiyun 	u8            out;
189*4882a593Smuzhiyun 	u8            sec_level;
190*4882a593Smuzhiyun 	u8            role_switch;
191*4882a593Smuzhiyun 	u32           defer_setup;
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun 	uint          mtu;
194*4882a593Smuzhiyun 	uint          cfc;
195*4882a593Smuzhiyun 	uint          rx_credits;
196*4882a593Smuzhiyun 	uint          tx_credits;
197*4882a593Smuzhiyun 
198*4882a593Smuzhiyun 	void          *owner;
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun 	void (*data_ready)(struct rfcomm_dlc *d, struct sk_buff *skb);
201*4882a593Smuzhiyun 	void (*state_change)(struct rfcomm_dlc *d, int err);
202*4882a593Smuzhiyun 	void (*modem_status)(struct rfcomm_dlc *d, u8 v24_sig);
203*4882a593Smuzhiyun 
204*4882a593Smuzhiyun 	ANDROID_KABI_RESERVE(1);
205*4882a593Smuzhiyun 	ANDROID_KABI_RESERVE(2);
206*4882a593Smuzhiyun };
207*4882a593Smuzhiyun 
208*4882a593Smuzhiyun /* DLC and session flags */
209*4882a593Smuzhiyun #define RFCOMM_RX_THROTTLED 0
210*4882a593Smuzhiyun #define RFCOMM_TX_THROTTLED 1
211*4882a593Smuzhiyun #define RFCOMM_TIMED_OUT    2
212*4882a593Smuzhiyun #define RFCOMM_MSC_PENDING  3
213*4882a593Smuzhiyun #define RFCOMM_SEC_PENDING  4
214*4882a593Smuzhiyun #define RFCOMM_AUTH_PENDING 5
215*4882a593Smuzhiyun #define RFCOMM_AUTH_ACCEPT  6
216*4882a593Smuzhiyun #define RFCOMM_AUTH_REJECT  7
217*4882a593Smuzhiyun #define RFCOMM_DEFER_SETUP  8
218*4882a593Smuzhiyun #define RFCOMM_ENC_DROP     9
219*4882a593Smuzhiyun 
220*4882a593Smuzhiyun /* Scheduling flags and events */
221*4882a593Smuzhiyun #define RFCOMM_SCHED_WAKEUP 31
222*4882a593Smuzhiyun 
223*4882a593Smuzhiyun /* MSC exchange flags */
224*4882a593Smuzhiyun #define RFCOMM_MSCEX_TX     1
225*4882a593Smuzhiyun #define RFCOMM_MSCEX_RX     2
226*4882a593Smuzhiyun #define RFCOMM_MSCEX_OK     (RFCOMM_MSCEX_TX + RFCOMM_MSCEX_RX)
227*4882a593Smuzhiyun 
228*4882a593Smuzhiyun /* CFC states */
229*4882a593Smuzhiyun #define RFCOMM_CFC_UNKNOWN  -1
230*4882a593Smuzhiyun #define RFCOMM_CFC_DISABLED 0
231*4882a593Smuzhiyun #define RFCOMM_CFC_ENABLED  RFCOMM_MAX_CREDITS
232*4882a593Smuzhiyun 
233*4882a593Smuzhiyun /* ---- RFCOMM SEND RPN ---- */
234*4882a593Smuzhiyun int rfcomm_send_rpn(struct rfcomm_session *s, int cr, u8 dlci,
235*4882a593Smuzhiyun 			u8 bit_rate, u8 data_bits, u8 stop_bits,
236*4882a593Smuzhiyun 			u8 parity, u8 flow_ctrl_settings,
237*4882a593Smuzhiyun 			u8 xon_char, u8 xoff_char, u16 param_mask);
238*4882a593Smuzhiyun 
239*4882a593Smuzhiyun /* ---- RFCOMM DLCs (channels) ---- */
240*4882a593Smuzhiyun struct rfcomm_dlc *rfcomm_dlc_alloc(gfp_t prio);
241*4882a593Smuzhiyun void rfcomm_dlc_free(struct rfcomm_dlc *d);
242*4882a593Smuzhiyun int  rfcomm_dlc_open(struct rfcomm_dlc *d, bdaddr_t *src, bdaddr_t *dst,
243*4882a593Smuzhiyun 								u8 channel);
244*4882a593Smuzhiyun int  rfcomm_dlc_close(struct rfcomm_dlc *d, int reason);
245*4882a593Smuzhiyun int  rfcomm_dlc_send(struct rfcomm_dlc *d, struct sk_buff *skb);
246*4882a593Smuzhiyun void rfcomm_dlc_send_noerror(struct rfcomm_dlc *d, struct sk_buff *skb);
247*4882a593Smuzhiyun int  rfcomm_dlc_set_modem_status(struct rfcomm_dlc *d, u8 v24_sig);
248*4882a593Smuzhiyun int  rfcomm_dlc_get_modem_status(struct rfcomm_dlc *d, u8 *v24_sig);
249*4882a593Smuzhiyun void rfcomm_dlc_accept(struct rfcomm_dlc *d);
250*4882a593Smuzhiyun struct rfcomm_dlc *rfcomm_dlc_exists(bdaddr_t *src, bdaddr_t *dst, u8 channel);
251*4882a593Smuzhiyun 
252*4882a593Smuzhiyun #define rfcomm_dlc_lock(d)     mutex_lock(&d->lock)
253*4882a593Smuzhiyun #define rfcomm_dlc_unlock(d)   mutex_unlock(&d->lock)
254*4882a593Smuzhiyun 
rfcomm_dlc_hold(struct rfcomm_dlc * d)255*4882a593Smuzhiyun static inline void rfcomm_dlc_hold(struct rfcomm_dlc *d)
256*4882a593Smuzhiyun {
257*4882a593Smuzhiyun 	refcount_inc(&d->refcnt);
258*4882a593Smuzhiyun }
259*4882a593Smuzhiyun 
rfcomm_dlc_put(struct rfcomm_dlc * d)260*4882a593Smuzhiyun static inline void rfcomm_dlc_put(struct rfcomm_dlc *d)
261*4882a593Smuzhiyun {
262*4882a593Smuzhiyun 	if (refcount_dec_and_test(&d->refcnt))
263*4882a593Smuzhiyun 		rfcomm_dlc_free(d);
264*4882a593Smuzhiyun }
265*4882a593Smuzhiyun 
266*4882a593Smuzhiyun void __rfcomm_dlc_throttle(struct rfcomm_dlc *d);
267*4882a593Smuzhiyun void __rfcomm_dlc_unthrottle(struct rfcomm_dlc *d);
268*4882a593Smuzhiyun 
rfcomm_dlc_throttle(struct rfcomm_dlc * d)269*4882a593Smuzhiyun static inline void rfcomm_dlc_throttle(struct rfcomm_dlc *d)
270*4882a593Smuzhiyun {
271*4882a593Smuzhiyun 	if (!test_and_set_bit(RFCOMM_RX_THROTTLED, &d->flags))
272*4882a593Smuzhiyun 		__rfcomm_dlc_throttle(d);
273*4882a593Smuzhiyun }
274*4882a593Smuzhiyun 
rfcomm_dlc_unthrottle(struct rfcomm_dlc * d)275*4882a593Smuzhiyun static inline void rfcomm_dlc_unthrottle(struct rfcomm_dlc *d)
276*4882a593Smuzhiyun {
277*4882a593Smuzhiyun 	if (test_and_clear_bit(RFCOMM_RX_THROTTLED, &d->flags))
278*4882a593Smuzhiyun 		__rfcomm_dlc_unthrottle(d);
279*4882a593Smuzhiyun }
280*4882a593Smuzhiyun 
281*4882a593Smuzhiyun /* ---- RFCOMM sessions ---- */
282*4882a593Smuzhiyun void   rfcomm_session_getaddr(struct rfcomm_session *s, bdaddr_t *src,
283*4882a593Smuzhiyun 								bdaddr_t *dst);
284*4882a593Smuzhiyun 
285*4882a593Smuzhiyun /* ---- RFCOMM sockets ---- */
286*4882a593Smuzhiyun struct sockaddr_rc {
287*4882a593Smuzhiyun 	sa_family_t	rc_family;
288*4882a593Smuzhiyun 	bdaddr_t	rc_bdaddr;
289*4882a593Smuzhiyun 	u8		rc_channel;
290*4882a593Smuzhiyun };
291*4882a593Smuzhiyun 
292*4882a593Smuzhiyun #define RFCOMM_CONNINFO	0x02
293*4882a593Smuzhiyun struct rfcomm_conninfo {
294*4882a593Smuzhiyun 	__u16 hci_handle;
295*4882a593Smuzhiyun 	__u8  dev_class[3];
296*4882a593Smuzhiyun };
297*4882a593Smuzhiyun 
298*4882a593Smuzhiyun #define RFCOMM_LM	0x03
299*4882a593Smuzhiyun #define RFCOMM_LM_MASTER	0x0001
300*4882a593Smuzhiyun #define RFCOMM_LM_AUTH		0x0002
301*4882a593Smuzhiyun #define RFCOMM_LM_ENCRYPT	0x0004
302*4882a593Smuzhiyun #define RFCOMM_LM_TRUSTED	0x0008
303*4882a593Smuzhiyun #define RFCOMM_LM_RELIABLE	0x0010
304*4882a593Smuzhiyun #define RFCOMM_LM_SECURE	0x0020
305*4882a593Smuzhiyun #define RFCOMM_LM_FIPS		0x0040
306*4882a593Smuzhiyun 
307*4882a593Smuzhiyun #define rfcomm_pi(sk) ((struct rfcomm_pinfo *) sk)
308*4882a593Smuzhiyun 
309*4882a593Smuzhiyun struct rfcomm_pinfo {
310*4882a593Smuzhiyun 	struct bt_sock bt;
311*4882a593Smuzhiyun 	bdaddr_t src;
312*4882a593Smuzhiyun 	bdaddr_t dst;
313*4882a593Smuzhiyun 	struct rfcomm_dlc   *dlc;
314*4882a593Smuzhiyun 	u8     channel;
315*4882a593Smuzhiyun 	u8     sec_level;
316*4882a593Smuzhiyun 	u8     role_switch;
317*4882a593Smuzhiyun };
318*4882a593Smuzhiyun 
319*4882a593Smuzhiyun int  rfcomm_init_sockets(void);
320*4882a593Smuzhiyun void rfcomm_cleanup_sockets(void);
321*4882a593Smuzhiyun 
322*4882a593Smuzhiyun int  rfcomm_connect_ind(struct rfcomm_session *s, u8 channel,
323*4882a593Smuzhiyun 							struct rfcomm_dlc **d);
324*4882a593Smuzhiyun 
325*4882a593Smuzhiyun /* ---- RFCOMM TTY ---- */
326*4882a593Smuzhiyun #define RFCOMM_MAX_DEV  256
327*4882a593Smuzhiyun 
328*4882a593Smuzhiyun #define RFCOMMCREATEDEV		_IOW('R', 200, int)
329*4882a593Smuzhiyun #define RFCOMMRELEASEDEV	_IOW('R', 201, int)
330*4882a593Smuzhiyun #define RFCOMMGETDEVLIST	_IOR('R', 210, int)
331*4882a593Smuzhiyun #define RFCOMMGETDEVINFO	_IOR('R', 211, int)
332*4882a593Smuzhiyun #define RFCOMMSTEALDLC		_IOW('R', 220, int)
333*4882a593Smuzhiyun 
334*4882a593Smuzhiyun /* rfcomm_dev.flags bit definitions */
335*4882a593Smuzhiyun #define RFCOMM_REUSE_DLC      0
336*4882a593Smuzhiyun #define RFCOMM_RELEASE_ONHUP  1
337*4882a593Smuzhiyun #define RFCOMM_HANGUP_NOW     2
338*4882a593Smuzhiyun #define RFCOMM_TTY_ATTACHED   3
339*4882a593Smuzhiyun #define RFCOMM_DEFUNCT_BIT4   4	  /* don't reuse this bit - userspace visible */
340*4882a593Smuzhiyun 
341*4882a593Smuzhiyun /* rfcomm_dev.status bit definitions */
342*4882a593Smuzhiyun #define RFCOMM_DEV_RELEASED   0
343*4882a593Smuzhiyun #define RFCOMM_TTY_OWNED      1
344*4882a593Smuzhiyun 
345*4882a593Smuzhiyun struct rfcomm_dev_req {
346*4882a593Smuzhiyun 	s16      dev_id;
347*4882a593Smuzhiyun 	u32      flags;
348*4882a593Smuzhiyun 	bdaddr_t src;
349*4882a593Smuzhiyun 	bdaddr_t dst;
350*4882a593Smuzhiyun 	u8       channel;
351*4882a593Smuzhiyun };
352*4882a593Smuzhiyun 
353*4882a593Smuzhiyun struct rfcomm_dev_info {
354*4882a593Smuzhiyun 	s16      id;
355*4882a593Smuzhiyun 	u32      flags;
356*4882a593Smuzhiyun 	u16      state;
357*4882a593Smuzhiyun 	bdaddr_t src;
358*4882a593Smuzhiyun 	bdaddr_t dst;
359*4882a593Smuzhiyun 	u8       channel;
360*4882a593Smuzhiyun };
361*4882a593Smuzhiyun 
362*4882a593Smuzhiyun struct rfcomm_dev_list_req {
363*4882a593Smuzhiyun 	u16      dev_num;
364*4882a593Smuzhiyun 	struct   rfcomm_dev_info dev_info[];
365*4882a593Smuzhiyun };
366*4882a593Smuzhiyun 
367*4882a593Smuzhiyun int  rfcomm_dev_ioctl(struct sock *sk, unsigned int cmd, void __user *arg);
368*4882a593Smuzhiyun 
369*4882a593Smuzhiyun #ifdef CONFIG_BT_RFCOMM_TTY
370*4882a593Smuzhiyun int  rfcomm_init_ttys(void);
371*4882a593Smuzhiyun void rfcomm_cleanup_ttys(void);
372*4882a593Smuzhiyun #else
rfcomm_init_ttys(void)373*4882a593Smuzhiyun static inline int rfcomm_init_ttys(void)
374*4882a593Smuzhiyun {
375*4882a593Smuzhiyun 	return 0;
376*4882a593Smuzhiyun }
rfcomm_cleanup_ttys(void)377*4882a593Smuzhiyun static inline void rfcomm_cleanup_ttys(void)
378*4882a593Smuzhiyun {
379*4882a593Smuzhiyun }
380*4882a593Smuzhiyun #endif
381*4882a593Smuzhiyun #endif /* __RFCOMM_H */
382