Commit | Line | Data |
---|---|---|
f9e815b3 HW |
1 | #ifndef _NFNETLINK_H |
2 | #define _NFNETLINK_H | |
ac6d439d | 3 | |
f9e815b3 | 4 | |
080774a2 | 5 | #include <linux/netlink.h> |
f9e815b3 | 6 | #include <linux/capability.h> |
df6fb868 | 7 | #include <net/netlink.h> |
94d0ec58 | 8 | #include <uapi/linux/netfilter/nfnetlink.h> |
f9e815b3 | 9 | |
d94d9fee | 10 | struct nfnl_callback { |
7b8002a1 | 11 | int (*call)(struct net *net, struct sock *nl, struct sk_buff *skb, |
6b75e3e8 ED |
12 | const struct nlmsghdr *nlh, |
13 | const struct nlattr * const cda[]); | |
7b8002a1 PNA |
14 | int (*call_rcu)(struct net *net, struct sock *nl, struct sk_buff *skb, |
15 | const struct nlmsghdr *nlh, | |
16 | const struct nlattr * const cda[]); | |
633c9a84 | 17 | int (*call_batch)(struct net *net, struct sock *nl, struct sk_buff *skb, |
0628b123 PNA |
18 | const struct nlmsghdr *nlh, |
19 | const struct nlattr * const cda[]); | |
e3730578 PM |
20 | const struct nla_policy *policy; /* netlink attribute policy */ |
21 | const u_int16_t attr_count; /* number of nlattr's */ | |
f9e815b3 HW |
22 | }; |
23 | ||
d94d9fee | 24 | struct nfnetlink_subsystem { |
f9e815b3 | 25 | const char *name; |
7c8d4cb4 PM |
26 | __u8 subsys_id; /* nfnetlink subsystem ID */ |
27 | __u8 cb_count; /* number of callbacks */ | |
28 | const struct nfnl_callback *cb; /* callback for individual types */ | |
5913beaf PNA |
29 | int (*commit)(struct net *net, struct sk_buff *skb); |
30 | int (*abort)(struct net *net, struct sk_buff *skb); | |
f9e815b3 HW |
31 | }; |
32 | ||
a0f4ecf3 JP |
33 | int nfnetlink_subsys_register(const struct nfnetlink_subsystem *n); |
34 | int nfnetlink_subsys_unregister(const struct nfnetlink_subsystem *n); | |
35 | ||
36 | int nfnetlink_has_listeners(struct net *net, unsigned int group); | |
a0f4ecf3 JP |
37 | int nfnetlink_send(struct sk_buff *skb, struct net *net, u32 portid, |
38 | unsigned int group, int echo, gfp_t flags); | |
39 | int nfnetlink_set_err(struct net *net, u32 portid, u32 group, int error); | |
40 | int nfnetlink_unicast(struct sk_buff *skb, struct net *net, u32 portid, | |
41 | int flags); | |
42 | ||
43 | void nfnl_lock(__u8 subsys_id); | |
44 | void nfnl_unlock(__u8 subsys_id); | |
0eb5db7a | 45 | #ifdef CONFIG_PROVE_LOCKING |
875e0829 | 46 | bool lockdep_nfnl_is_held(__u8 subsys_id); |
0eb5db7a | 47 | #else |
875e0829 | 48 | static inline bool lockdep_nfnl_is_held(__u8 subsys_id) |
0eb5db7a | 49 | { |
875e0829 | 50 | return true; |
0eb5db7a PM |
51 | } |
52 | #endif /* CONFIG_PROVE_LOCKING */ | |
53 | ||
54 | /* | |
55 | * nfnl_dereference - fetch RCU pointer when updates are prevented by subsys mutex | |
56 | * | |
57 | * @p: The pointer to read, prior to dereferencing | |
58 | * @ss: The nfnetlink subsystem ID | |
59 | * | |
60 | * Return the value of the specified RCU-protected pointer, but omit | |
61 | * both the smp_read_barrier_depends() and the ACCESS_ONCE(), because | |
62 | * caller holds the NFNL subsystem mutex. | |
63 | */ | |
64 | #define nfnl_dereference(p, ss) \ | |
65 | rcu_dereference_protected(p, lockdep_nfnl_is_held(ss)) | |
e6a7d3c0 | 66 | |
0ab43f84 HW |
67 | #define MODULE_ALIAS_NFNL_SUBSYS(subsys) \ |
68 | MODULE_ALIAS("nfnetlink-subsys-" __stringify(subsys)) | |
69 | ||
f9e815b3 | 70 | #endif /* _NFNETLINK_H */ |