1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _NETFILTER_NETDEV_H_
3 #define _NETFILTER_NETDEV_H_
5 #include <linux/netfilter.h>
6 #include <linux/netdevice.h>
8 #ifdef CONFIG_NETFILTER_INGRESS
9 static inline bool nf_hook_ingress_active(const struct sk_buff
*skb
)
11 #ifdef CONFIG_JUMP_LABEL
12 if (!static_key_false(&nf_hooks_needed
[NFPROTO_NETDEV
][NF_NETDEV_INGRESS
]))
15 return rcu_access_pointer(skb
->dev
->nf_hooks_ingress
);
18 /* caller must hold rcu_read_lock */
19 static inline int nf_hook_ingress(struct sk_buff
*skb
)
21 struct nf_hook_entries
*e
= rcu_dereference(skb
->dev
->nf_hooks_ingress
);
22 struct nf_hook_state state
;
25 /* Must recheck the ingress hook head, in the event it became NULL
26 * after the check in nf_hook_ingress_active evaluated to true.
31 nf_hook_state_init(&state
, NF_NETDEV_INGRESS
,
32 NFPROTO_NETDEV
, skb
->dev
, NULL
, NULL
,
33 dev_net(skb
->dev
), NULL
);
34 ret
= nf_hook_slow(skb
, &state
, e
, 0);
41 #else /* CONFIG_NETFILTER_INGRESS */
42 static inline int nf_hook_ingress_active(struct sk_buff
*skb
)
47 static inline int nf_hook_ingress(struct sk_buff
*skb
)
51 #endif /* CONFIG_NETFILTER_INGRESS */
53 #ifdef CONFIG_NETFILTER_EGRESS
54 static inline bool nf_hook_egress_active(void)
56 #ifdef CONFIG_JUMP_LABEL
57 if (!static_key_false(&nf_hooks_needed
[NFPROTO_NETDEV
][NF_NETDEV_EGRESS
]))
64 * nf_hook_egress - classify packets before transmission
65 * @skb: packet to be classified
66 * @rc: result code which shall be returned by __dev_queue_xmit() on failure
67 * @dev: netdev whose egress hooks shall be applied to @skb
69 * Returns @skb on success or %NULL if the packet was consumed or filtered.
70 * Caller must hold rcu_read_lock.
72 * On ingress, packets are classified first by tc, then by netfilter.
73 * On egress, the order is reversed for symmetry. Conceptually, tc and
74 * netfilter can be thought of as layers, with netfilter layered above tc:
75 * When tc redirects a packet to another interface, netfilter is not applied
76 * because the packet is on the tc layer.
78 * The nf_skip_egress flag controls whether netfilter is applied on egress.
79 * It is updated by __netif_receive_skb_core() and __dev_queue_xmit() when the
80 * packet passes through tc and netfilter. Because __dev_queue_xmit() may be
81 * called recursively by tunnel drivers such as vxlan, the flag is reverted to
82 * false after sch_handle_egress(). This ensures that netfilter is applied
83 * both on the overlay and underlying network.
85 static inline struct sk_buff
*nf_hook_egress(struct sk_buff
*skb
, int *rc
,
86 struct net_device
*dev
)
88 struct nf_hook_entries
*e
;
89 struct nf_hook_state state
;
92 #ifdef CONFIG_NETFILTER_SKIP_EGRESS
93 if (skb
->nf_skip_egress
)
97 e
= rcu_dereference_check(dev
->nf_hooks_egress
, rcu_read_lock_bh_held());
101 nf_hook_state_init(&state
, NF_NETDEV_EGRESS
,
102 NFPROTO_NETDEV
, NULL
, dev
, NULL
,
105 /* nf assumes rcu_read_lock, not just read_lock_bh */
107 ret
= nf_hook_slow(skb
, &state
, e
, 0);
112 } else if (ret
< 0) {
115 } else { /* ret == 0 */
116 *rc
= NET_XMIT_SUCCESS
;
120 #else /* CONFIG_NETFILTER_EGRESS */
121 static inline bool nf_hook_egress_active(void)
126 static inline struct sk_buff
*nf_hook_egress(struct sk_buff
*skb
, int *rc
,
127 struct net_device
*dev
)
131 #endif /* CONFIG_NETFILTER_EGRESS */
133 static inline void nf_skip_egress(struct sk_buff
*skb
, bool skip
)
135 #ifdef CONFIG_NETFILTER_SKIP_EGRESS
136 skb
->nf_skip_egress
= skip
;
140 static inline void nf_hook_netdev_init(struct net_device
*dev
)
142 #ifdef CONFIG_NETFILTER_INGRESS
143 RCU_INIT_POINTER(dev
->nf_hooks_ingress
, NULL
);
145 #ifdef CONFIG_NETFILTER_EGRESS
146 RCU_INIT_POINTER(dev
->nf_hooks_egress
, NULL
);
150 #endif /* _NETFILTER_NETDEV_H_ */