netfilter: call nf_hook_state_init with rcu_read_lock held
[cascardo/linux.git] / include / linux / netfilter_ingress.h
1 #ifndef _NETFILTER_INGRESS_H_
2 #define _NETFILTER_INGRESS_H_
3
4 #include <linux/netfilter.h>
5 #include <linux/netdevice.h>
6
7 #ifdef CONFIG_NETFILTER_INGRESS
8 static inline bool nf_hook_ingress_active(const struct sk_buff *skb)
9 {
10 #ifdef HAVE_JUMP_LABEL
11         if (!static_key_false(&nf_hooks_needed[NFPROTO_NETDEV][NF_NETDEV_INGRESS]))
12                 return false;
13 #endif
14         return !list_empty(&skb->dev->nf_hooks_ingress);
15 }
16
17 /* caller must hold rcu_read_lock */
18 static inline int nf_hook_ingress(struct sk_buff *skb)
19 {
20         struct nf_hook_state state;
21
22         nf_hook_state_init(&state, &skb->dev->nf_hooks_ingress,
23                            NF_NETDEV_INGRESS, INT_MIN, NFPROTO_NETDEV,
24                            skb->dev, NULL, NULL, dev_net(skb->dev), NULL);
25         return nf_hook_slow(skb, &state);
26 }
27
28 static inline void nf_hook_ingress_init(struct net_device *dev)
29 {
30         INIT_LIST_HEAD(&dev->nf_hooks_ingress);
31 }
32 #else /* CONFIG_NETFILTER_INGRESS */
33 static inline int nf_hook_ingress_active(struct sk_buff *skb)
34 {
35         return 0;
36 }
37
38 static inline int nf_hook_ingress(struct sk_buff *skb)
39 {
40         return 0;
41 }
42
43 static inline void nf_hook_ingress_init(struct net_device *dev) {}
44 #endif /* CONFIG_NETFILTER_INGRESS */
45 #endif /* _NETFILTER_INGRESS_H_ */