mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 13:53:24 +00:00
for-net
-----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEE+soXsSLHKoYyzcli6rmadz2vbToFAmYExnMACgkQ6rmadz2v bTofuA/8CVtNs4vcBfHSDaz9SzcSOp5pGhmUFHpwXkE5NPyi6tTRFRxfCkEK9/UG 1z9J54U6I7HB/6zbrhf1PP9c7ZbD9awPYTXude1cQaN9lgyxnfl5rfMDj4H5+5S7 TlmXxtFXUDlhcl8Hayxxe8UEZd6VPbfTP0/b7BRsesrT+G3+FxVf1Mh43NjEllYQ Fn/s/4UpYxz0YJCuud97fL+Vd04Dpx33ZihhIXU0hQ85ieyRMozat9o8n2bTsUGv 7K9Jsp9SzLpELeS/ScbzCqgU5mAJYfQWaXtt7tRNOpetvmL3/HQGAM3JRmPlOtna KDjZFO8ihIxSpqxXxwLjy3Z9SgzwqfVn6SP4cA+vhK2Nbk1vItAD/BvPkxsX1Zl+ Q8zSHQGNtoz+dMPlQtU1nEjVdk8YxQ/R9OI807CuiifY6590V13SfiNnxgoC213A tduI8q/EBFvAnuA8IJlutfVasHRuqCPmn0PXYWnlaWJP9tExE3shjCJG2Qmy3+bC z8RHeswujidR22VL8vDLxRKtlDl3mOclBqSJa+Cz5gH3oEBlvMfD0UU8CFeiEM4p ngryIc2dtd4Jd7eDKw2caNq+rgaTXpUjFi34deR0T0jO+YEwHGw6Kr/JYvU4UovY /YgGIeQXNMoO5eI72nNyDIeZNwENZLnt2P618vjIPDL+Pqau7go= =Sz5u -----END PGP SIGNATURE----- Merge tag 'for-net' of https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf Alexei Starovoitov says: ==================== pull-request: bpf 2024-03-27 The following pull-request contains BPF updates for your *net* tree. We've added 4 non-merge commits during the last 1 day(s) which contain a total of 5 files changed, 26 insertions(+), 3 deletions(-). The main changes are: 1) Fix bloom filter value size validation and protect the verifier against such mistakes, from Andrei. 2) Fix build due to CONFIG_KEXEC_CORE/CRASH_DUMP split, from Hari. 3) Update bpf_lsm maintainers entry, from Matt. * tag 'for-net' of https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf: bpf: update BPF LSM designated reviewer list bpf: Protect against int overflow for stack access size bpf: Check bloom filter map value size bpf: fix warning for crash_kexec ==================== Link: https://lore.kernel.org/r/20240328012938.24249-1-alexei.starovoitov@gmail.com Signed-off-by: Paolo Abeni <pabeni@redhat.com>
This commit is contained in:
commit
7e6f4b2af5
@ -3941,8 +3941,7 @@ F: kernel/bpf/ringbuf.c
|
|||||||
|
|
||||||
BPF [SECURITY & LSM] (Security Audit and Enforcement using BPF)
|
BPF [SECURITY & LSM] (Security Audit and Enforcement using BPF)
|
||||||
M: KP Singh <kpsingh@kernel.org>
|
M: KP Singh <kpsingh@kernel.org>
|
||||||
R: Florent Revest <revest@chromium.org>
|
R: Matt Bobrowski <mattbobrowski@google.com>
|
||||||
R: Brendan Jackman <jackmanb@chromium.org>
|
|
||||||
L: bpf@vger.kernel.org
|
L: bpf@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/bpf/prog_lsm.rst
|
F: Documentation/bpf/prog_lsm.rst
|
||||||
|
@ -80,6 +80,18 @@ static int bloom_map_get_next_key(struct bpf_map *map, void *key, void *next_key
|
|||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Called from syscall */
|
||||||
|
static int bloom_map_alloc_check(union bpf_attr *attr)
|
||||||
|
{
|
||||||
|
if (attr->value_size > KMALLOC_MAX_SIZE)
|
||||||
|
/* if value_size is bigger, the user space won't be able to
|
||||||
|
* access the elements.
|
||||||
|
*/
|
||||||
|
return -E2BIG;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static struct bpf_map *bloom_map_alloc(union bpf_attr *attr)
|
static struct bpf_map *bloom_map_alloc(union bpf_attr *attr)
|
||||||
{
|
{
|
||||||
u32 bitset_bytes, bitset_mask, nr_hash_funcs, nr_bits;
|
u32 bitset_bytes, bitset_mask, nr_hash_funcs, nr_bits;
|
||||||
@ -191,6 +203,7 @@ static u64 bloom_map_mem_usage(const struct bpf_map *map)
|
|||||||
BTF_ID_LIST_SINGLE(bpf_bloom_map_btf_ids, struct, bpf_bloom_filter)
|
BTF_ID_LIST_SINGLE(bpf_bloom_map_btf_ids, struct, bpf_bloom_filter)
|
||||||
const struct bpf_map_ops bloom_filter_map_ops = {
|
const struct bpf_map_ops bloom_filter_map_ops = {
|
||||||
.map_meta_equal = bpf_map_meta_equal,
|
.map_meta_equal = bpf_map_meta_equal,
|
||||||
|
.map_alloc_check = bloom_map_alloc_check,
|
||||||
.map_alloc = bloom_map_alloc,
|
.map_alloc = bloom_map_alloc,
|
||||||
.map_free = bloom_map_free,
|
.map_free = bloom_map_free,
|
||||||
.map_get_next_key = bloom_map_get_next_key,
|
.map_get_next_key = bloom_map_get_next_key,
|
||||||
|
@ -2548,7 +2548,7 @@ __bpf_kfunc void bpf_throw(u64 cookie)
|
|||||||
__bpf_kfunc_end_defs();
|
__bpf_kfunc_end_defs();
|
||||||
|
|
||||||
BTF_KFUNCS_START(generic_btf_ids)
|
BTF_KFUNCS_START(generic_btf_ids)
|
||||||
#ifdef CONFIG_KEXEC_CORE
|
#ifdef CONFIG_CRASH_DUMP
|
||||||
BTF_ID_FLAGS(func, crash_kexec, KF_DESTRUCTIVE)
|
BTF_ID_FLAGS(func, crash_kexec, KF_DESTRUCTIVE)
|
||||||
#endif
|
#endif
|
||||||
BTF_ID_FLAGS(func, bpf_obj_new_impl, KF_ACQUIRE | KF_RET_NULL)
|
BTF_ID_FLAGS(func, bpf_obj_new_impl, KF_ACQUIRE | KF_RET_NULL)
|
||||||
|
@ -6701,6 +6701,11 @@ static int check_stack_access_within_bounds(
|
|||||||
err = check_stack_slot_within_bounds(env, min_off, state, type);
|
err = check_stack_slot_within_bounds(env, min_off, state, type);
|
||||||
if (!err && max_off > 0)
|
if (!err && max_off > 0)
|
||||||
err = -EINVAL; /* out of stack access into non-negative offsets */
|
err = -EINVAL; /* out of stack access into non-negative offsets */
|
||||||
|
if (!err && access_size < 0)
|
||||||
|
/* access_size should not be negative (or overflow an int); others checks
|
||||||
|
* along the way should have prevented such an access.
|
||||||
|
*/
|
||||||
|
err = -EFAULT; /* invalid negative access size; integer overflow? */
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
if (tnum_is_const(reg->var_off)) {
|
if (tnum_is_const(reg->var_off)) {
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
/* Copyright (c) 2021 Facebook */
|
/* Copyright (c) 2021 Facebook */
|
||||||
|
|
||||||
#include <sys/syscall.h>
|
#include <sys/syscall.h>
|
||||||
|
#include <limits.h>
|
||||||
#include <test_progs.h>
|
#include <test_progs.h>
|
||||||
#include "bloom_filter_map.skel.h"
|
#include "bloom_filter_map.skel.h"
|
||||||
|
|
||||||
@ -21,6 +22,11 @@ static void test_fail_cases(void)
|
|||||||
if (!ASSERT_LT(fd, 0, "bpf_map_create bloom filter invalid value size 0"))
|
if (!ASSERT_LT(fd, 0, "bpf_map_create bloom filter invalid value size 0"))
|
||||||
close(fd);
|
close(fd);
|
||||||
|
|
||||||
|
/* Invalid value size: too big */
|
||||||
|
fd = bpf_map_create(BPF_MAP_TYPE_BLOOM_FILTER, NULL, 0, INT32_MAX, 100, NULL);
|
||||||
|
if (!ASSERT_LT(fd, 0, "bpf_map_create bloom filter invalid value too large"))
|
||||||
|
close(fd);
|
||||||
|
|
||||||
/* Invalid max entries size */
|
/* Invalid max entries size */
|
||||||
fd = bpf_map_create(BPF_MAP_TYPE_BLOOM_FILTER, NULL, 0, sizeof(value), 0, NULL);
|
fd = bpf_map_create(BPF_MAP_TYPE_BLOOM_FILTER, NULL, 0, sizeof(value), 0, NULL);
|
||||||
if (!ASSERT_LT(fd, 0, "bpf_map_create bloom filter invalid max entries size"))
|
if (!ASSERT_LT(fd, 0, "bpf_map_create bloom filter invalid max entries size"))
|
||||||
|
Loading…
Reference in New Issue
Block a user