Commit 96de68ff authored by Dmitry Safonov's avatar Dmitry Safonov Committed by Arnaldo Carvalho de Melo

perf symbols: Use (long) for iterator for bfd symbols

GCC (GCC) 8.4.0 20200304 fails to build perf with:
: util/symbol.c: In function 'dso__load_bfd_symbols':
: util/symbol.c:1626:16: error: comparison of integer expressions of different signednes
:   for (i = 0; i < symbols_count; ++i) {
:                 ^
: util/symbol.c:1632:16: error: comparison of integer expressions of different signednes
:    while (i + 1 < symbols_count &&
:                 ^
: util/symbol.c:1637:13: error: comparison of integer expressions of different signednes
:    if (i + 1 < symbols_count &&
:              ^
: cc1: all warnings being treated as errors

It's unlikely that the symtable will be that big, but the fix is an
oneliner and as perf has CORE_CFLAGS += -Wextra, which makes build to
fail together with CORE_CFLAGS += -Werror

Fixes: eac9a434 ("perf symbols: Try reading the symbol table with libbfd")
Signed-off-by: default avatarDmitry Safonov <dima@arista.com>
Acked-by: default avatarNamhyung Kim <namhyung@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Dmitry Safonov <0x7f454c46@gmail.com>
Cc: Jacek Caban <jacek@codeweavers.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Remi Bernon <rbernon@codeweavers.com>
Link: http://lore.kernel.org/lkml/20210209145148.178702-1-dima@arista.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 1f0e6edc
...@@ -1561,12 +1561,11 @@ static int bfd2elf_binding(asymbol *symbol) ...@@ -1561,12 +1561,11 @@ static int bfd2elf_binding(asymbol *symbol)
int dso__load_bfd_symbols(struct dso *dso, const char *debugfile) int dso__load_bfd_symbols(struct dso *dso, const char *debugfile)
{ {
int err = -1; int err = -1;
long symbols_size, symbols_count; long symbols_size, symbols_count, i;
asection *section; asection *section;
asymbol **symbols, *sym; asymbol **symbols, *sym;
struct symbol *symbol; struct symbol *symbol;
bfd *abfd; bfd *abfd;
u_int i;
u64 start, len; u64 start, len;
abfd = bfd_openr(dso->long_name, NULL); abfd = bfd_openr(dso->long_name, NULL);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment