Commit 781e3f1e authored by Maksim Krasnyanskiy's avatar Maksim Krasnyanskiy

Just like many other parts of the kernel Bluetooth code was abusing

typedefs for non opaque objects. This changeset cleans up L2CAP code
and headers. In addition it optimizes sendmsg for L2CAP sockets.
parent d70029d5
...@@ -89,37 +89,34 @@ struct l2cap_qos { ...@@ -89,37 +89,34 @@ struct l2cap_qos {
#define L2CAP_INFO_RSP 0x0b #define L2CAP_INFO_RSP 0x0b
/* L2CAP structures */ /* L2CAP structures */
typedef struct { struct l2cap_hdr {
__u16 len; __u16 len;
__u16 cid; __u16 cid;
} __attribute__ ((packed)) l2cap_hdr; } __attribute__ ((packed));
#define L2CAP_HDR_SIZE 4 #define L2CAP_HDR_SIZE 4
typedef struct { struct l2cap_cmd_hdr {
__u8 code; __u8 code;
__u8 ident; __u8 ident;
__u16 len; __u16 len;
} __attribute__ ((packed)) l2cap_cmd_hdr; } __attribute__ ((packed));
#define L2CAP_CMD_HDR_SIZE 4 #define L2CAP_CMD_HDR_SIZE 4
typedef struct { struct l2cap_cmd_rej {
__u16 reason; __u16 reason;
} __attribute__ ((packed)) l2cap_cmd_rej; } __attribute__ ((packed));
#define L2CAP_CMD_REJ_SIZE 2
typedef struct { struct l2cap_conn_req {
__u16 psm; __u16 psm;
__u16 scid; __u16 scid;
} __attribute__ ((packed)) l2cap_conn_req; } __attribute__ ((packed));
#define L2CAP_CONN_REQ_SIZE 4
typedef struct { struct l2cap_conn_rsp {
__u16 dcid; __u16 dcid;
__u16 scid; __u16 scid;
__u16 result; __u16 result;
__u16 status; __u16 status;
} __attribute__ ((packed)) l2cap_conn_rsp; } __attribute__ ((packed));
#define L2CAP_CONN_RSP_SIZE 8
/* connect result */ /* connect result */
#define L2CAP_CR_SUCCESS 0x0000 #define L2CAP_CR_SUCCESS 0x0000
...@@ -133,29 +130,27 @@ typedef struct { ...@@ -133,29 +130,27 @@ typedef struct {
#define L2CAP_CS_AUTHEN_PEND 0x0001 #define L2CAP_CS_AUTHEN_PEND 0x0001
#define L2CAP_CS_AUTHOR_PEND 0x0002 #define L2CAP_CS_AUTHOR_PEND 0x0002
typedef struct { struct l2cap_conf_req {
__u16 dcid; __u16 dcid;
__u16 flags; __u16 flags;
__u8 data[0]; __u8 data[0];
} __attribute__ ((packed)) l2cap_conf_req; } __attribute__ ((packed));
#define L2CAP_CONF_REQ_SIZE 4
typedef struct { struct l2cap_conf_rsp {
__u16 scid; __u16 scid;
__u16 flags; __u16 flags;
__u16 result; __u16 result;
__u8 data[0]; __u8 data[0];
} __attribute__ ((packed)) l2cap_conf_rsp; } __attribute__ ((packed));
#define L2CAP_CONF_RSP_SIZE 6
#define L2CAP_CONF_SUCCESS 0x00 #define L2CAP_CONF_SUCCESS 0x00
#define L2CAP_CONF_UNACCEPT 0x01 #define L2CAP_CONF_UNACCEPT 0x01
typedef struct { struct l2cap_conf_opt {
__u8 type; __u8 type;
__u8 len; __u8 len;
__u8 val[0]; __u8 val[0];
} __attribute__ ((packed)) l2cap_conf_opt; } __attribute__ ((packed));
#define L2CAP_CONF_OPT_SIZE 2 #define L2CAP_CONF_OPT_SIZE 2
#define L2CAP_CONF_MTU 0x01 #define L2CAP_CONF_MTU 0x01
...@@ -164,30 +159,26 @@ typedef struct { ...@@ -164,30 +159,26 @@ typedef struct {
#define L2CAP_CONF_MAX_SIZE 22 #define L2CAP_CONF_MAX_SIZE 22
typedef struct { struct l2cap_disconn_req {
__u16 dcid; __u16 dcid;
__u16 scid; __u16 scid;
} __attribute__ ((packed)) l2cap_disconn_req; } __attribute__ ((packed));
#define L2CAP_DISCONN_REQ_SIZE 4
typedef struct { struct l2cap_disconn_rsp {
__u16 dcid; __u16 dcid;
__u16 scid; __u16 scid;
} __attribute__ ((packed)) l2cap_disconn_rsp; } __attribute__ ((packed));
#define L2CAP_DISCONN_RSP_SIZE 4
typedef struct { struct l2cap_info_req {
__u16 type; __u16 type;
__u8 data[0]; __u8 data[0];
} __attribute__ ((packed)) l2cap_info_req; } __attribute__ ((packed));
#define L2CAP_INFO_REQ_SIZE 2
typedef struct { struct l2cap_info_rsp {
__u16 type; __u16 type;
__u16 result; __u16 result;
__u8 data[0]; __u8 data[0];
} __attribute__ ((packed)) l2cap_info_rsp; } __attribute__ ((packed));
#define L2CAP_INFO_RSP_SIZE 4
/* ----- L2CAP connections ----- */ /* ----- L2CAP connections ----- */
struct l2cap_chan_list { struct l2cap_chan_list {
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment