]> www.infradead.org Git - users/dwmw2/linux.git/commit
Merge branch 'fix-hash-bucket-overflow-checks-for-32-bit-arches'
authorAlexei Starovoitov <ast@kernel.org>
Fri, 8 Mar 2024 04:02:39 +0000 (20:02 -0800)
committerAlexei Starovoitov <ast@kernel.org>
Fri, 8 Mar 2024 04:06:32 +0000 (20:06 -0800)
commita27e89673abf1623c298ea84eaa03f4c57aeca1b
tree055be779382b86723c540e8c180876dd163b4826
parentc7d4274e90a1e7aa43d11d2a16066cbbe610070e
parent7a4b21250bf79eef26543d35bd390448646c536b
Merge branch 'fix-hash-bucket-overflow-checks-for-32-bit-arches'

Toke Høiland-Jørgensen says:

====================
Fix hash bucket overflow checks for 32-bit arches

Syzbot managed to trigger a crash by creating a DEVMAP_HASH map with a
large number of buckets because the overflow check relies on
well-defined behaviour that is only correct on 64-bit arches.

Fix the overflow checks to happen before values are rounded up in all
the affected map types.

v3:
- Keep the htab->n_buckets > U32_MAX / sizeof(struct bucket) check
- Use 1UL << 31 instead of U32_MAX / 2 + 1 as the constant to check
  against
- Add patch to fix stackmap.c
v2:
- Fix off-by-one error in overflow check
- Apply the same fix to hashtab, where the devmap_hash code was copied
  from (John)

Toke Høiland-Jørgensen (3):
  bpf: Fix DEVMAP_HASH overflow check on 32-bit arches
  bpf: Fix hashtab overflow check on 32-bit arches
  bpf: Fix stackmap overflow check on 32-bit arches

 kernel/bpf/devmap.c   | 11 ++++++-----
 kernel/bpf/hashtab.c  | 14 +++++++++-----
 kernel/bpf/stackmap.c |  9 ++++++---
 3 files changed, 21 insertions(+), 13 deletions(-)
====================

Link: https://lore.kernel.org/r/20240307120340.99577-1-toke@redhat.com
Signed-off-by: Alexei Starovoitov <ast@kernel.org>