summaryrefslogtreecommitdiff
path: root/binutils/objdump.c
diff options
context:
space:
mode:
authorKen Raeburn <raeburn@cygnus>1993-02-22 15:31:30 +0000
committerKen Raeburn <raeburn@cygnus>1993-02-22 15:31:30 +0000
commitd9971b8304d745324c070c45355362f0e62fab64 (patch)
tree05557220f87ceac696d5547b06389905cba1aaf5 /binutils/objdump.c
parent424bac5c8f2a8ecbbbef6e954fdc05c1347276df (diff)
downloadbinutils-gdb-d9971b8304d745324c070c45355362f0e62fab64.tar.gz
from minyard@bnr.ca: free up copy of section contents each time through loop
Diffstat (limited to 'binutils/objdump.c')
-rw-r--r--binutils/objdump.c128
1 files changed, 83 insertions, 45 deletions
diff --git a/binutils/objdump.c b/binutils/objdump.c
index 876ee50d1cb..bc423c9383e 100644
--- a/binutils/objdump.c
+++ b/binutils/objdump.c
@@ -1,5 +1,5 @@
/* objdump.c -- dump information about an object file.
- Copyright (C) 1990, 1991 Free Software Foundation, Inc.
+ Copyright 1990, 1991, 1992 Free Software Foundation, Inc.
This file is part of BFD, the Binary File Diddler.
@@ -61,27 +61,28 @@ boolean disassemble; /* -d */
boolean info; /* -i */
char *only;
-PROTO (void, display_file, (char *filename, char *target));
-PROTO (void, dump_data, (bfd * abfd));
-PROTO (void, dump_relocs, (bfd * abfd));
-PROTO (void, dump_symbols, (bfd * abfd));
-PROTO (void, print_arelt_descr, (FILE *, bfd * abfd, boolean verbose));
-
-
-
-
-
-
-
char *machine = (char *) NULL;
asymbol **syms;
asymbol **syms2;
-
unsigned int storage;
unsigned int symcount = 0;
+/* Forward declarations. */
+
+static void
+display_file PARAMS ((char *filename, char *target));
+
+static void
+dump_data PARAMS ((bfd *abfd));
+
+static void
+dump_relocs PARAMS ((bfd *abfd));
+
+static void
+dump_symbols PARAMS ((bfd *abfd));
+
void
usage ()
{
@@ -179,13 +180,18 @@ comp (ap, bp)
asymbol *a = *(asymbol **)ap;
asymbol *b = *(asymbol **)bp;
int diff;
+ bfd *a_bfd, *b_bfd;
if (a->name == (char *) NULL || (a->flags & (BSF_DEBUGGING)))
- a->the_bfd = 0;
+ a_bfd = 0;
+ else
+ a_bfd = bfd_asymbol_bfd(a);
if (b->name == (char *) NULL || (b->flags & (BSF_DEBUGGING)))
- b->the_bfd = 0;
+ b_bfd = 0;
+ else
+ b_bfd = bfd_asymbol_bfd(b);
- diff = a->the_bfd - b->the_bfd;
+ diff = a_bfd - b_bfd;
if (diff)
{
return -diff;
@@ -229,7 +235,11 @@ print_address (vma, stream)
break;
vardiff = syms[thisplace]->value - vma;
- if (vardiff)
+ if (vardiff
+ /* Check that the value isn't merely a coincidence.
+ (if not checked, we might print some undefined symbol
+ for the address 0 rather than "main", for example. */
+ || !(syms[thisplace]->flags & (BSF_GLOBAL|BSF_LOCAL)))
{
if (vardiff > 0)
{
@@ -297,10 +307,13 @@ disassemble_data (abfd)
unsigned int (*print) ()= 0;
unsigned int print_insn_m68k ();
unsigned int print_insn_a29k ();
+ unsigned int print_insn_z8001 ();
+ unsigned int print_insn_z8002 ();
unsigned int print_insn_i960 ();
unsigned int print_insn_sparc ();
unsigned int print_insn_i386 ();
unsigned int print_insn_h8300 ();
+ unsigned int print_insn_mips ();
enum bfd_architecture a;
asection *section;
@@ -325,7 +338,8 @@ disassemble_data (abfd)
for (i = 0; i < symcount; i++)
{
- if (syms[i]->the_bfd == 0)
+ if (syms[i]->name == (char *) NULL
+ || (syms[i]->flags & BSF_DEBUGGING) != 0)
{
symcount = i;
break;
@@ -361,6 +375,12 @@ disassemble_data (abfd)
case bfd_arch_sparc:
print = print_insn_sparc;
break;
+ case bfd_arch_z8k:
+ if (bfd_get_mach(abfd) == bfd_mach_z8001)
+ print = print_insn_z8001;
+ else
+ print = print_insn_z8002;
+ break;
case bfd_arch_i386:
print = print_insn_i386;
break;
@@ -373,6 +393,10 @@ disassemble_data (abfd)
case bfd_arch_i960:
print = print_insn_i960;
break;
+ case bfd_arch_mips:
+ /* MIPS is handled specially, because we need to pass an
+ additional endianness argument. */
+ break;
default:
fprintf (stderr, "%s: Can't disassemble for architecture %s\n",
program_name,
@@ -429,15 +453,17 @@ disassemble_data (abfd)
CONST char *functionname;
unsigned int line;
- bfd_find_nearest_line (abfd,
- section,
- syms,
- section->vma + i,
- &filename,
- &functionname,
- &line);
-
- if (filename && functionname && line && line != prevline)
+ if (bfd_find_nearest_line (abfd,
+ section,
+ syms,
+ section->vma + i,
+ &filename,
+ &functionname,
+ &line)
+ && filename
+ && functionname
+ && line
+ && line != prevline)
{
printf ("%s:%u\n", filename, line);
prevline = line;
@@ -446,9 +472,18 @@ disassemble_data (abfd)
print_address (section->vma + i, stdout);
printf (" ");
- i += print (section->vma + i,
- data + i,
- stdout);
+ if (a != bfd_arch_mips)
+ i += print (section->vma + i,
+ data + i,
+ stdout);
+ else
+ {
+ /* The endianness of the MIPS can vary. */
+ i += print_insn_mips (section->vma + i,
+ data + i,
+ stdout,
+ (int) abfd->xvec->byteorder_big_p);
+ }
putchar ('\n');
}
}
@@ -546,7 +581,7 @@ dump_elf_stabs_1 (abfd, name1, name2)
strtab = (char *) xmalloc (stabstr_hdr->sh_size);
stabs_end = (struct internal_nlist *) (stab_hdr->sh_size + (char *)stabs);
- if (bfd_seek (abfd, stab_hdr->sh_offset, L_SET) < 0 ||
+ if (bfd_seek (abfd, stab_hdr->sh_offset, SEEK_SET) < 0 ||
stab_hdr->sh_size != bfd_read ((PTR)stabs, stab_hdr->sh_size, 1, abfd))
{
fprintf (stderr, "%s: reading %s section of %s failed.\n",
@@ -555,7 +590,7 @@ dump_elf_stabs_1 (abfd, name1, name2)
return;
}
- if (bfd_seek (abfd, stabstr_hdr->sh_offset, L_SET) < 0 ||
+ if (bfd_seek (abfd, stabstr_hdr->sh_offset, SEEK_SET) < 0 ||
stabstr_hdr->sh_size != bfd_read ((PTR)strtab, stabstr_hdr->sh_size,
1, abfd))
{
@@ -675,7 +710,7 @@ display_bfd (abfd)
disassemble_data (abfd);
}
-void
+static void
display_file (filename, target)
char *filename;
char *target;
@@ -716,7 +751,7 @@ display_file (filename, target)
/* Actually display the various requested regions */
-void
+static void
dump_data (abfd)
bfd *abfd;
{
@@ -775,14 +810,14 @@ dump_data (abfd)
}
putchar ('\n');
}
+ free (data);
}
}
- free (data);
}
}
/* Should perhaps share code and display with nm? */
-void
+static void
dump_symbols (abfd)
bfd *abfd;
{
@@ -795,13 +830,16 @@ dump_symbols (abfd)
for (count = 0; count < symcount; count++)
{
- if (*current && (*current)->the_bfd)
+ if (*current)
{
- bfd_print_symbol ((*current)->the_bfd,
- stdout,
- *current, bfd_print_symbol_all);
-
- printf ("\n");
+ bfd *cur_bfd = bfd_asymbol_bfd(*current);
+ if (cur_bfd)
+ {
+ bfd_print_symbol (cur_bfd,
+ stdout,
+ *current, bfd_print_symbol_all);
+ printf ("\n");
+ }
}
current++;
@@ -810,7 +848,7 @@ dump_symbols (abfd)
printf ("\n");
}
-void
+static void
dump_relocs (abfd)
bfd *abfd;
{
@@ -824,7 +862,7 @@ dump_relocs (abfd)
continue;
if (a == &bfd_und_section)
continue;
- if (a == &bfd_com_section)
+ if (bfd_is_com_section (a))
continue;
printf ("RELOCATION RECORDS FOR [%s]:", a->name);