]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
selftests/bpf: Rename libarena malloc/free methods
authorEmil Tsalapatis <emil@etsalapatis.com>
Tue, 28 Apr 2026 13:42:52 +0000 (06:42 -0700)
committerAlexei Starovoitov <ast@kernel.org>
Tue, 28 Apr 2026 14:40:21 +0000 (07:40 -0700)
The s390 architecture uses the token "free" for an enum, conflicting
with the malloc/free definitions. Rename the calls to arena_malloc and
arena_free instead to prevent collisions.

Reported-by: Ihor Solodrai <ihor.solodrai@linux.dev>
Signed-off-by: Emil Tsalapatis <etsal@meta.com>
Fixes: 86426a28c52d ("selftests/bpf: Add buddy allocator for libarena")
Acked-by: Ihor Solodrai <ihor.solodrai@linux.dev>
Link: https://lore.kernel.org/r/20260428134252.2783519-1-etsal@meta.com
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
tools/testing/selftests/bpf/libarena/Makefile
tools/testing/selftests/bpf/libarena/include/libarena/common.h
tools/testing/selftests/bpf/libarena/src/common.bpf.c

index 3c695f9c005453c9f934719ea3f543dc0fd224d4..5e2ab514805e4cc0f6e09852992ff32dece899ad 100644 (file)
@@ -51,8 +51,6 @@ ASAN_FLAGS += -mllvm -asan-destructor-kind=none
 override BPF_CFLAGS += -DENABLE_ATOMICS_TESTS
 override BPF_CFLAGS += -O2 -g
 override BPF_CFLAGS += -Wno-incompatible-pointer-types-discards-qualifiers
-# Required to define our own arena-based free()
-override BPF_CFLAGS += -Wno-incompatible-library-redeclaration
 # Required for suppressing harmless vmlinux.h-related warnings.
 override BPF_CFLAGS += -Wno-missing-declarations
 override BPF_CFLAGS += $(INCLUDES)
index e54cb7b869bd11b870e9aa27d894d5be0a943643..ca1a6c1d6477343e687f39ac125dd110d39ccb42 100644 (file)
@@ -48,9 +48,9 @@ extern volatile u64 asan_violated;
 
 int arena_fls(__u64 word);
 
-u64 malloc_internal(size_t size);
-#define malloc(size) ((void __arena *)malloc_internal((size)))
-void free(void __arena *ptr);
+u64 arena_malloc_internal(size_t size);
+#define arena_malloc(size) ((void __arena *)arena_malloc_internal((size)))
+void arena_free(void __arena *ptr);
 
 /*
  * The verifier associates arenas with programs by checking LD.IMM
index e5da1e37e83e486b994f91569d0a7095c1a246f0..544bf9e1cb38f53e2ecc4748498a641c44a3b72b 100644 (file)
@@ -38,12 +38,12 @@ __weak int arena_buddy_reset(void)
        return buddy_init(&buddy);
 }
 
-__weak u64 malloc_internal(size_t size)
+__weak u64 arena_malloc_internal(size_t size)
 {
        return buddy_alloc_internal(&buddy, size);
 }
 
-__weak void free(void __arg_arena __arena *ptr)
+__weak void arena_free(void __arg_arena __arena *ptr)
 {
        buddy_free_internal(&buddy, (u64)ptr);
 }