2010-12-01 17:58:26 +03:00
/*
2005-04-17 02:20:36 +04:00
BlueZ - Bluetooth protocol stack for Linux
Copyright ( C ) 2000 - 2001 Qualcomm Incorporated
2010-07-13 18:57:11 +04:00
Copyright ( C ) 2009 - 2010 Gustavo F . Padovan < gustavo @ padovan . org >
2010-07-16 23:18:39 +04:00
Copyright ( C ) 2010 Google Inc .
2005-04-17 02:20:36 +04:00
Written 2000 , 2001 by Maxim Krasnyansky < maxk @ qualcomm . com >
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License version 2 as
published by the Free Software Foundation ;
THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS
OR IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS .
IN NO EVENT SHALL THE COPYRIGHT HOLDER ( S ) AND AUTHOR ( S ) BE LIABLE FOR ANY
2010-12-01 17:58:26 +03:00
CLAIM , OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES , OR ANY DAMAGES
WHATSOEVER RESULTING FROM LOSS OF USE , DATA OR PROFITS , WHETHER IN AN
ACTION OF CONTRACT , NEGLIGENCE OR OTHER TORTIOUS ACTION , ARISING OUT OF
2005-04-17 02:20:36 +04:00
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE .
2010-12-01 17:58:26 +03:00
ALL LIABILITY , INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS ,
COPYRIGHTS , TRADEMARKS OR OTHER RIGHTS , RELATING TO USE OF THIS
2005-04-17 02:20:36 +04:00
SOFTWARE IS DISCLAIMED .
*/
# ifndef __L2CAP_H
# define __L2CAP_H
/* L2CAP defaults */
2009-05-03 05:57:55 +04:00
# define L2CAP_DEFAULT_MTU 672
2009-07-04 22:06:24 +04:00
# define L2CAP_DEFAULT_MIN_MTU 48
2009-05-03 05:57:55 +04:00
# define L2CAP_DEFAULT_FLUSH_TO 0xffff
2009-08-21 05:25:57 +04:00
# define L2CAP_DEFAULT_TX_WINDOW 63
2011-10-11 14:37:42 +04:00
# define L2CAP_DEFAULT_EXT_WINDOW 0x3FFF
2009-08-21 05:26:00 +04:00
# define L2CAP_DEFAULT_MAX_TX 3
2010-08-06 02:54:20 +04:00
# define L2CAP_DEFAULT_RETRANS_TO 2000 /* 2 seconds */
2009-08-21 05:26:00 +04:00
# define L2CAP_DEFAULT_MONITOR_TO 12000 /* 12 seconds */
2010-08-06 02:54:27 +04:00
# define L2CAP_DEFAULT_MAX_PDU_SIZE 1009 /* Sized for 3-DH5 packet */
2010-05-01 23:15:39 +04:00
# define L2CAP_DEFAULT_ACK_TO 200
2011-02-11 04:38:50 +03:00
# define L2CAP_LE_DEFAULT_MTU 23
2011-10-13 17:18:54 +04:00
# define L2CAP_DEFAULT_MAX_SDU_SIZE 0xFFFF
# define L2CAP_DEFAULT_SDU_ITIME 0xFFFFFFFF
# define L2CAP_DEFAULT_ACC_LAT 0xFFFFFFFF
2005-04-17 02:20:36 +04:00
2007-10-20 15:37:56 +04:00
# define L2CAP_CONN_TIMEOUT (40000) /* 40 seconds */
# define L2CAP_INFO_TIMEOUT (4000) /* 4 seconds */
2005-04-17 02:20:36 +04:00
/* L2CAP socket address */
struct sockaddr_l2 {
sa_family_t l2_family ;
2007-07-29 11:16:36 +04:00
__le16 l2_psm ;
2005-04-17 02:20:36 +04:00
bdaddr_t l2_bdaddr ;
2009-02-12 07:07:45 +03:00
__le16 l2_cid ;
2005-04-17 02:20:36 +04:00
} ;
/* L2CAP socket options */
# define L2CAP_OPTIONS 0x01
struct l2cap_options {
__u16 omtu ;
__u16 imtu ;
__u16 flush_to ;
__u8 mode ;
2009-08-21 05:26:02 +04:00
__u8 fcs ;
2010-05-01 23:15:41 +04:00
__u8 max_tx ;
2010-05-01 23:15:40 +04:00
__u16 txwin_size ;
2005-04-17 02:20:36 +04:00
} ;
# define L2CAP_CONNINFO 0x02
struct l2cap_conninfo {
__u16 hci_handle ;
__u8 dev_class [ 3 ] ;
} ;
# define L2CAP_LM 0x03
# define L2CAP_LM_MASTER 0x0001
# define L2CAP_LM_AUTH 0x0002
# define L2CAP_LM_ENCRYPT 0x0004
# define L2CAP_LM_TRUSTED 0x0008
# define L2CAP_LM_RELIABLE 0x0010
# define L2CAP_LM_SECURE 0x0020
/* L2CAP command codes */
2009-05-03 05:57:55 +04:00
# define L2CAP_COMMAND_REJ 0x01
# define L2CAP_CONN_REQ 0x02
# define L2CAP_CONN_RSP 0x03
# define L2CAP_CONF_REQ 0x04
# define L2CAP_CONF_RSP 0x05
# define L2CAP_DISCONN_REQ 0x06
# define L2CAP_DISCONN_RSP 0x07
# define L2CAP_ECHO_REQ 0x08
# define L2CAP_ECHO_RSP 0x09
# define L2CAP_INFO_REQ 0x0a
# define L2CAP_INFO_RSP 0x0b
2011-02-12 00:28:54 +03:00
# define L2CAP_CONN_PARAM_UPDATE_REQ 0x12
# define L2CAP_CONN_PARAM_UPDATE_RSP 0x13
2009-05-03 05:57:55 +04:00
2011-09-16 17:26:30 +04:00
/* L2CAP extended feature mask */
2009-05-03 05:57:55 +04:00
# define L2CAP_FEAT_FLOWCTL 0x00000001
# define L2CAP_FEAT_RETRANS 0x00000002
2011-09-16 17:26:30 +04:00
# define L2CAP_FEAT_BIDIR_QOS 0x00000004
2009-05-03 05:57:55 +04:00
# define L2CAP_FEAT_ERTM 0x00000008
# define L2CAP_FEAT_STREAMING 0x00000010
# define L2CAP_FEAT_FCS 0x00000020
2011-09-16 17:26:30 +04:00
# define L2CAP_FEAT_EXT_FLOW 0x00000040
2009-05-03 05:57:55 +04:00
# define L2CAP_FEAT_FIXED_CHAN 0x00000080
2011-09-16 17:26:30 +04:00
# define L2CAP_FEAT_EXT_WINDOW 0x00000100
# define L2CAP_FEAT_UCD 0x00000200
2009-05-03 05:57:55 +04:00
/* L2CAP checksum option */
# define L2CAP_FCS_NONE 0x00
# define L2CAP_FCS_CRC16 0x01
2005-04-17 02:20:36 +04:00
2009-08-21 05:25:57 +04:00
/* L2CAP Control Field bit masks */
2011-10-11 14:37:43 +04:00
# define L2CAP_CTRL_SAR 0xC000
# define L2CAP_CTRL_REQSEQ 0x3F00
# define L2CAP_CTRL_TXSEQ 0x007E
# define L2CAP_CTRL_SUPERVISE 0x000C
# define L2CAP_CTRL_RETRANS 0x0080
# define L2CAP_CTRL_FINAL 0x0080
# define L2CAP_CTRL_POLL 0x0010
# define L2CAP_CTRL_FRAME_TYPE 0x0001 /* I- or S-Frame */
# define L2CAP_CTRL_TXSEQ_SHIFT 1
# define L2CAP_CTRL_SUPER_SHIFT 2
# define L2CAP_CTRL_REQSEQ_SHIFT 8
# define L2CAP_CTRL_SAR_SHIFT 14
/* L2CAP Extended Control Field bit mask */
# define L2CAP_EXT_CTRL_TXSEQ 0xFFFC0000
# define L2CAP_EXT_CTRL_SAR 0x00030000
# define L2CAP_EXT_CTRL_SUPERVISE 0x00030000
# define L2CAP_EXT_CTRL_REQSEQ 0x0000FFFC
# define L2CAP_EXT_CTRL_POLL 0x00040000
# define L2CAP_EXT_CTRL_FINAL 0x00000002
# define L2CAP_EXT_CTRL_FRAME_TYPE 0x00000001 /* I- or S-Frame */
# define L2CAP_EXT_CTRL_REQSEQ_SHIFT 2
# define L2CAP_EXT_CTRL_SAR_SHIFT 16
# define L2CAP_EXT_CTRL_SUPER_SHIFT 16
# define L2CAP_EXT_CTRL_TXSEQ_SHIFT 18
2009-08-21 05:25:57 +04:00
/* L2CAP Supervisory Function */
2011-10-11 14:37:44 +04:00
# define L2CAP_SUPER_RR 0x00
# define L2CAP_SUPER_REJ 0x01
# define L2CAP_SUPER_RNR 0x02
# define L2CAP_SUPER_SREJ 0x03
2009-08-21 05:25:57 +04:00
/* L2CAP Segmentation and Reassembly */
2011-10-11 14:37:45 +04:00
# define L2CAP_SAR_UNSEGMENTED 0x00
# define L2CAP_SAR_START 0x01
# define L2CAP_SAR_END 0x02
# define L2CAP_SAR_CONTINUE 0x03
2009-08-21 05:25:57 +04:00
2011-07-10 09:47:44 +04:00
/* L2CAP Command rej. reasons */
2011-10-11 14:37:41 +04:00
# define L2CAP_REJ_NOT_UNDERSTOOD 0x0000
# define L2CAP_REJ_MTU_EXCEEDED 0x0001
# define L2CAP_REJ_INVALID_CID 0x0002
2011-07-10 09:47:44 +04:00
2005-04-17 02:20:36 +04:00
/* L2CAP structures */
struct l2cap_hdr {
2007-07-29 11:16:36 +04:00
__le16 len ;
__le16 cid ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
# define L2CAP_HDR_SIZE 4
2011-10-11 14:37:54 +04:00
# define L2CAP_ENH_HDR_SIZE 6
# define L2CAP_EXT_HDR_SIZE 8
# define L2CAP_FCS_SIZE 2
# define L2CAP_SDULEN_SIZE 2
# define L2CAP_PSMLEN_SIZE 2
2005-04-17 02:20:36 +04:00
struct l2cap_cmd_hdr {
__u8 code ;
__u8 ident ;
2007-07-29 11:16:36 +04:00
__le16 len ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
# define L2CAP_CMD_HDR_SIZE 4
2011-07-10 09:47:44 +04:00
struct l2cap_cmd_rej_unk {
__le16 reason ;
} __packed ;
struct l2cap_cmd_rej_mtu {
2007-07-29 11:16:36 +04:00
__le16 reason ;
2011-07-10 09:47:44 +04:00
__le16 max_mtu ;
} __packed ;
struct l2cap_cmd_rej_cid {
__le16 reason ;
__le16 scid ;
__le16 dcid ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
struct l2cap_conn_req {
2007-07-29 11:16:36 +04:00
__le16 psm ;
__le16 scid ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
struct l2cap_conn_rsp {
2007-07-29 11:16:36 +04:00
__le16 dcid ;
__le16 scid ;
__le16 result ;
__le16 status ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
2009-04-20 08:31:05 +04:00
/* channel indentifier */
# define L2CAP_CID_SIGNALING 0x0001
# define L2CAP_CID_CONN_LESS 0x0002
2011-02-11 04:38:49 +03:00
# define L2CAP_CID_LE_DATA 0x0004
# define L2CAP_CID_LE_SIGNALING 0x0005
# define L2CAP_CID_SMP 0x0006
2009-04-20 08:31:05 +04:00
# define L2CAP_CID_DYN_START 0x0040
# define L2CAP_CID_DYN_END 0xffff
2005-04-17 02:20:36 +04:00
/* connect result */
2009-05-03 05:57:55 +04:00
# define L2CAP_CR_SUCCESS 0x0000
# define L2CAP_CR_PEND 0x0001
# define L2CAP_CR_BAD_PSM 0x0002
# define L2CAP_CR_SEC_BLOCK 0x0003
# define L2CAP_CR_NO_MEM 0x0004
2005-04-17 02:20:36 +04:00
/* connect status */
2009-05-03 05:57:55 +04:00
# define L2CAP_CS_NO_INFO 0x0000
# define L2CAP_CS_AUTHEN_PEND 0x0001
# define L2CAP_CS_AUTHOR_PEND 0x0002
2005-04-17 02:20:36 +04:00
struct l2cap_conf_req {
2007-07-29 11:16:36 +04:00
__le16 dcid ;
__le16 flags ;
2005-04-17 02:20:36 +04:00
__u8 data [ 0 ] ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
struct l2cap_conf_rsp {
2007-07-29 11:16:36 +04:00
__le16 scid ;
__le16 flags ;
__le16 result ;
2005-04-17 02:20:36 +04:00
__u8 data [ 0 ] ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
2007-05-24 16:27:19 +04:00
# define L2CAP_CONF_SUCCESS 0x0000
# define L2CAP_CONF_UNACCEPT 0x0001
# define L2CAP_CONF_REJECT 0x0002
# define L2CAP_CONF_UNKNOWN 0x0003
2011-10-13 17:18:53 +04:00
# define L2CAP_CONF_EFS_REJECT 0x0005
2005-04-17 02:20:36 +04:00
struct l2cap_conf_opt {
__u8 type ;
__u8 len ;
__u8 val [ 0 ] ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
# define L2CAP_CONF_OPT_SIZE 2
2009-04-20 08:31:07 +04:00
# define L2CAP_CONF_HINT 0x80
2009-05-03 05:57:55 +04:00
# define L2CAP_CONF_MASK 0x7f
2009-04-20 08:31:07 +04:00
2005-04-17 02:20:36 +04:00
# define L2CAP_CONF_MTU 0x01
# define L2CAP_CONF_FLUSH_TO 0x02
# define L2CAP_CONF_QOS 0x03
# define L2CAP_CONF_RFC 0x04
2009-05-03 05:57:55 +04:00
# define L2CAP_CONF_FCS 0x05
2011-10-13 17:18:53 +04:00
# define L2CAP_CONF_EFS 0x06
2011-10-11 14:37:42 +04:00
# define L2CAP_CONF_EWS 0x07
2005-04-17 02:20:36 +04:00
# define L2CAP_CONF_MAX_SIZE 22
2007-10-20 15:39:51 +04:00
struct l2cap_conf_rfc {
__u8 mode ;
__u8 txwin_size ;
__u8 max_transmit ;
__le16 retrans_timeout ;
__le16 monitor_timeout ;
__le16 max_pdu_size ;
2010-07-19 09:00:13 +04:00
} __packed ;
2007-10-20 15:39:51 +04:00
# define L2CAP_MODE_BASIC 0x00
# define L2CAP_MODE_RETRANS 0x01
# define L2CAP_MODE_FLOWCTL 0x02
2009-05-03 05:57:55 +04:00
# define L2CAP_MODE_ERTM 0x03
2009-05-03 09:31:10 +04:00
# define L2CAP_MODE_STREAMING 0x04
2007-10-20 15:39:51 +04:00
2011-10-13 17:18:53 +04:00
struct l2cap_conf_efs {
__u8 id ;
__u8 stype ;
__le16 msdu ;
__le32 sdu_itime ;
__le32 acc_lat ;
__le32 flush_to ;
} __packed ;
2011-10-13 17:18:54 +04:00
# define L2CAP_SERV_NOTRAFIC 0x00
# define L2CAP_SERV_BESTEFFORT 0x01
# define L2CAP_SERV_GUARANTEED 0x02
# define L2CAP_BESTEFFORT_ID 0x01
2005-04-17 02:20:36 +04:00
struct l2cap_disconn_req {
2007-07-29 11:16:36 +04:00
__le16 dcid ;
__le16 scid ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
struct l2cap_disconn_rsp {
2007-07-29 11:16:36 +04:00
__le16 dcid ;
__le16 scid ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
struct l2cap_info_req {
2007-07-29 11:16:36 +04:00
__le16 type ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
struct l2cap_info_rsp {
2007-07-29 11:16:36 +04:00
__le16 type ;
__le16 result ;
2005-04-17 02:20:36 +04:00
__u8 data [ 0 ] ;
2010-07-19 09:00:13 +04:00
} __packed ;
2005-04-17 02:20:36 +04:00
/* info type */
2011-10-11 14:37:41 +04:00
# define L2CAP_IT_CL_MTU 0x0001
# define L2CAP_IT_FEAT_MASK 0x0002
# define L2CAP_IT_FIXED_CHAN 0x0003
2005-04-17 02:20:36 +04:00
/* info result */
2011-10-11 14:37:41 +04:00
# define L2CAP_IR_SUCCESS 0x0000
# define L2CAP_IR_NOTSUPP 0x0001
2005-04-17 02:20:36 +04:00
2011-02-12 00:28:55 +03:00
struct l2cap_conn_param_update_req {
__le16 min ;
__le16 max ;
__le16 latency ;
__le16 to_multiplier ;
} __packed ;
struct l2cap_conn_param_update_rsp {
__le16 result ;
} __packed ;
/* Connection Parameters result */
# define L2CAP_CONN_PARAM_ACCEPTED 0x0000
# define L2CAP_CONN_PARAM_REJECTED 0x0001
2011-03-25 06:22:30 +03:00
/* ----- L2CAP channels and connections ----- */
2011-04-04 22:40:12 +04:00
struct srej_list {
2011-10-11 14:37:47 +04:00
__u16 tx_seq ;
2011-04-04 22:40:12 +04:00
struct list_head list ;
} ;
2011-03-25 06:22:30 +03:00
struct l2cap_chan {
struct sock * sk ;
2011-04-14 03:23:55 +04:00
struct l2cap_conn * conn ;
2011-06-03 07:19:47 +04:00
__u8 state ;
2011-05-17 21:34:52 +04:00
atomic_t refcnt ;
2011-04-14 02:50:45 +04:00
__le16 psm ;
__u16 dcid ;
__u16 scid ;
2011-04-13 01:31:57 +04:00
2011-04-14 00:20:49 +04:00
__u16 imtu ;
__u16 omtu ;
__u16 flush_to ;
__u8 mode ;
2011-05-03 00:13:55 +04:00
__u8 chan_type ;
2011-04-14 00:20:49 +04:00
__le16 sport ;
2011-04-13 01:31:57 +04:00
__u8 sec_level ;
2011-03-25 19:59:37 +03:00
__u8 ident ;
2011-03-25 20:16:54 +03:00
__u8 conf_req [ 64 ] ;
__u8 conf_len ;
__u8 num_conf_req ;
__u8 num_conf_rsp ;
2011-04-13 22:57:03 +04:00
__u8 fcs ;
2011-10-11 14:37:42 +04:00
__u16 tx_win ;
2011-04-13 22:57:03 +04:00
__u8 max_tx ;
__u16 retrans_timeout ;
__u16 monitor_timeout ;
__u16 mps ;
2011-06-11 00:02:12 +04:00
unsigned long conf_state ;
2011-06-11 04:28:49 +04:00
unsigned long conn_state ;
2011-10-11 15:04:31 +04:00
unsigned long flags ;
2011-03-26 01:43:39 +03:00
2011-10-11 14:37:47 +04:00
__u16 next_tx_seq ;
__u16 expected_ack_seq ;
__u16 expected_tx_seq ;
2011-10-11 14:37:46 +04:00
__u16 buffer_seq ;
2011-10-11 14:37:47 +04:00
__u16 buffer_seq_srej ;
__u16 srej_save_reqseq ;
__u16 frames_sent ;
__u16 unacked_frames ;
2011-04-01 07:38:50 +04:00
__u8 retry_count ;
__u8 num_acked ;
2011-03-26 02:09:37 +03:00
__u16 sdu_len ;
struct sk_buff * sdu ;
2011-07-23 01:54:00 +04:00
struct sk_buff * sdu_last_frag ;
2011-03-26 02:09:37 +03:00
2011-10-11 14:37:42 +04:00
__u16 remote_tx_win ;
2011-03-26 02:15:28 +03:00
__u8 remote_max_tx ;
__u16 remote_mps ;
2011-03-26 01:58:34 +03:00
2011-10-13 17:18:53 +04:00
__u8 local_id ;
__u8 local_stype ;
__u16 local_msdu ;
__u32 local_sdu_itime ;
__u32 local_acc_lat ;
__u32 local_flush_to ;
__u8 remote_id ;
__u8 remote_stype ;
__u16 remote_msdu ;
__u32 remote_sdu_itime ;
__u32 remote_acc_lat ;
__u32 remote_flush_to ;
2011-05-03 01:25:01 +04:00
struct timer_list chan_timer ;
2011-04-01 07:53:45 +04:00
struct timer_list retrans_timer ;
struct timer_list monitor_timer ;
struct timer_list ack_timer ;
2011-04-04 23:16:44 +04:00
struct sk_buff * tx_send_head ;
struct sk_buff_head tx_q ;
2011-03-26 02:36:10 +03:00
struct sk_buff_head srej_q ;
2011-04-04 22:40:12 +04:00
struct list_head srej_l ;
2011-04-01 07:53:45 +04:00
2011-03-31 23:17:41 +04:00
struct list_head list ;
2011-04-28 01:26:32 +04:00
struct list_head global_l ;
2011-05-17 00:24:37 +04:00
void * data ;
struct l2cap_ops * ops ;
} ;
struct l2cap_ops {
char * name ;
struct l2cap_chan * ( * new_connection ) ( void * data ) ;
2011-05-17 00:57:22 +04:00
int ( * recv ) ( void * data , struct sk_buff * skb ) ;
2011-05-17 01:23:24 +04:00
void ( * close ) ( void * data ) ;
2011-06-03 07:19:47 +04:00
void ( * state_change ) ( void * data , int state ) ;
2005-04-17 02:20:36 +04:00
} ;
struct l2cap_conn {
struct hci_conn * hcon ;
bdaddr_t * dst ;
bdaddr_t * src ;
unsigned int mtu ;
2007-10-20 15:37:56 +04:00
__u32 feat_mask ;
__u8 info_state ;
__u8 info_ident ;
struct timer_list info_timer ;
2005-04-17 02:20:36 +04:00
spinlock_t lock ;
struct sk_buff * rx_skb ;
__u32 rx_len ;
__u8 tx_ident ;
2009-02-12 16:02:50 +03:00
__u8 disc_reason ;
2011-06-14 20:37:41 +04:00
struct timer_list security_timer ;
2011-09-05 21:31:30 +04:00
struct smp_chan * smp_chan ;
2011-06-14 20:37:41 +04:00
2011-03-31 23:17:41 +04:00
struct list_head chan_l ;
rwlock_t chan_lock ;
2005-04-17 02:20:36 +04:00
} ;
2007-10-20 15:37:56 +04:00
# define L2CAP_INFO_CL_MTU_REQ_SENT 0x01
2009-02-07 01:35:19 +03:00
# define L2CAP_INFO_FEAT_MASK_REQ_SENT 0x04
# define L2CAP_INFO_FEAT_MASK_REQ_DONE 0x08
2007-10-20 15:37:56 +04:00
2011-05-03 00:13:55 +04:00
# define L2CAP_CHAN_RAW 1
# define L2CAP_CHAN_CONN_LESS 2
# define L2CAP_CHAN_CONN_ORIENTED 3
2011-03-25 06:22:30 +03:00
/* ----- L2CAP socket info ----- */
2005-04-17 02:20:36 +04:00
# define l2cap_pi(sk) ((struct l2cap_pinfo *) sk)
struct l2cap_pinfo {
struct bt_sock bt ;
2011-03-25 06:22:30 +03:00
struct l2cap_chan * chan ;
2011-07-07 20:39:02 +04:00
struct sk_buff * rx_busy_skb ;
2005-04-17 02:20:36 +04:00
} ;
2011-06-11 00:02:12 +04:00
enum {
CONF_REQ_SENT ,
CONF_INPUT_DONE ,
CONF_OUTPUT_DONE ,
CONF_MTU_DONE ,
CONF_MODE_DONE ,
CONF_CONNECT_PEND ,
CONF_NO_FCS_RECV ,
CONF_STATE2_DEVICE ,
2011-10-11 14:37:42 +04:00
CONF_EWS_RECV ,
2011-06-11 00:02:12 +04:00
} ;
2009-07-04 22:06:24 +04:00
# define L2CAP_CONF_MAX_CONF_REQ 2
# define L2CAP_CONF_MAX_CONF_RSP 2
2007-10-20 15:37:06 +04:00
2011-06-11 04:28:49 +04:00
enum {
CONN_SREJ_SENT ,
CONN_WAIT_F ,
CONN_SREJ_ACT ,
CONN_SEND_PBIT ,
CONN_REMOTE_BUSY ,
CONN_LOCAL_BUSY ,
CONN_REJ_ACT ,
CONN_SEND_FBIT ,
CONN_RNR_SENT ,
} ;
2009-08-21 05:26:00 +04:00
2011-10-11 15:04:31 +04:00
/* Definitions for flags in l2cap_chan */
enum {
2011-10-11 15:04:34 +04:00
FLAG_ROLE_SWITCH ,
2011-10-11 15:04:33 +04:00
FLAG_FORCE_ACTIVE ,
2011-10-11 15:04:32 +04:00
FLAG_FORCE_RELIABLE ,
2011-10-11 15:04:31 +04:00
FLAG_FLUSHABLE ,
2011-10-11 14:37:42 +04:00
FLAG_EXT_CTRL ,
2011-10-13 17:18:53 +04:00
FLAG_EFS_ENABLE ,
2011-10-11 15:04:31 +04:00
} ;
2011-05-17 21:59:01 +04:00
# define __set_chan_timer(c, t) l2cap_set_timer(c, &c->chan_timer, (t))
# define __clear_chan_timer(c) l2cap_clear_timer(c, &c->chan_timer)
2011-05-17 22:13:19 +04:00
# define __set_retrans_timer(c) l2cap_set_timer(c, &c->retrans_timer, \
L2CAP_DEFAULT_RETRANS_TO ) ;
# define __clear_retrans_timer(c) l2cap_clear_timer(c, &c->retrans_timer)
# define __set_monitor_timer(c) l2cap_set_timer(c, &c->monitor_timer, \
L2CAP_DEFAULT_MONITOR_TO ) ;
# define __clear_monitor_timer(c) l2cap_clear_timer(c, &c->monitor_timer)
# define __set_ack_timer(c) l2cap_set_timer(c, &chan->ack_timer, \
L2CAP_DEFAULT_ACK_TO ) ;
# define __clear_ack_timer(c) l2cap_clear_timer(c, &c->ack_timer)
2009-08-21 05:25:58 +04:00
2011-03-26 01:58:34 +03:00
static inline int l2cap_tx_window_full ( struct l2cap_chan * ch )
2009-08-21 05:25:57 +04:00
{
int sub ;
2011-03-26 01:58:34 +03:00
sub = ( ch - > next_tx_seq - ch - > expected_ack_seq ) % 64 ;
2009-08-21 05:25:57 +04:00
if ( sub < 0 )
sub + = 64 ;
2011-03-26 02:15:28 +03:00
return sub = = ch - > remote_tx_win ;
2009-08-21 05:25:57 +04:00
}
2011-10-11 14:37:46 +04:00
static inline __u16 __get_reqseq ( struct l2cap_chan * chan , __u32 ctrl )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( ctrl & L2CAP_EXT_CTRL_REQSEQ ) > >
L2CAP_EXT_CTRL_REQSEQ_SHIFT ;
else
return ( ctrl & L2CAP_CTRL_REQSEQ ) > > L2CAP_CTRL_REQSEQ_SHIFT ;
}
static inline __u32 __set_reqseq ( struct l2cap_chan * chan , __u32 reqseq )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( reqseq < < L2CAP_EXT_CTRL_REQSEQ_SHIFT ) &
L2CAP_EXT_CTRL_REQSEQ ;
else
return ( reqseq < < L2CAP_CTRL_REQSEQ_SHIFT ) & L2CAP_CTRL_REQSEQ ;
}
2011-10-11 14:37:47 +04:00
static inline __u16 __get_txseq ( struct l2cap_chan * chan , __u32 ctrl )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( ctrl & L2CAP_EXT_CTRL_TXSEQ ) > >
L2CAP_EXT_CTRL_TXSEQ_SHIFT ;
else
return ( ctrl & L2CAP_CTRL_TXSEQ ) > > L2CAP_CTRL_TXSEQ_SHIFT ;
}
static inline __u32 __set_txseq ( struct l2cap_chan * chan , __u32 txseq )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( txseq < < L2CAP_EXT_CTRL_TXSEQ_SHIFT ) &
L2CAP_EXT_CTRL_TXSEQ ;
else
return ( txseq < < L2CAP_CTRL_TXSEQ_SHIFT ) & L2CAP_CTRL_TXSEQ ;
}
2011-10-11 14:37:48 +04:00
static inline bool __is_sframe ( struct l2cap_chan * chan , __u32 ctrl )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ctrl & L2CAP_EXT_CTRL_FRAME_TYPE ;
else
return ctrl & L2CAP_CTRL_FRAME_TYPE ;
}
static inline __u32 __set_sframe ( struct l2cap_chan * chan )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return L2CAP_EXT_CTRL_FRAME_TYPE ;
else
return L2CAP_CTRL_FRAME_TYPE ;
}
2011-10-11 14:37:45 +04:00
static inline __u8 __get_ctrl_sar ( struct l2cap_chan * chan , __u32 ctrl )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( ctrl & L2CAP_EXT_CTRL_SAR ) > > L2CAP_EXT_CTRL_SAR_SHIFT ;
else
return ( ctrl & L2CAP_CTRL_SAR ) > > L2CAP_CTRL_SAR_SHIFT ;
}
static inline __u32 __set_ctrl_sar ( struct l2cap_chan * chan , __u32 sar )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( sar < < L2CAP_EXT_CTRL_SAR_SHIFT ) & L2CAP_EXT_CTRL_SAR ;
else
return ( sar < < L2CAP_CTRL_SAR_SHIFT ) & L2CAP_CTRL_SAR ;
}
static inline bool __is_sar_start ( struct l2cap_chan * chan , __u32 ctrl )
{
return __get_ctrl_sar ( chan , ctrl ) = = L2CAP_SAR_START ;
}
static inline __u32 __get_sar_mask ( struct l2cap_chan * chan )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return L2CAP_EXT_CTRL_SAR ;
else
return L2CAP_CTRL_SAR ;
}
2005-04-17 02:20:36 +04:00
2011-10-11 14:37:44 +04:00
static inline __u8 __get_ctrl_super ( struct l2cap_chan * chan , __u32 ctrl )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( ctrl & L2CAP_EXT_CTRL_SUPERVISE ) > >
L2CAP_EXT_CTRL_SUPER_SHIFT ;
else
return ( ctrl & L2CAP_CTRL_SUPERVISE ) > > L2CAP_CTRL_SUPER_SHIFT ;
}
static inline __u32 __set_ctrl_super ( struct l2cap_chan * chan , __u32 super )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ( super < < L2CAP_EXT_CTRL_SUPER_SHIFT ) &
L2CAP_EXT_CTRL_SUPERVISE ;
else
return ( super < < L2CAP_CTRL_SUPER_SHIFT ) &
L2CAP_CTRL_SUPERVISE ;
}
2011-10-11 14:37:49 +04:00
static inline __u32 __set_ctrl_final ( struct l2cap_chan * chan )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return L2CAP_EXT_CTRL_FINAL ;
else
return L2CAP_CTRL_FINAL ;
}
static inline bool __is_ctrl_final ( struct l2cap_chan * chan , __u32 ctrl )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ctrl & L2CAP_EXT_CTRL_FINAL ;
else
return ctrl & L2CAP_CTRL_FINAL ;
}
2011-10-11 14:37:50 +04:00
static inline __u32 __set_ctrl_poll ( struct l2cap_chan * chan )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return L2CAP_EXT_CTRL_POLL ;
else
return L2CAP_CTRL_POLL ;
}
static inline bool __is_ctrl_poll ( struct l2cap_chan * chan , __u32 ctrl )
{
if ( test_bit ( FLAG_EXT_CTRL , & chan - > flags ) )
return ctrl & L2CAP_EXT_CTRL_POLL ;
else
return ctrl & L2CAP_CTRL_POLL ;
}
2011-02-04 01:50:35 +03:00
extern int disable_ertm ;
int l2cap_init_sockets ( void ) ;
void l2cap_cleanup_sockets ( void ) ;
2011-04-14 03:23:55 +04:00
void __l2cap_connect_rsp_defer ( struct l2cap_chan * chan ) ;
2011-02-04 08:08:36 +03:00
int __l2cap_wait_ack ( struct sock * sk ) ;
2011-02-04 08:02:31 +03:00
2011-04-19 01:38:43 +04:00
int l2cap_add_psm ( struct l2cap_chan * chan , bdaddr_t * src , __le16 psm ) ;
int l2cap_add_scid ( struct l2cap_chan * chan , __u16 scid ) ;
2011-04-28 01:26:32 +04:00
struct l2cap_chan * l2cap_chan_create ( struct sock * sk ) ;
2011-05-05 02:42:50 +04:00
void l2cap_chan_close ( struct l2cap_chan * chan , int reason ) ;
2011-04-28 01:26:32 +04:00
void l2cap_chan_destroy ( struct l2cap_chan * chan ) ;
2011-04-13 01:17:14 +04:00
int l2cap_chan_connect ( struct l2cap_chan * chan ) ;
2011-04-29 01:50:17 +04:00
int l2cap_chan_send ( struct l2cap_chan * chan , struct msghdr * msg , size_t len ) ;
2011-07-07 20:39:02 +04:00
void l2cap_chan_busy ( struct l2cap_chan * chan , int busy ) ;
2011-02-04 01:50:35 +03:00
2005-04-17 02:20:36 +04:00
# endif /* __L2CAP_H */