]> www.infradead.org Git - users/hch/misc.git/commitdiff
perf bpf: Check libbpf version to use btf_dump_type_data_opts.emit_strings
authorArnaldo Carvalho de Melo <acme@redhat.com>
Fri, 19 Sep 2025 21:02:23 +0000 (18:02 -0300)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Tue, 30 Sep 2025 16:36:08 +0000 (13:36 -0300)
When building perf with LIBBPF_DYNAMIC=1 on a fedora system with
libbpf-devel 1.5 I it was breaking with:

util/bpf-event.c: In function ‘format_btf_variable’:
util/bpf-event.c:291:18: error: ‘const struct btf_dump_type_data_opts’ has no member named ‘emit_strings’
  291 |                 .emit_strings = 1,
      |                  ^~~~~~~~~~~~
util/bpf-event.c:291:33: error: initialized field overwritten [-Werror=override-init]
  291 |                 .emit_strings = 1,
      |                                 ^
util/bpf-event.c:291:33: note: (near initialization for ‘opts.skip_names’)

Check the version before using that feature.

Reviewed-by: Ian Rogers <irogers@google.com>
Acked-by: Namhyung Kim <namhyung@kernel.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Andrii Nakryiko <andrii@kernel.org>
Cc: James Clark <james.clark@linaro.org>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Kan Liang <kan.liang@linux.intel.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/bpf-event.c

index 2298cd396c4235e253c85fe4f6089197b971215b..59f84aef91b4a2ece4d63e1572d138936c11c91e 100644 (file)
@@ -288,7 +288,9 @@ static void format_btf_variable(struct btf *btf, char *buf, size_t buf_size,
                .sz = sizeof(struct btf_dump_type_data_opts),
                .skip_names = 1,
                .compact = 1,
+#if LIBBPF_CURRENT_VERSION_GEQ(1, 7)
                .emit_strings = 1,
+#endif
        };
        struct btf_dump *d;
        size_t btf_size;