Updated copyright notices for most files.
[deliverable/binutils-gdb.git] / gdb / mipsread.c
index f67eeea98192941683f8ad4dfd94a40b1f8304f7..a84003fb90147f32c164b344cd7614300e6c47db 100644 (file)
@@ -1,7 +1,9 @@
 /* Read a symbol table in MIPS' format (Third-Eye).
-   Copyright 1986, 1987, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996,
-   1998, 1999, 2000, 2001, 2003, 2004
+
+   Copyright (C) 1986, 1987, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996,
+   1998, 1999, 2000, 2001, 2003, 2004, 2007, 2008, 2009
    Free Software Foundation, Inc.
+
    Contributed by Alessandro Forin (af@cs.cmu.edu) at CMU.  Major work
    by Per Bothner, John Gilmore and Ian Lance Taylor at Cygnus Support.
 
@@ -9,7 +11,7 @@
 
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 2 of the License, or
+   the Free Software Foundation; either version 3 of the License, or
    (at your option) any later version.
 
    This program is distributed in the hope that it will be useful,
@@ -18,9 +20,7 @@
    GNU General Public License for more details.
 
    You should have received a copy of the GNU General Public License
-   along with this program; if not, write to the Free Software
-   Foundation, Inc., 59 Temple Place - Suite 330,
-   Boston, MA 02111-1307, USA.  */
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
 
 /* Read symbols from an ECOFF file.  Most of the work is done in
    mdebugread.c.  */
 #include "libcoff.h"           /* Private BFD COFF information.  */
 #include "libecoff.h"          /* Private BFD ECOFF information.  */
 #include "elf/common.h"
+#include "elf/internal.h"
 #include "elf/mips.h"
 
-extern void _initialize_mipsread (void);
-
-static void mipscoff_new_init (struct objfile *);
-
-static void mipscoff_symfile_init (struct objfile *);
-
-static void mipscoff_symfile_read (struct objfile *, int);
-
-static void mipscoff_symfile_finish (struct objfile *);
-
 static void
 read_alphacoff_dynamic_symtab (struct section_offsets *,
                               struct objfile *objfile);
@@ -59,12 +50,9 @@ read_alphacoff_dynamic_symtab (struct section_offsets *,
    symbol file is specified (not just adding some symbols from another
    file, e.g. a shared library).  */
 
-extern CORE_ADDR sigtramp_address;
-
 static void
 mipscoff_new_init (struct objfile *ignore)
 {
-  sigtramp_address = 0;
   stabsread_new_init ();
   buildsym_new_init ();
 }
@@ -92,7 +80,7 @@ mipscoff_symfile_read (struct objfile *objfile, int mainline)
 
   if (!((*ecoff_backend (abfd)->debug_swap.read_debug_info)
        (abfd, (asection *) NULL, &ecoff_data (abfd)->debug_info)))
-    error ("Error reading symbol table: %s", bfd_errmsg (bfd_get_error ()));
+    error (_("Error reading symbol table: %s"), bfd_errmsg (bfd_get_error ()));
 
   mdebug_build_psymtabs (objfile, &ecoff_backend (abfd)->debug_swap,
                         &ecoff_data (abfd)->debug_info);
@@ -105,25 +93,6 @@ mipscoff_symfile_read (struct objfile *objfile, int mainline)
      minimal symbols for this objfile. */
 
   install_minimal_symbols (objfile);
-
-  /* If the entry_file bounds are still unknown after processing the
-     partial symbols, then try to set them from the minimal symbols
-     surrounding the entry_point.  */
-
-  if (mainline
-      && objfile->ei.entry_point != INVALID_ENTRY_POINT
-      && objfile->ei.deprecated_entry_file_lowpc == INVALID_ENTRY_LOWPC)
-    {
-      struct minimal_symbol *m;
-
-      m = lookup_minimal_symbol_by_pc (objfile->ei.entry_point);
-      if (m && DEPRECATED_SYMBOL_NAME (m + 1))
-       {
-         objfile->ei.deprecated_entry_file_lowpc = SYMBOL_VALUE_ADDRESS (m);
-         objfile->ei.deprecated_entry_file_highpc = SYMBOL_VALUE_ADDRESS (m + 1);
-       }
-    }
-
   do_cleanups (back_to);
 }
 
@@ -136,58 +105,56 @@ mipscoff_symfile_finish (struct objfile *objfile)
 }
 
 /* Alpha OSF/1 encapsulates the dynamic symbols in ELF format in a
-   standard coff section.  The ELF format for the symbols differs from
-   the format defined in elf/external.h. It seems that a normal ELF 32 bit
-   format is used, and the representation only changes because longs are
-   64 bit on the alpha. In addition, the handling of text/data section
-   indices for symbols is different from the ELF ABI.
-   As the BFD linker currently does not support dynamic linking on the alpha,
-   there seems to be no reason to pollute BFD with another mixture of object
-   file formats for now.  */
+   standard COFF section.  The ELF format for the symbols differs from
+   the format defined in elf/external.h.  It seems that a normal ELF
+   32-bit format is used, and the representation only changes because
+   longs are 64-bit on the alpha. In addition, the handling of
+   text/data section indices for symbols is different from the ELF
+   ABI.  As the BFD linker currently does not support dynamic linking
+   on the alpha, there seems to be no reason to pollute BFD with
+   another mixture of object file formats for now.  */
 
 /* Format of an alpha external ELF symbol.  */
 
 typedef struct
 {
-  unsigned char st_name[4];    /* Symbol name, index in string tbl */
-  unsigned char st_pad[4];     /* Pad to long word boundary */
-  unsigned char st_value[8];   /* Value of the symbol */
-  unsigned char st_size[4];    /* Associated symbol size */
-  unsigned char st_info[1];    /* Type and binding attributes */
-  unsigned char st_other[1];   /* No defined meaning, 0 */
-  unsigned char st_shndx[2];   /* Associated section index */
-}
-Elfalpha_External_Sym;
+  unsigned char st_name[4];    /* Symbol name, index in string table.  */
+  unsigned char st_pad[4];     /* Pad to long word boundary.  */
+  unsigned char st_value[8];   /* Value of the symbol.  */
+  unsigned char st_size[4];    /* Associated symbol size.  */
+  unsigned char st_info[1];    /* Type and binding attributes.  */
+  unsigned char st_other[1];   /* No defined meaning, 0.  */
+  unsigned char st_shndx[2];   /* Associated section index.  */
+} Elfalpha_External_Sym;
 
 /* Format of an alpha external ELF dynamic info structure.  */
 
 typedef struct
+{
+  unsigned char d_tag[4];      /* Tag.  */
+  unsigned char d_pad[4];      /* Pad to long word boundary.  */
+  union
   {
-    unsigned char d_tag[4];    /* Tag */
-    unsigned char d_pad[4];    /* Pad to long word boundary */
-    union
-      {
-       unsigned char d_ptr[8]; /* Pointer value */
-       unsigned char d_val[4]; /* Integer value */
-      }
-    d_un;
+    unsigned char d_ptr[8];    /* Pointer value.  */
+    unsigned char d_val[4];    /* Integer value.  */
   }
-Elfalpha_External_Dyn;
+  d_un;
+} Elfalpha_External_Dyn;
 
 /* Struct to obtain the section pointers for alpha dynamic symbol info.  */
 
 struct alphacoff_dynsecinfo
-  {
-    asection *sym_sect;                /* Section pointer for .dynsym section */
-    asection *str_sect;                /* Section pointer for .dynstr section */
-    asection *dyninfo_sect;    /* Section pointer for .dynamic section */
-    asection *got_sect;                /* Section pointer for .got section */
-  };
+{
+  asection *sym_sect;          /* Section pointer for .dynsym section.  */
+  asection *str_sect;          /* Section pointer for .dynstr section.  */
+  asection *dyninfo_sect;      /* Section pointer for .dynamic section.  */
+  asection *got_sect;          /* Section pointer for .got section.  */
+};
 
 /* We are called once per section from read_alphacoff_dynamic_symtab.
-   We need to examine each section we are passed, check to see
-   if it is something we are interested in processing, and
-   if so, stash away some access information for the section.  */
+   We need to examine each section we are passed, check to see if it
+   is something we are interested in processing, and if so, stash away
+   some access information for the section.  */
 
 static void
 alphacoff_locate_sections (bfd *ignore_abfd, asection *sectp, void *sip)
@@ -196,26 +163,18 @@ alphacoff_locate_sections (bfd *ignore_abfd, asection *sectp, void *sip)
 
   si = (struct alphacoff_dynsecinfo *) sip;
 
-  if (DEPRECATED_STREQ (sectp->name, ".dynsym"))
-    {
-      si->sym_sect = sectp;
-    }
-  else if (DEPRECATED_STREQ (sectp->name, ".dynstr"))
-    {
-      si->str_sect = sectp;
-    }
-  else if (DEPRECATED_STREQ (sectp->name, ".dynamic"))
-    {
-      si->dyninfo_sect = sectp;
-    }
-  else if (DEPRECATED_STREQ (sectp->name, ".got"))
-    {
+  if (strcmp (sectp->name, ".dynsym") == 0)
+    si->sym_sect = sectp;
+  else if (strcmp (sectp->name, ".dynstr") == 0)
+    si->str_sect = sectp;
+  else if (strcmp (sectp->name, ".dynamic") == 0)
+    si->dyninfo_sect = sectp;
+  else if (strcmp (sectp->name, ".got") == 0)
       si->got_sect = sectp;
-    }
 }
 
-/* Scan an alpha dynamic symbol table for symbols of interest and
-   add them to the minimal symbol table.  */
+/* Scan an alpha dynamic symbol table for symbols of interest and add
+   them to the minimal symbol table.  */
 
 static void
 read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
@@ -242,7 +201,6 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
   int dt_mips_gotsym = -1;
   struct cleanup *cleanups;
 
-
   /* We currently only know how to handle alpha dynamic symbols.  */
   if (bfd_get_arch (abfd) != bfd_arch_alpha)
     return;
@@ -250,24 +208,22 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
   /* Locate the dynamic symbols sections and read them in.  */
   memset ((char *) &si, 0, sizeof (si));
   bfd_map_over_sections (abfd, alphacoff_locate_sections, (void *) & si);
-  if (si.sym_sect == NULL
-      || si.str_sect == NULL
-      || si.dyninfo_sect == NULL
-      || si.got_sect == NULL)
+  if (si.sym_sect == NULL || si.str_sect == NULL
+      || si.dyninfo_sect == NULL || si.got_sect == NULL)
     return;
 
-  sym_secsize = bfd_get_section_size_before_reloc (si.sym_sect);
-  str_secsize = bfd_get_section_size_before_reloc (si.str_sect);
-  dyninfo_secsize = bfd_get_section_size_before_reloc (si.dyninfo_sect);
-  got_secsize = bfd_get_section_size_before_reloc (si.got_sect);
+  sym_secsize = bfd_get_section_size (si.sym_sect);
+  str_secsize = bfd_get_section_size (si.str_sect);
+  dyninfo_secsize = bfd_get_section_size (si.dyninfo_sect);
+  got_secsize = bfd_get_section_size (si.got_sect);
   sym_secptr = xmalloc (sym_secsize);
-  cleanups = make_cleanup (free, sym_secptr);
+  cleanups = make_cleanup (xfree, sym_secptr);
   str_secptr = xmalloc (str_secsize);
-  make_cleanup (free, str_secptr);
+  make_cleanup (xfree, str_secptr);
   dyninfo_secptr = xmalloc (dyninfo_secsize);
-  make_cleanup (free, dyninfo_secptr);
+  make_cleanup (xfree, dyninfo_secptr);
   got_secptr = xmalloc (got_secsize);
-  make_cleanup (free, got_secptr);
+  make_cleanup (xfree, got_secptr);
 
   if (!bfd_get_section_contents (abfd, si.sym_sect, sym_secptr,
                                 (file_ptr) 0, sym_secsize))
@@ -282,8 +238,8 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
                                 (file_ptr) 0, got_secsize))
     return;
 
-  /* Find the number of local GOT entries and the index for the
-     the first dynamic symbol in the GOT. */
+  /* Find the number of local GOT entries and the index for the the
+     first dynamic symbol in the GOT.  */
   for (dyninfo_p = dyninfo_secptr, dyninfo_end = dyninfo_p + dyninfo_secsize;
        dyninfo_p < dyninfo_end;
        dyninfo_p += sizeof (Elfalpha_External_Dyn))
@@ -310,8 +266,8 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
   if (dt_mips_local_gotno < 0 || dt_mips_gotsym < 0)
     return;
 
-  /* Scan all dynamic symbols and enter them into the minimal symbol table
-     if appropriate.  */
+  /* Scan all dynamic symbols and enter them into the minimal symbol
+     table if appropriate.  */
   sym_count = sym_secsize / sizeof (Elfalpha_External_Sym);
   stripped = (bfd_get_symcount (abfd) == 0);
 
@@ -338,6 +294,8 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
       sym_value = bfd_h_get_64 (abfd, (bfd_byte *) x_symp->st_value);
       sym_info = bfd_h_get_8 (abfd, (bfd_byte *) x_symp->st_info);
       sym_shndx = bfd_h_get_16 (abfd, (bfd_byte *) x_symp->st_shndx);
+      if (sym_shndx >= (SHN_LORESERVE & 0xffff))
+       sym_shndx += SHN_LORESERVE - (SHN_LORESERVE & 0xffff);
       isglobal = (ELF_ST_BIND (sym_info) == STB_GLOBAL);
 
       if (sym_shndx == SHN_UNDEF)
@@ -355,17 +313,20 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
 
             If sym_value is zero, then we have to get the GOT entry
             for the symbol.
-            If the GOT entry is nonzero, it represents the quickstart
-            address of the function and we use that as the symbol value.
 
-            If the GOT entry is zero, the function address has to be resolved
-            by the runtime loader before the executable is started.
-            We are unable to find any meaningful address for these
-            functions in the executable file, so we skip them.  */
+            If the GOT entry is nonzero, it represents the quickstart
+            address of the function and we use that as the symbol
+            value.
+
+            If the GOT entry is zero, the function address has to be
+            resolved by the runtime loader before the executable is
+            started.  We are unable to find any meaningful address
+            for these functions in the executable file, so we skip
+            them.  */
          if (sym_value == 0)
            {
              int got_entry_offset =
-             (i - dt_mips_gotsym + dt_mips_local_gotno) * got_entry_size;
+               (i - dt_mips_gotsym + dt_mips_local_gotno) * got_entry_size;
 
              if (got_entry_offset < 0 || got_entry_offset >= got_secsize)
                continue;
@@ -378,9 +339,10 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
        }
       else
        {
-         /* Symbols defined in the executable itself. We only care about
-            them if this is a stripped executable, otherwise they have
-            been retrieved from the normal symbol table already.  */
+         /* Symbols defined in the executable itself. We only care
+            about them if this is a stripped executable, otherwise
+            they have been retrieved from the normal symbol table
+            already.  */
          if (!stripped)
            continue;
 
@@ -424,7 +386,7 @@ read_alphacoff_dynamic_symtab (struct section_offsets *section_offsets,
   do_cleanups (cleanups);
 }
 
-/* Initialization */
+/* Initialization */
 
 static struct sym_fns ecoff_sym_fns =
 {
@@ -434,9 +396,15 @@ static struct sym_fns ecoff_sym_fns =
   mipscoff_symfile_read,       /* sym_read: read a symbol file into symtab */
   mipscoff_symfile_finish,     /* sym_finish: finished with file, cleanup */
   default_symfile_offsets,     /* sym_offsets: dummy FIXME til implem sym reloc */
+  default_symfile_segments,    /* sym_segments: Get segment information from
+                                  a file.  */
+  NULL,                         /* sym_read_linetable */
   NULL                         /* next: pointer to next struct sym_fns */
 };
 
+/* Provide a prototype to silence -Wmissing-prototypes.  */
+void _initialize_mipsread (void);
+
 void
 _initialize_mipsread (void)
 {
This page took 0.028673 seconds and 4 git commands to generate.