1caab277bSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
21da177e4SLinus Torvalds /*
31da177e4SLinus Torvalds BNEP protocol definition for Linux Bluetooth stack (BlueZ).
41da177e4SLinus Torvalds Copyright (C) 2002 Maxim Krasnyansky <maxk@qualcomm.com>
51da177e4SLinus Torvalds
61da177e4SLinus Torvalds */
71da177e4SLinus Torvalds
81da177e4SLinus Torvalds #ifndef _BNEP_H
91da177e4SLinus Torvalds #define _BNEP_H
101da177e4SLinus Torvalds
111da177e4SLinus Torvalds #include <linux/types.h>
121da177e4SLinus Torvalds #include <linux/crc32.h>
131da177e4SLinus Torvalds #include <net/bluetooth/bluetooth.h>
141da177e4SLinus Torvalds
153aad75a1SSzymon Janc /* Limits */
161da177e4SLinus Torvalds #define BNEP_MAX_PROTO_FILTERS 5
171da177e4SLinus Torvalds #define BNEP_MAX_MULTICAST_FILTERS 20
181da177e4SLinus Torvalds
193aad75a1SSzymon Janc /* UUIDs */
201da177e4SLinus Torvalds #define BNEP_BASE_UUID 0x0000000000001000800000805F9B34FB
211da177e4SLinus Torvalds #define BNEP_UUID16 0x02
221da177e4SLinus Torvalds #define BNEP_UUID32 0x04
231da177e4SLinus Torvalds #define BNEP_UUID128 0x16
241da177e4SLinus Torvalds
251da177e4SLinus Torvalds #define BNEP_SVC_PANU 0x1115
261da177e4SLinus Torvalds #define BNEP_SVC_NAP 0x1116
271da177e4SLinus Torvalds #define BNEP_SVC_GN 0x1117
281da177e4SLinus Torvalds
293aad75a1SSzymon Janc /* Packet types */
301da177e4SLinus Torvalds #define BNEP_GENERAL 0x00
311da177e4SLinus Torvalds #define BNEP_CONTROL 0x01
321da177e4SLinus Torvalds #define BNEP_COMPRESSED 0x02
331da177e4SLinus Torvalds #define BNEP_COMPRESSED_SRC_ONLY 0x03
341da177e4SLinus Torvalds #define BNEP_COMPRESSED_DST_ONLY 0x04
351da177e4SLinus Torvalds
363aad75a1SSzymon Janc /* Control types */
371da177e4SLinus Torvalds #define BNEP_CMD_NOT_UNDERSTOOD 0x00
381da177e4SLinus Torvalds #define BNEP_SETUP_CONN_REQ 0x01
391da177e4SLinus Torvalds #define BNEP_SETUP_CONN_RSP 0x02
401da177e4SLinus Torvalds #define BNEP_FILTER_NET_TYPE_SET 0x03
411da177e4SLinus Torvalds #define BNEP_FILTER_NET_TYPE_RSP 0x04
421da177e4SLinus Torvalds #define BNEP_FILTER_MULTI_ADDR_SET 0x05
431da177e4SLinus Torvalds #define BNEP_FILTER_MULTI_ADDR_RSP 0x06
441da177e4SLinus Torvalds
453aad75a1SSzymon Janc /* Extension types */
461da177e4SLinus Torvalds #define BNEP_EXT_CONTROL 0x00
471da177e4SLinus Torvalds
483aad75a1SSzymon Janc /* Response messages */
491da177e4SLinus Torvalds #define BNEP_SUCCESS 0x00
501da177e4SLinus Torvalds
511da177e4SLinus Torvalds #define BNEP_CONN_INVALID_DST 0x01
521da177e4SLinus Torvalds #define BNEP_CONN_INVALID_SRC 0x02
531da177e4SLinus Torvalds #define BNEP_CONN_INVALID_SVC 0x03
541da177e4SLinus Torvalds #define BNEP_CONN_NOT_ALLOWED 0x04
551da177e4SLinus Torvalds
561da177e4SLinus Torvalds #define BNEP_FILTER_UNSUPPORTED_REQ 0x01
571da177e4SLinus Torvalds #define BNEP_FILTER_INVALID_RANGE 0x02
581da177e4SLinus Torvalds #define BNEP_FILTER_INVALID_MCADDR 0x02
591da177e4SLinus Torvalds #define BNEP_FILTER_LIMIT_REACHED 0x03
601da177e4SLinus Torvalds #define BNEP_FILTER_DENIED_SECURITY 0x04
611da177e4SLinus Torvalds
623aad75a1SSzymon Janc /* L2CAP settings */
631da177e4SLinus Torvalds #define BNEP_MTU 1691
641da177e4SLinus Torvalds #define BNEP_PSM 0x0f
651da177e4SLinus Torvalds #define BNEP_FLUSH_TO 0xffff
661da177e4SLinus Torvalds #define BNEP_CONNECT_TO 15
671da177e4SLinus Torvalds #define BNEP_FILTER_TO 15
681da177e4SLinus Torvalds
693aad75a1SSzymon Janc /* Headers */
701da177e4SLinus Torvalds #define BNEP_TYPE_MASK 0x7f
711da177e4SLinus Torvalds #define BNEP_EXT_HEADER 0x80
721da177e4SLinus Torvalds
731da177e4SLinus Torvalds struct bnep_setup_conn_req {
741da177e4SLinus Torvalds __u8 type;
751da177e4SLinus Torvalds __u8 ctrl;
761da177e4SLinus Torvalds __u8 uuid_size;
77*a7e45454SGustavo A. R. Silva __u8 service[];
78bc10502dSEric Dumazet } __packed;
791da177e4SLinus Torvalds
801da177e4SLinus Torvalds struct bnep_set_filter_req {
811da177e4SLinus Torvalds __u8 type;
821da177e4SLinus Torvalds __u8 ctrl;
831bc5d448SAl Viro __be16 len;
84*a7e45454SGustavo A. R. Silva __u8 list[];
85bc10502dSEric Dumazet } __packed;
861da177e4SLinus Torvalds
871da177e4SLinus Torvalds struct bnep_control_rsp {
881da177e4SLinus Torvalds __u8 type;
891da177e4SLinus Torvalds __u8 ctrl;
901bc5d448SAl Viro __be16 resp;
91bc10502dSEric Dumazet } __packed;
921da177e4SLinus Torvalds
931da177e4SLinus Torvalds struct bnep_ext_hdr {
941da177e4SLinus Torvalds __u8 type;
951da177e4SLinus Torvalds __u8 len;
96*a7e45454SGustavo A. R. Silva __u8 data[];
97bc10502dSEric Dumazet } __packed;
981da177e4SLinus Torvalds
991da177e4SLinus Torvalds /* BNEP ioctl defines */
1001da177e4SLinus Torvalds #define BNEPCONNADD _IOW('B', 200, int)
1011da177e4SLinus Torvalds #define BNEPCONNDEL _IOW('B', 201, int)
1021da177e4SLinus Torvalds #define BNEPGETCONNLIST _IOR('B', 210, int)
1031da177e4SLinus Torvalds #define BNEPGETCONNINFO _IOR('B', 211, int)
1040477e2e8SGrzegorz Kolodziejczyk #define BNEPGETSUPPFEAT _IOR('B', 212, int)
1051da177e4SLinus Torvalds
106836a061bSGrzegorz Kolodziejczyk #define BNEP_SETUP_RESPONSE 0
107836a061bSGrzegorz Kolodziejczyk #define BNEP_SETUP_RSP_SENT 10
108836a061bSGrzegorz Kolodziejczyk
1091da177e4SLinus Torvalds struct bnep_connadd_req {
1103aad75a1SSzymon Janc int sock; /* Connected socket */
1111da177e4SLinus Torvalds __u32 flags;
1121da177e4SLinus Torvalds __u16 role;
1133aad75a1SSzymon Janc char device[16]; /* Name of the Ethernet device */
1141da177e4SLinus Torvalds };
1151da177e4SLinus Torvalds
1161da177e4SLinus Torvalds struct bnep_conndel_req {
1171da177e4SLinus Torvalds __u32 flags;
1181da177e4SLinus Torvalds __u8 dst[ETH_ALEN];
1191da177e4SLinus Torvalds };
1201da177e4SLinus Torvalds
1211da177e4SLinus Torvalds struct bnep_conninfo {
1221da177e4SLinus Torvalds __u32 flags;
1231da177e4SLinus Torvalds __u16 role;
1241da177e4SLinus Torvalds __u16 state;
1251da177e4SLinus Torvalds __u8 dst[ETH_ALEN];
1261da177e4SLinus Torvalds char device[16];
1271da177e4SLinus Torvalds };
1281da177e4SLinus Torvalds
1291da177e4SLinus Torvalds struct bnep_connlist_req {
1301da177e4SLinus Torvalds __u32 cnum;
1311da177e4SLinus Torvalds struct bnep_conninfo __user *ci;
1321da177e4SLinus Torvalds };
1331da177e4SLinus Torvalds
1341da177e4SLinus Torvalds struct bnep_proto_filter {
1351da177e4SLinus Torvalds __u16 start;
1361da177e4SLinus Torvalds __u16 end;
1371da177e4SLinus Torvalds };
1381da177e4SLinus Torvalds
1391da177e4SLinus Torvalds int bnep_add_connection(struct bnep_connadd_req *req, struct socket *sock);
1401da177e4SLinus Torvalds int bnep_del_connection(struct bnep_conndel_req *req);
1411da177e4SLinus Torvalds int bnep_get_connlist(struct bnep_connlist_req *req);
1421da177e4SLinus Torvalds int bnep_get_conninfo(struct bnep_conninfo *ci);
1431da177e4SLinus Torvalds
1443aad75a1SSzymon Janc /* BNEP sessions */
1451da177e4SLinus Torvalds struct bnep_session {
1461da177e4SLinus Torvalds struct list_head list;
1471da177e4SLinus Torvalds
1481da177e4SLinus Torvalds unsigned int role;
1491da177e4SLinus Torvalds unsigned long state;
1501da177e4SLinus Torvalds unsigned long flags;
151751c10a5SPeter Hurley atomic_t terminate;
152f4d7cd4aSSzymon Janc struct task_struct *task;
1531da177e4SLinus Torvalds
1541da177e4SLinus Torvalds struct ethhdr eh;
1551da177e4SLinus Torvalds struct msghdr msg;
1561da177e4SLinus Torvalds
1571da177e4SLinus Torvalds struct bnep_proto_filter proto_filter[BNEP_MAX_PROTO_FILTERS];
158a418b893SMarcel Holtmann unsigned long long mc_filter;
1591da177e4SLinus Torvalds
1601da177e4SLinus Torvalds struct socket *sock;
1611da177e4SLinus Torvalds struct net_device *dev;
1621da177e4SLinus Torvalds };
1631da177e4SLinus Torvalds
1641da177e4SLinus Torvalds void bnep_net_setup(struct net_device *dev);
1651da177e4SLinus Torvalds int bnep_sock_init(void);
166a4e2acf0STobias Klauser void bnep_sock_cleanup(void);
1671da177e4SLinus Torvalds
bnep_mc_hash(__u8 * addr)1681da177e4SLinus Torvalds static inline int bnep_mc_hash(__u8 *addr)
1691da177e4SLinus Torvalds {
1703aad75a1SSzymon Janc return crc32_be(~0, addr, ETH_ALEN) >> 26;
1711da177e4SLinus Torvalds }
1721da177e4SLinus Torvalds
1731da177e4SLinus Torvalds #endif
174