* objdump.c (disassemble_data): Added "0x" prefix to printed hex
offsets; fixed MIPS16 disassembly for --prefix-addresses mode; see PR 12149.
This commit is contained in:
parent
794868783d
commit
243aa0c242
2 changed files with 78 additions and 21 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
Sun Oct 5 09:05:44 1997 Frank Ch. Eigler <fche@cygnus.com>
|
||||||
|
|
||||||
|
* objdump.c (disassemble_data): Add "0x" prefix for
|
||||||
|
symbol-offsets in disassembly. Make "--prefix-addresses"
|
||||||
|
disassembly adjust to mixed-length instructions.
|
||||||
|
|
||||||
Fri Oct 3 12:04:25 1997 Ian Lance Taylor <ian@cygnus.com>
|
Fri Oct 3 12:04:25 1997 Ian Lance Taylor <ian@cygnus.com>
|
||||||
|
|
||||||
* objcopy.c (set_times): New static function, replacing
|
* objcopy.c (set_times): New static function, replacing
|
||||||
|
|
|
@ -103,11 +103,20 @@ static asymbol **dynsyms;
|
||||||
/* Number of symbols in `dynsyms'. */
|
/* Number of symbols in `dynsyms'. */
|
||||||
static long dynsymcount = 0;
|
static long dynsymcount = 0;
|
||||||
|
|
||||||
/* Forward declarations. */
|
/* Static declarations. */
|
||||||
|
|
||||||
|
static void
|
||||||
|
usage PARAMS ((FILE *, int));
|
||||||
|
|
||||||
static void
|
static void
|
||||||
display_file PARAMS ((char *filename, char *target));
|
display_file PARAMS ((char *filename, char *target));
|
||||||
|
|
||||||
|
static void
|
||||||
|
dump_section_header PARAMS ((bfd *, asection *, PTR));
|
||||||
|
|
||||||
|
static void
|
||||||
|
dump_headers PARAMS ((bfd *));
|
||||||
|
|
||||||
static void
|
static void
|
||||||
dump_data PARAMS ((bfd *abfd));
|
dump_data PARAMS ((bfd *abfd));
|
||||||
|
|
||||||
|
@ -123,9 +132,27 @@ dump_reloc_set PARAMS ((bfd *, asection *, arelent **, long));
|
||||||
static void
|
static void
|
||||||
dump_symbols PARAMS ((bfd *abfd, boolean dynamic));
|
dump_symbols PARAMS ((bfd *abfd, boolean dynamic));
|
||||||
|
|
||||||
|
static void
|
||||||
|
dump_bfd_header PARAMS ((bfd *));
|
||||||
|
|
||||||
|
static void
|
||||||
|
dump_bfd_private_header PARAMS ((bfd *));
|
||||||
|
|
||||||
static void
|
static void
|
||||||
display_bfd PARAMS ((bfd *abfd));
|
display_bfd PARAMS ((bfd *abfd));
|
||||||
|
|
||||||
|
static void
|
||||||
|
display_target_list PARAMS ((void));
|
||||||
|
|
||||||
|
static void
|
||||||
|
display_info_table PARAMS ((int, int));
|
||||||
|
|
||||||
|
static void
|
||||||
|
display_target_tables PARAMS ((void));
|
||||||
|
|
||||||
|
static void
|
||||||
|
display_info PARAMS ((void));
|
||||||
|
|
||||||
static void
|
static void
|
||||||
objdump_print_value PARAMS ((bfd_vma, struct disassemble_info *, boolean));
|
objdump_print_value PARAMS ((bfd_vma, struct disassemble_info *, boolean));
|
||||||
|
|
||||||
|
@ -158,6 +185,30 @@ disassemble_data PARAMS ((bfd *));
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
endian_string PARAMS ((enum bfd_endian));
|
endian_string PARAMS ((enum bfd_endian));
|
||||||
|
|
||||||
|
static asymbol **
|
||||||
|
slurp_symtab PARAMS ((bfd *));
|
||||||
|
|
||||||
|
static asymbol **
|
||||||
|
slurp_dynamic_symtab PARAMS ((bfd *));
|
||||||
|
|
||||||
|
static long
|
||||||
|
remove_useless_symbols PARAMS ((asymbol **, long));
|
||||||
|
|
||||||
|
static int
|
||||||
|
compare_symbols PARAMS ((const PTR, const PTR));
|
||||||
|
|
||||||
|
static int
|
||||||
|
compare_relocs PARAMS ((const PTR, const PTR));
|
||||||
|
|
||||||
|
static void
|
||||||
|
dump_stabs PARAMS ((bfd *));
|
||||||
|
|
||||||
|
static boolean
|
||||||
|
read_section_stabs PARAMS ((bfd *, const char *, const char *));
|
||||||
|
|
||||||
|
static void
|
||||||
|
print_section_stabs PARAMS ((bfd *, const char *, const char *));
|
||||||
|
|
||||||
static void
|
static void
|
||||||
usage (stream, status)
|
usage (stream, status)
|
||||||
|
@ -752,12 +803,12 @@ objdump_print_addr_with_sym (abfd, sec, sym, vma, info, skip_zeroes)
|
||||||
secaddr = bfd_get_section_vma (abfd, sec);
|
secaddr = bfd_get_section_vma (abfd, sec);
|
||||||
if (vma < secaddr)
|
if (vma < secaddr)
|
||||||
{
|
{
|
||||||
(*info->fprintf_func) (info->stream, "-");
|
(*info->fprintf_func) (info->stream, "-0x");
|
||||||
objdump_print_value (secaddr - vma, info, true);
|
objdump_print_value (secaddr - vma, info, true);
|
||||||
}
|
}
|
||||||
else if (vma > secaddr)
|
else if (vma > secaddr)
|
||||||
{
|
{
|
||||||
(*info->fprintf_func) (info->stream, "+");
|
(*info->fprintf_func) (info->stream, "+0x");
|
||||||
objdump_print_value (vma - secaddr, info, true);
|
objdump_print_value (vma - secaddr, info, true);
|
||||||
}
|
}
|
||||||
(*info->fprintf_func) (info->stream, ">");
|
(*info->fprintf_func) (info->stream, ">");
|
||||||
|
@ -768,12 +819,12 @@ objdump_print_addr_with_sym (abfd, sec, sym, vma, info, skip_zeroes)
|
||||||
objdump_print_symname (abfd, info, sym);
|
objdump_print_symname (abfd, info, sym);
|
||||||
if (bfd_asymbol_value (sym) > vma)
|
if (bfd_asymbol_value (sym) > vma)
|
||||||
{
|
{
|
||||||
(*info->fprintf_func) (info->stream, "-");
|
(*info->fprintf_func) (info->stream, "-0x");
|
||||||
objdump_print_value (bfd_asymbol_value (sym) - vma, info, true);
|
objdump_print_value (bfd_asymbol_value (sym) - vma, info, true);
|
||||||
}
|
}
|
||||||
else if (vma > bfd_asymbol_value (sym))
|
else if (vma > bfd_asymbol_value (sym))
|
||||||
{
|
{
|
||||||
(*info->fprintf_func) (info->stream, "+");
|
(*info->fprintf_func) (info->stream, "+0x");
|
||||||
objdump_print_value (vma - bfd_asymbol_value (sym), info, true);
|
objdump_print_value (vma - bfd_asymbol_value (sym), info, true);
|
||||||
}
|
}
|
||||||
(*info->fprintf_func) (info->stream, ">");
|
(*info->fprintf_func) (info->stream, ">");
|
||||||
|
@ -794,6 +845,7 @@ objdump_print_addr (vma, info, skip_zeroes)
|
||||||
|
|
||||||
if (sorted_symcount < 1)
|
if (sorted_symcount < 1)
|
||||||
{
|
{
|
||||||
|
printf ("0x");
|
||||||
objdump_print_value (vma, info, skip_zeroes);
|
objdump_print_value (vma, info, skip_zeroes);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1436,7 +1488,7 @@ disassemble_data (abfd)
|
||||||
fprintf (stderr, "%s: Can't disassemble for architecture %s\n",
|
fprintf (stderr, "%s: Can't disassemble for architecture %s\n",
|
||||||
program_name,
|
program_name,
|
||||||
bfd_printable_arch_mach (bfd_get_arch (abfd), 0));
|
bfd_printable_arch_mach (bfd_get_arch (abfd), 0));
|
||||||
exit (1);
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
disasm_info.flavour = bfd_get_flavour (abfd);
|
disasm_info.flavour = bfd_get_flavour (abfd);
|
||||||
|
@ -1527,10 +1579,7 @@ disassemble_data (abfd)
|
||||||
stop = disasm_info.buffer_length;
|
stop = disasm_info.buffer_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prefix_addresses)
|
if(1) /* with or without prefix_addresses */
|
||||||
disassemble_bytes (&disasm_info, disassemble_fn, true, data, i, stop,
|
|
||||||
&relpp, relppend);
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
asymbol *sym;
|
asymbol *sym;
|
||||||
long place;
|
long place;
|
||||||
|
@ -1549,12 +1598,15 @@ disassemble_data (abfd)
|
||||||
else
|
else
|
||||||
disasm_info.symbol = NULL;
|
disasm_info.symbol = NULL;
|
||||||
|
|
||||||
|
if (! prefix_addresses)
|
||||||
|
{
|
||||||
printf ("\n");
|
printf ("\n");
|
||||||
objdump_print_addr_with_sym (abfd, section, sym,
|
objdump_print_addr_with_sym (abfd, section, sym,
|
||||||
section->vma + i,
|
section->vma + i,
|
||||||
&disasm_info,
|
&disasm_info,
|
||||||
false);
|
false);
|
||||||
printf (":\n");
|
printf (":\n");
|
||||||
|
}
|
||||||
|
|
||||||
if (sym != NULL && bfd_asymbol_value (sym) > section->vma + i)
|
if (sym != NULL && bfd_asymbol_value (sym) > section->vma + i)
|
||||||
nextsym = sym;
|
nextsym = sym;
|
||||||
|
@ -1654,8 +1706,8 @@ static bfd_size_type stabstr_size;
|
||||||
static boolean
|
static boolean
|
||||||
read_section_stabs (abfd, stabsect_name, strsect_name)
|
read_section_stabs (abfd, stabsect_name, strsect_name)
|
||||||
bfd *abfd;
|
bfd *abfd;
|
||||||
char *stabsect_name;
|
const char *stabsect_name;
|
||||||
char *strsect_name;
|
const char *strsect_name;
|
||||||
{
|
{
|
||||||
asection *stabsect, *stabstrsect;
|
asection *stabsect, *stabstrsect;
|
||||||
|
|
||||||
|
@ -1725,8 +1777,8 @@ read_section_stabs (abfd, stabsect_name, strsect_name)
|
||||||
static void
|
static void
|
||||||
print_section_stabs (abfd, stabsect_name, strsect_name)
|
print_section_stabs (abfd, stabsect_name, strsect_name)
|
||||||
bfd *abfd;
|
bfd *abfd;
|
||||||
char *stabsect_name;
|
const char *stabsect_name;
|
||||||
char *strsect_name;
|
const char *strsect_name;
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
unsigned file_string_table_offset = 0, next_file_string_table_offset = 0;
|
unsigned file_string_table_offset = 0, next_file_string_table_offset = 0;
|
||||||
|
@ -2492,7 +2544,6 @@ display_target_tables ()
|
||||||
int t, columns;
|
int t, columns;
|
||||||
extern bfd_target *bfd_target_vector[];
|
extern bfd_target *bfd_target_vector[];
|
||||||
char *colum;
|
char *colum;
|
||||||
extern char *getenv ();
|
|
||||||
|
|
||||||
columns = 0;
|
columns = 0;
|
||||||
colum = getenv ("COLUMNS");
|
colum = getenv ("COLUMNS");
|
||||||
|
|
Loading…
Reference in a new issue