Hi everyone.

I built and ran selftests/bpf with GCC 15-20241229, and would like to
share my findings.

Building required small adjustments in the Makefile, besides -std=gnu17

With the following change we can mitigate int64_t issue:

+progs/test_cls_redirect.c-CFLAGS := -nostdinc
+progs/test_cls_redirect_dynptr.c-CFLAGS := -nostdinc
+progs/test_cls_redirect_subprogs.c-CFLAGS := -nostdinc

Then, the compiler complains about an uninitialized variable in
progs/verifier_bpf_fastcall.c and progs/verifier_search_pruning.c
(full log at [1]):

    In file included from progs/verifier_bpf_fastcall.c:7:
    progs/verifier_bpf_fastcall.c: In function ‘may_goto_interaction’:
    progs/bpf_misc.h:153:42: error: ‘<Uc098>’ is used uninitialized 
[-Werror=uninitialized]
      153 | #define __imm_insn(name, expr) [name]"i"(*(long *)&(expr))
          |                                          ^~~~~~~~~~~~~~~~
    progs/verifier_bpf_fastcall.c:652:11: note: in expansion of macro 
‘__imm_insn’
      652 |           __imm_insn(may_goto, BPF_RAW_INSN(BPF_JMP | BPF_JCOND, 0, 
0, +1 /* offset */, 0))
          |           ^~~~~~~~~~
    
/ci/workspace/tools/testing/selftests/bpf/../../../include/linux/filter.h:299:28:
 note: ‘({anonymous})’ declared here
      299 |         ((struct bpf_insn) {                                    \
          |                            ^
    progs/bpf_misc.h:153:53: note: in definition of macro ‘__imm_insn’
      153 | #define __imm_insn(name, expr) [name]"i"(*(long *)&(expr))
          |                                                     ^~~~
    progs/verifier_bpf_fastcall.c:652:32: note: in expansion of macro 
‘BPF_RAW_INSN’
      652 |           __imm_insn(may_goto, BPF_RAW_INSN(BPF_JMP | BPF_JCOND, 0, 
0, +1 /* offset */, 0))

BPF_RAW_INSN expands into struct init expr (include/linux/filter.h):

    #define BPF_RAW_INSN(CODE, DST, SRC, OFF, IMM)                      \
        ((struct bpf_insn) {                                    \
                .code  = CODE,                                  \
                .dst_reg = DST,                                 \
                .src_reg = SRC,                                 \
                .off   = OFF,                                   \
                .imm   = IMM })

This can be silenced with:

+progs/verifier_bpf_fastcall.c-CFLAGS := -Wno-error
+progs/verifier_search_pruning.c-CFLAGS := -Wno-error

Then the selftests/bpf build completes successfully, although libbpf
prints a lot of warnings like these on GEN-SKEL:

    [...]
    libbpf: elf: skipping section(3) .data (size 0)
    libbpf: elf: skipping section(4) .data (size 0)
    libbpf: elf: skipping unrecognized data section(13) .comment
    libbpf: elf: skipping unrecognized data section(9) .comment
    libbpf: elf: skipping unrecognized data section(12) .comment
    libbpf: elf: skipping unrecognized data section(7) .comment
    [...]

Test .bpf.o files are compiled regardless. Full log at [2].

Running all tests at once, as is usually done on CI, produces a too
cluttered log. I wrote a script to run each test individually in a
separate qemu instance and collect the logs.

187/581 of toplevel tests fail on current bpf-next [3]. Many tests
have subtests: toplevel test passes if all of its subtests pass.

You can find the archive with per-test logs at [4].

[1] https://gist.github.com/theihor/10b2425e6780fcfebb80aeceafba7678
[2] https://gist.github.com/theihor/9e96643ca730365cf79cea8445e40aeb
[3] 
https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf-next.git/commit/?id=96ea081ed52bf077cad6d00153b6fba68e510767
[4] 
https://github.com/kernel-patches/bpf/blob/8f2e62702ee17675464ab00d97d89d599922de20/tools/testing/selftests/bpf/gcc-bpf-selftests-logs.tgz

Reply via email to