blob: b20a1731759b2e6dc8bbe3064933bb3d67134d26 [file] [log] [blame]
Andrey Vagin0f29c762013-03-21 20:33:47 +04001#ifndef _AF_NETLINK_H
2#define _AF_NETLINK_H
3
Thomas Grafe3416942014-08-02 11:47:45 +02004#include <linux/rhashtable.h>
Andrey Vagin0f29c762013-03-21 20:33:47 +04005#include <net/sock.h>
6
7#define NLGRPSZ(x) (ALIGN(x, sizeof(unsigned long) * 8) / 8)
8#define NLGRPLONGS(x) (NLGRPSZ(x)/sizeof(unsigned long))
9
Patrick McHardyccdfcc32013-04-17 06:47:01 +000010struct netlink_ring {
11 void **pg_vec;
12 unsigned int head;
13 unsigned int frames_per_block;
14 unsigned int frame_size;
15 unsigned int frame_max;
16
17 unsigned int pg_vec_order;
18 unsigned int pg_vec_pages;
19 unsigned int pg_vec_len;
20
21 atomic_t pending;
22};
23
Andrey Vagin0f29c762013-03-21 20:33:47 +040024struct netlink_sock {
25 /* struct sock has to be the first member of netlink_sock */
26 struct sock sk;
27 u32 portid;
28 u32 dst_portid;
29 u32 dst_group;
30 u32 flags;
31 u32 subscriptions;
32 u32 ngroups;
33 unsigned long *groups;
34 unsigned long state;
Eric Dumazet9063e212014-03-07 12:02:33 -080035 size_t max_recvmsg_len;
Andrey Vagin0f29c762013-03-21 20:33:47 +040036 wait_queue_head_t wait;
Pravin B Shelar16b304f2013-08-15 15:31:06 -070037 bool cb_running;
38 struct netlink_callback cb;
Andrey Vagin0f29c762013-03-21 20:33:47 +040039 struct mutex *cb_mutex;
40 struct mutex cb_def_mutex;
41 void (*netlink_rcv)(struct sk_buff *skb);
Richard Guy Briggs4f520902014-04-22 21:31:54 -040042 int (*netlink_bind)(int group);
43 void (*netlink_unbind)(int group);
Andrey Vagin0f29c762013-03-21 20:33:47 +040044 struct module *module;
Patrick McHardyccdfcc32013-04-17 06:47:01 +000045#ifdef CONFIG_NETLINK_MMAP
46 struct mutex pg_vec_lock;
47 struct netlink_ring rx_ring;
48 struct netlink_ring tx_ring;
49 atomic_t mapped;
50#endif /* CONFIG_NETLINK_MMAP */
Thomas Grafe3416942014-08-02 11:47:45 +020051
52 struct rhash_head node;
Andrey Vagin0f29c762013-03-21 20:33:47 +040053};
54
55static inline struct netlink_sock *nlk_sk(struct sock *sk)
56{
57 return container_of(sk, struct netlink_sock, sk);
58}
59
Andrey Vagin0f29c762013-03-21 20:33:47 +040060struct netlink_table {
Thomas Grafe3416942014-08-02 11:47:45 +020061 struct rhashtable hash;
Andrey Vagin0f29c762013-03-21 20:33:47 +040062 struct hlist_head mc_list;
63 struct listeners __rcu *listeners;
64 unsigned int flags;
65 unsigned int groups;
66 struct mutex *cb_mutex;
67 struct module *module;
Richard Guy Briggs4f520902014-04-22 21:31:54 -040068 int (*bind)(int group);
69 void (*unbind)(int group);
Gao fengda12c902013-06-06 14:49:11 +080070 bool (*compare)(struct net *net, struct sock *sock);
Andrey Vagin0f29c762013-03-21 20:33:47 +040071 int registered;
72};
73
74extern struct netlink_table *nl_table;
75extern rwlock_t nl_table_lock;
Thomas Graf6c8f7e72014-08-07 00:18:47 +010076extern struct mutex nl_sk_hash_lock;
Andrey Vagin0f29c762013-03-21 20:33:47 +040077
78#endif