diff options
author | Alan Modra <amodra@gmail.com> | 2023-12-05 09:23:41 +1030 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2023-12-06 12:23:05 +1030 |
commit | 3c8852fcc806915fdeab8b3d6f49be7347160527 (patch) | |
tree | 0738b9341e04fae97c7cc25efa39f86e054e99ca | |
parent | 9d498f4286d7058f448cf78214c0bc6cdf8dad31 (diff) | |
download | binutils-3c8852fcc806915fdeab8b3d6f49be7347160527.zip binutils-3c8852fcc806915fdeab8b3d6f49be7347160527.tar.gz binutils-3c8852fcc806915fdeab8b3d6f49be7347160527.tar.bz2 |
PR31096, nm shows 32bit addresses as 64bit addresses
Prior to commit 0e3c1eebb2 nm output depended on the host unsigned
long when printing "negative" symbol values for 32-bit targets.
Commit 0e3c1eebb22 made the output match that seen with a 64-bit host
unsigned long. The fact that nm output changed depending on host is
of course a bug, but it is reasonable to expect 32-bit target output
is only 32 bits. So this patch makes 32-bit target output the same as
it was on 32-bit hosts prior to 0e3c1eebb2.
PR 31096
* nm.c (print_format_string): Make it a static buffer.
(get_print_format): Merge into..
(set_print_format): ..this, renamed from set_print_width. When
print_width is 32, set up print_format_string for an int32_t
value. Don't malloc print_format_string. Adjust calls.
(print_value): Correct printing of 32-bit values.
-rw-r--r-- | binutils/nm.c | 79 |
1 files changed, 44 insertions, 35 deletions
diff --git a/binutils/nm.c b/binutils/nm.c index 54ee818..bfab620 100644 --- a/binutils/nm.c +++ b/binutils/nm.c @@ -169,7 +169,7 @@ static const struct output_fns formats[FORMAT_MAX] = /* The output format to use. */ static const struct output_fns *format = &formats[FORMAT_DEFAULT]; static unsigned int print_format = FORMAT_DEFAULT; -static const char *print_format_string = NULL; +static char print_format_string[10]; /* Command options. */ @@ -1512,37 +1512,8 @@ display_rel_file (bfd *abfd, bfd *archive_bfd) /* Construct a formatting string for printing symbol values. */ -static const char * -get_print_format (void) -{ - const char * padding; - if (print_format == FORMAT_POSIX || print_format == FORMAT_JUST_SYMBOLS) - { - /* POSIX compatible output does not have any padding. */ - padding = ""; - } - else if (print_width == 32) - { - padding ="08"; - } - else /* print_width == 64 */ - { - padding = "016"; - } - - const char * radix = NULL; - switch (print_radix) - { - case 8: radix = PRIo64; break; - case 10: radix = PRId64; break; - case 16: radix = PRIx64; break; - } - - return concat ("%", padding, radix, NULL); -} - static void -set_print_width (bfd *file) +set_print_format (bfd *file) { print_width = bfd_get_arch_size (file); @@ -1559,8 +1530,43 @@ set_print_width (bfd *file) else print_width = 32; } - free ((char *) print_format_string); - print_format_string = get_print_format (); + + char *p = print_format_string; + *p++ = '%'; + if (print_format == FORMAT_POSIX || print_format == FORMAT_JUST_SYMBOLS) + { + /* POSIX compatible output does not have any padding. */ + } + else if (print_width == 32) + { + *p++ = '0'; + *p++ = '8'; + } + else /* print_width == 64. */ + { + *p++ = '0'; + *p++ = '1'; + *p++ = '6'; + } + + if (print_width == 32) + { + switch (print_radix) + { + case 8: strcpy (p, PRIo32); break; + case 10: strcpy (p, PRId32); break; + case 16: strcpy (p, PRIx32); break; + } + } + else + { + switch (print_radix) + { + case 8: strcpy (p, PRIo64); break; + case 10: strcpy (p, PRId64); break; + case 16: strcpy (p, PRIx64); break; + } + } } static void @@ -1588,7 +1594,7 @@ display_archive (bfd *file) if (bfd_check_format_matches (arfile, bfd_object, &matching)) { - set_print_width (arfile); + set_print_format (arfile); format->print_archive_member (bfd_get_filename (file), bfd_get_filename (arfile)); display_rel_file (arfile, file); @@ -1644,7 +1650,7 @@ display_file (char *filename) } else if (bfd_check_format_matches (file, bfd_object, &matching)) { - set_print_width (file); + set_print_format (file); format->print_object_filename (filename); display_rel_file (file, NULL); } @@ -1821,6 +1827,9 @@ print_value (bfd *abfd ATTRIBUTE_UNUSED, bfd_vma val) switch (print_width) { case 32: + printf (print_format_string, (uint32_t) val); + break; + case 64: printf (print_format_string, (uint64_t) val); break; |