[lvc-project] [PATCH 5.10] bpf: fix potential 32-bit overflow when accessing ARRAY map element
Fedor Pchelkin
pchelkin at ispras.ru
Mon Mar 16 13:59:57 MSK 2026
On Mon, 16. Mar 12:35, Viktoriya Danchenko wrote:
> From: Andrii Nakryiko <andrii at kernel.org>
>
> [ Upstream commit 87ac0d600943994444e24382a87aa19acc4cd3d4 ]
>
> If BPF array map is bigger than 4GB, element pointer calculation can
> overflow because both index and elem_size are u32. Fix this everywhere
> by forcing 64-bit multiplication. Extract this formula into separate
> small helper and use it consistently in various places.
>
> Speculative-preventing formula utilizing index_mask trick is left as is,
> but explicit u64 casts are added in both places.
>
> Fixes: c85d69135a91 ("bpf: move memory size checks to bpf_map_charge_init()")
> Signed-off-by: Andrii Nakryiko <andrii at kernel.org>
> Link: https://lore.kernel.org/r/20220715053146.1291891-2-andrii@kernel.org
> Signed-off-by: Alexei Starovoitov <ast at kernel.org>
> Signed-off-by: Sasha Levin <sashal at kernel.org>
> Signed-off-by: Andrey Algin <a.algin at omp.ru>
> Signed-off-by: Viktoriya Danchenko <v.danchenko at omp.ru>
Для будущих бэкпортов: просьба ставить от себя поясняющий комментарий в
квадратных скобках над своей подписью, поясняющий, если пришлось
устранять нетривиальный конфликт при переносе патча. Так другим будет
понятно, что вы как минимум проанализировали конфликтное место, а не
машинально устранили его.
Устранение нескольких неактуальных для стабильной ветки частей патча
_не является тривиальным_ и достойно краткого комментария.
Здесь более чем достаточно общей фразы:
[ Viktoriya: drop patch hunks not relevant for 5.10 and related to newer
functionality, namely added by:
- 68134668c17f ("bpf: Add map side support for bpf timers.")
- 14a324f6a67e ("bpf: Wire up freeing of referenced kptr")
- 06dcdcd4b9e8 ("bpf: Add arraymap support for bpf_for_each_map_elem()
helper") ]
Коммиты перечислять необязательно, но таким образом вы чётко всё
обоснуете.
> ---
> Backport fix for CVE-2022-50167
> ---
> kernel/bpf/arraymap.c | 13 +++++++++----
> 1 file changed, 9 insertions(+), 4 deletions(-)
>
> diff --git a/kernel/bpf/arraymap.c b/kernel/bpf/arraymap.c
> index 3d92e42c3895..06f27f4bdf59 100644
> --- a/kernel/bpf/arraymap.c
> +++ b/kernel/bpf/arraymap.c
> @@ -174,6 +174,11 @@ static struct bpf_map *array_map_alloc(union bpf_attr *attr)
> return &array->map;
> }
>
> +static void *array_map_elem_ptr(struct bpf_array* array, u32 index)
> +{
> + return array->value + (u64)array->elem_size * index;
> +}
> +
> /* Called from syscall or from eBPF program */
> static void *array_map_lookup_elem(struct bpf_map *map, void *key)
> {
> @@ -183,7 +188,7 @@ static void *array_map_lookup_elem(struct bpf_map *map, void *key)
> if (unlikely(index >= array->map.max_entries))
> return NULL;
>
> - return array->value + array->elem_size * (index & array->index_mask);
> + return array->value + (u64)array->elem_size * (index & array->index_mask);
> }
>
> static int array_map_direct_value_addr(const struct bpf_map *map, u64 *imm,
> @@ -335,7 +340,7 @@ static int array_map_update_elem(struct bpf_map *map, void *key, void *value,
> value, map->value_size);
> } else {
> val = array->value +
> - array->elem_size * (index & array->index_mask);
> + (u64)array->elem_size * (index & array->index_mask);
> if (map_flags & BPF_F_LOCK)
> copy_map_value_locked(map, val, value, false);
> else
> @@ -530,7 +535,7 @@ static void *bpf_array_map_seq_start(struct seq_file *seq, loff_t *pos)
> index = info->index & array->index_mask;
> if (info->percpu_value_buf)
> return array->pptrs[index];
> - return array->value + array->elem_size * index;
> + return array_map_elem_ptr(array, index);
> }
>
> static void *bpf_array_map_seq_next(struct seq_file *seq, void *v, loff_t *pos)
> @@ -549,7 +554,7 @@ static void *bpf_array_map_seq_next(struct seq_file *seq, void *v, loff_t *pos)
> index = info->index & array->index_mask;
> if (info->percpu_value_buf)
> return array->pptrs[index];
> - return array->value + array->elem_size * index;
> + return array_map_elem_ptr(array, index);
> }
>
> static int __bpf_array_map_seq_show(struct seq_file *seq, void *v)
> --
> 2.43.0
More information about the lvc-project
mailing list