/* BNEP protocol definition for Linux Bluetooth stack (BlueZ). Copyright (C) 2002 Maxim Krasnyansky 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. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, see . */ #ifndef _BNEP_H #define _BNEP_H #include #include #include /* Limits */ #define BNEP_MAX_PROTO_FILTERS 5 #define BNEP_MAX_MULTICAST_FILTERS 20 /* UUIDs */ #define BNEP_BASE_UUID 0x0000000000001000800000805F9B34FB #define BNEP_UUID16 0x02 #define BNEP_UUID32 0x04 #define BNEP_UUID128 0x16 #define BNEP_SVC_PANU 0x1115 #define BNEP_SVC_NAP 0x1116 #define BNEP_SVC_GN 0x1117 /* Packet types */ #define BNEP_GENERAL 0x00 #define BNEP_CONTROL 0x01 #define BNEP_COMPRESSED 0x02 #define BNEP_COMPRESSED_SRC_ONLY 0x03 #define BNEP_COMPRESSED_DST_ONLY 0x04 /* Control types */ #define BNEP_CMD_NOT_UNDERSTOOD 0x00 #define BNEP_SETUP_CONN_REQ 0x01 #define BNEP_SETUP_CONN_RSP 0x02 #define BNEP_FILTER_NET_TYPE_SET 0x03 #define BNEP_FILTER_NET_TYPE_RSP 0x04 #define BNEP_FILTER_MULTI_ADDR_SET 0x05 #define BNEP_FILTER_MULTI_ADDR_RSP 0x06 /* Extension types */ #define BNEP_EXT_CONTROL 0x00 /* Response messages */ #define BNEP_SUCCESS 0x00 #define BNEP_CONN_INVALID_DST 0x01 #define BNEP_CONN_INVALID_SRC 0x02 #define BNEP_CONN_INVALID_SVC 0x03 #define BNEP_CONN_NOT_ALLOWED 0x04 #define BNEP_FILTER_UNSUPPORTED_REQ 0x01 #define BNEP_FILTER_INVALID_RANGE 0x02 #define BNEP_FILTER_INVALID_MCADDR 0x02 #define BNEP_FILTER_LIMIT_REACHED 0x03 #define BNEP_FILTER_DENIED_SECURITY 0x04 /* L2CAP settings */ #define BNEP_MTU 1691 #define BNEP_PSM 0x0f #define BNEP_FLUSH_TO 0xffff #define BNEP_CONNECT_TO 15 #define BNEP_FILTER_TO 15 /* Headers */ #define BNEP_TYPE_MASK 0x7f #define BNEP_EXT_HEADER 0x80 struct bnep_setup_conn_req { __u8 type; __u8 ctrl; __u8 uuid_size; __u8 service[0]; } __packed; struct bnep_set_filter_req { __u8 type; __u8 ctrl; __be16 len; __u8 list[0]; } __packed; struct bnep_control_rsp { __u8 type; __u8 ctrl; __be16 resp; } __packed; struct bnep_ext_hdr { __u8 type; __u8 len; __u8 data[0]; } __packed; /* BNEP ioctl defines */ #define BNEPCONNADD _IOW('B', 200, int) #define BNEPCONNDEL _IOW('B', 201, int) #define BNEPGETCONNLIST _IOR('B', 210, int) #define BNEPGETCONNINFO _IOR('B', 211, int) #define BNEPGETSUPPFEAT _IOR('B', 212, int) #define BNEP_SETUP_RESPONSE 0 #define BNEP_SETUP_RSP_SENT 10 struct bnep_connadd_req { int sock; /* Connected socket */ __u32 flags; __u16 role; char device[16]; /* Name of the Ethernet device */ }; struct bnep_conndel_req { __u32 flags; __u8 dst[ETH_ALEN]; }; struct bnep_conninfo { __u32 flags; __u16 role; __u16 state; __u8 dst[ETH_ALEN]; char device[16]; }; struct bnep_connlist_req { __u32 cnum; struct bnep_conninfo __user *ci; }; struct bnep_proto_filter { __u16 start; __u16 end; }; int bnep_add_connection(struct bnep_connadd_req *req, struct socket *sock); int bnep_del_connection(struct bnep_conndel_req *req); int bnep_get_connlist(struct bnep_connlist_req *req); int bnep_get_conninfo(struct bnep_conninfo *ci); /* BNEP sessions */ struct bnep_session { struct list_head list; unsigned int role; unsigned long state; unsigned long flags; atomic_t terminate; struct task_struct *task; struct ethhdr eh; struct msghdr msg; struct bnep_proto_filter proto_filter[BNEP_MAX_PROTO_FILTERS]; unsigned long long mc_filter; struct socket *sock; struct net_device *dev; }; void bnep_net_setup(struct net_device *dev); int bnep_sock_init(void); void bnep_sock_cleanup(void); static inline int bnep_mc_hash(__u8 *addr) { return crc32_be(~0, addr, ETH_ALEN) >> 26; } #endif option>space:mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-01-01 12:27:05 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-01-01 12:27:05 -0800
commit4759d386d55fef452d692bf101167914437e848e (patch)
treee7109c192ec589fcea2a98f9702aa3c0e4009581 /sound/pci/vx222/Makefile
parent238d1d0f79f619d75c2cc741d6770fb0986aef24 (diff)
parent1db175428ee374489448361213e9c3b749d14900 (diff)
Merge branch 'libnvdimm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm
Pull DAX updates from Dan Williams: "The completion of Jan's DAX work for 4.10. As I mentioned in the libnvdimm-for-4.10 pull request, these are some final fixes for the DAX dirty-cacheline-tracking invalidation work that was merged through the -mm, ext4, and xfs trees in -rc1. These patches were prepared prior to the merge window, but we waited for 4.10-rc1 to have a stable merge base after all the prerequisites were merged. Quoting Jan on the overall changes in these patches: "So I'd like all these 6 patches to go for rc2. The first three patches fix invalidation of exceptional DAX entries (a bug which is there for a long time) - without these patches data loss can occur on power failure even though user called fsync(2). The other three patches change locking of DAX faults so that ->iomap_begin() is called in a more relaxed locking context and we are safe to start a transaction there for ext4" These have received a build success notification from the kbuild robot, and pass the latest libnvdimm unit tests. There have not been any -next releases since -rc1, so they have not appeared there" * 'libnvdimm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm: ext4: Simplify DAX fault path dax: Call ->iomap_begin without entry lock during dax fault dax: Finish fault completely when loading holes dax: Avoid page invalidation races and unnecessary radix tree traversals mm: Invalidate DAX radix tree entries only if appropriate ext2: Return BH_New buffers for zeroed blocks
Diffstat (limited to 'sound/pci/vx222/Makefile')