lwt: Check LWTUNNEL_XMIT_CONTINUE strictly
[ Upstream commita171fbec88
] LWTUNNEL_XMIT_CONTINUE is implicitly assumed in ip(6)_finish_output2, such that any positive return value from a xmit hook could cause unexpected continue behavior, despite that related skb may have been freed. This could be error-prone for future xmit hook ops. One of the possible errors is to return statuses of dst_output directly. To make the code safer, redefine LWTUNNEL_XMIT_CONTINUE value to distinguish from dst_output statuses and check the continue condition explicitly. Fixes:3a0af8fd61
("bpf: BPF for lightweight tunnel infrastructure") Suggested-by: Dan Carpenter <dan.carpenter@linaro.org> Signed-off-by: Yan Zhai <yan@cloudflare.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Link: https://lore.kernel.org/bpf/96b939b85eda00e8df4f7c080f770970a4c5f698.1692326837.git.yan@cloudflare.com Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
Родитель
e3f647e4b6
Коммит
f683992d30
|
@ -16,9 +16,12 @@
|
|||
#define LWTUNNEL_STATE_INPUT_REDIRECT BIT(1)
|
||||
#define LWTUNNEL_STATE_XMIT_REDIRECT BIT(2)
|
||||
|
||||
/* LWTUNNEL_XMIT_CONTINUE should be distinguishable from dst_output return
|
||||
* values (NET_XMIT_xxx and NETDEV_TX_xxx in linux/netdevice.h) for safety.
|
||||
*/
|
||||
enum {
|
||||
LWTUNNEL_XMIT_DONE,
|
||||
LWTUNNEL_XMIT_CONTINUE,
|
||||
LWTUNNEL_XMIT_CONTINUE = 0x100,
|
||||
};
|
||||
|
||||
|
||||
|
|
|
@ -214,7 +214,7 @@ static int ip_finish_output2(struct net *net, struct sock *sk, struct sk_buff *s
|
|||
if (lwtunnel_xmit_redirect(dst->lwtstate)) {
|
||||
int res = lwtunnel_xmit(skb);
|
||||
|
||||
if (res < 0 || res == LWTUNNEL_XMIT_DONE)
|
||||
if (res != LWTUNNEL_XMIT_CONTINUE)
|
||||
return res;
|
||||
}
|
||||
|
||||
|
|
|
@ -112,7 +112,7 @@ static int ip6_finish_output2(struct net *net, struct sock *sk, struct sk_buff *
|
|||
if (lwtunnel_xmit_redirect(dst->lwtstate)) {
|
||||
int res = lwtunnel_xmit(skb);
|
||||
|
||||
if (res < 0 || res == LWTUNNEL_XMIT_DONE)
|
||||
if (res != LWTUNNEL_XMIT_CONTINUE)
|
||||
return res;
|
||||
}
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче