1 /* SPDX-License-Identifier: GPL-2.0 */
5 #include <linux/rhashtable.h>
6 #include <linux/atomic.h>
7 #include <linux/workqueue.h>
11 #define NETLINK_F_KERNEL_SOCKET 0x1
12 #define NETLINK_F_RECV_PKTINFO 0x2
13 #define NETLINK_F_BROADCAST_SEND_ERROR 0x4
14 #define NETLINK_F_RECV_NO_ENOBUFS 0x8
15 #define NETLINK_F_LISTEN_ALL_NSID 0x10
16 #define NETLINK_F_CAP_ACK 0x20
17 #define NETLINK_F_EXT_ACK 0x40
18 #define NETLINK_F_STRICT_CHK 0x80
20 #define NLGRPSZ(x) (ALIGN(x, sizeof(unsigned long) * 8) / 8)
21 #define NLGRPLONGS(x) (NLGRPSZ(x)/sizeof(unsigned long))
24 /* struct sock has to be the first member of netlink_sock */
32 unsigned long *groups
;
34 size_t max_recvmsg_len
;
35 wait_queue_head_t wait
;
39 struct netlink_callback cb
;
40 struct mutex
*cb_mutex
;
41 struct mutex cb_def_mutex
;
42 void (*netlink_rcv
)(struct sk_buff
*skb
);
43 int (*netlink_bind
)(struct net
*net
, int group
);
44 void (*netlink_unbind
)(struct net
*net
, int group
);
45 struct module
*module
;
47 struct rhash_head node
;
49 struct work_struct work
;
52 static inline struct netlink_sock
*nlk_sk(struct sock
*sk
)
54 return container_of(sk
, struct netlink_sock
, sk
);
57 struct netlink_table
{
58 struct rhashtable hash
;
59 struct hlist_head mc_list
;
60 struct listeners __rcu
*listeners
;
63 struct mutex
*cb_mutex
;
64 struct module
*module
;
65 int (*bind
)(struct net
*net
, int group
);
66 void (*unbind
)(struct net
*net
, int group
);
67 bool (*compare
)(struct net
*net
, struct sock
*sock
);
71 extern struct netlink_table
*nl_table
;
72 extern rwlock_t nl_table_lock
;