Eric Dumazet 97dab36e57 netfilter: complete validation of user input
[ Upstream commit 65acf6e0501ac8880a4f73980d01b5d27648b956 ]

In my recent commit, I missed that do_replace() handlers
use copy_from_sockptr() (which I fixed), followed
by unsafe copy_from_sockptr_offset() calls.

In all functions, we can perform the @optlen validation
before even calling xt_alloc_table_info() with the following
check:

if ((u64)optlen < (u64)tmp.size + sizeof(tmp))
        return -EINVAL;

Fixes: 0c83842df40f ("netfilter: validate user input for expected length")
Reported-by: syzbot <syzkaller@googlegroups.com>
Signed-off-by: Eric Dumazet <edumazet@google.com>
Reviewed-by: Pablo Neira Ayuso <pablo@netfilter.org>
Link: https://lore.kernel.org/r/20240409120741.3538135-1-edumazet@google.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2024-04-17 11:15:15 +02:00
..
2021-06-30 15:51:09 -07:00
2024-03-01 13:22:00 +01:00
2021-08-31 12:03:33 +01:00
2021-05-17 15:29:35 -07:00
2023-04-13 16:48:18 +02:00
2021-06-30 15:51:09 -07:00
2021-07-27 20:11:44 +01:00
2022-05-18 10:26:57 +02:00
2021-05-17 15:29:35 -07:00
2021-05-17 15:29:35 -07:00