]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
perf symbols: Break infinite loop on zero-filled notes in sysfs__read_build_id()
authorArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 10 Jun 2026 22:32:22 +0000 (19:32 -0300)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 17 Jun 2026 11:28:31 +0000 (08:28 -0300)
sysfs__read_build_id() iterates ELF note headers from sysfs files in a
while(1) loop.  If the file contains a zero-filled note header (both
n_namesz and n_descsz are 0), the code computes n = namesz + descsz = 0
and calls read(fd, bf, 0).  read() with count 0 returns 0, which
matches the expected (ssize_t)n value, so the error check passes and
the loop repeats — reading the same zero bytes and spinning forever.

This can happen with corrupted or zero-padded sysfs pseudo-files.

Add a check for n == 0 before the read, since no valid ELF note has
both name and description of zero length.

Reported-by: sashiko-bot <sashiko-bot@kernel.org>
Fixes: f1617b40596cb341 ("perf symbols: Record the build_ids of kernel modules too")
Reviewed-by: Ian Rogers <irogers@google.com>
Assisted-by: Claude:claude-opus-4.6
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/symbol-elf.c

index c301c298ded9fa83390feeb02a65cb4912d388da..39562bdec8b9063b4785354f2aa4434ec8c60a5c 100644 (file)
@@ -995,6 +995,9 @@ int sysfs__read_build_id(const char *filename, struct build_id *bid)
                        } else {
                                n = namesz + descsz;
                        }
+                       /* no valid note has both namesz and descsz zero */
+                       if (n == 0)
+                               break;
                        if (read(fd, bf, n) != (ssize_t)n)
                                break;
                }