* symfile.h (struct sym_fns): Add new field sym_read_linetable.
authorJoel Brobecker <brobecker@gnat.com>
Fri, 21 Sep 2007 18:01:26 +0000 (18:01 +0000)
committerJoel Brobecker <brobecker@gnat.com>
Fri, 21 Sep 2007 18:01:26 +0000 (18:01 +0000)
        * coffread.c, dbxread.c, elfread.c, mipsread.c somread.c:
        Adjust the struct sym_fns object accordingly by setting
        the new field to NULL.
        * xcoffread.c (aix_process_linenos): Make static.
        (xcoff_sym_fns): Set new field to aix_process_linenos.
        * buildsym.c (end_symtab): Replace call to PROCESS_LINENUMBER_HOOK
        by call to new the new sym_fns sym_read_linetable function.
        * config/powerpc/aix.mt (DEPRECATED_TM_FILE): Delete.
        * config/rs6000/tm-rs6000.h: Delete.

gdb/ChangeLog
gdb/buildsym.c
gdb/coffread.c
gdb/config/powerpc/aix.mt
gdb/config/rs6000/tm-rs6000.h [deleted file]
gdb/dbxread.c
gdb/elfread.c
gdb/mipsread.c
gdb/somread.c
gdb/symfile.h
gdb/xcoffread.c

index c217f0cabfe89e8d1c365209863a2029356dbeeb..814fc5e11292aff5f26860dbfd135e31c49baabc 100644 (file)
@@ -1,3 +1,16 @@
+2007-09-21  Joel Brobecker  <brobecker@adacore.com>
+
+       * symfile.h (struct sym_fns): Add new field sym_read_linetable.
+       * coffread.c, dbxread.c, elfread.c, mipsread.c somread.c:
+       Adjust the struct sym_fns object accordingly by setting
+       the new field to NULL.
+       * xcoffread.c (aix_process_linenos): Make static.
+       (xcoff_sym_fns): Set new field to aix_process_linenos.
+       * buildsym.c (end_symtab): Replace call to PROCESS_LINENUMBER_HOOK
+       by call to new the new sym_fns sym_read_linetable function.
+       * config/powerpc/aix.mt (DEPRECATED_TM_FILE): Delete.
+       * config/rs6000/tm-rs6000.h: Delete.
+
 2007-09-21  David Ung  <davidu@mips.com>
             Maciej W. Rozycki  <macro@mips.com>
 
index 547e7ca646b00554c3b4a64ee24d469e35145c32..d3af35e1d51ca3739ef61755c1d0b2f848a25200 100644 (file)
@@ -933,10 +933,9 @@ end_symtab (CORE_ADDR end_addr, struct objfile *objfile, int section)
                             &objfile->objfile_obstack);
     }
 
-#ifndef PROCESS_LINENUMBER_HOOK
-#define PROCESS_LINENUMBER_HOOK()
-#endif
-  PROCESS_LINENUMBER_HOOK ();  /* Needed for xcoff. */
+  /* Read the line table if it has to be read separately.  */
+  if (objfile->sf->sym_read_linetable != NULL)
+    objfile->sf->sym_read_linetable ();
 
   /* Now create the symtab objects proper, one for each subfile.  */
   /* (The main file is the last one on the chain.)  */
index 0276378996bdfc3a76fdc303fb403508acd7a393..b767eaff7134c81cc0f38f02f2ee977c7a8b4ae7 100644 (file)
@@ -2100,6 +2100,7 @@ static struct sym_fns coff_sym_fns =
   default_symfile_offsets,     /* sym_offsets:  xlate external to internal form */
   default_symfile_segments,    /* sym_segments: Get segment information from
                                   a file.  */
+  NULL,                         /* sym_read_linetable  */
   NULL                         /* next: pointer to next struct sym_fns */
 };
 
index c18e4ba4f173c80abc7ee285d5e5ea077b96a86c..06a9984e06aabc9f5e0c83f452ddd97b99a349a2 100644 (file)
@@ -1,4 +1,3 @@
 # Target: PowerPC running AIX
 TDEPFILES= rs6000-tdep.o rs6000-aix-tdep.o \
            xcoffread.o ppc-sysv-tdep.o solib.o solib-svr4.o
-DEPRECATED_TM_FILE= config/rs6000/tm-rs6000.h
diff --git a/gdb/config/rs6000/tm-rs6000.h b/gdb/config/rs6000/tm-rs6000.h
deleted file mode 100644 (file)
index 511c534..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-/* Parameters for target execution on an RS6000, for GDB, the GNU debugger.
-
-   Copyright 1986, 1987, 1989, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
-   1999, 2000, 2004, 2007 Free Software Foundation, Inc.
-
-   Contributed by IBM Corporation.
-
-   This file is part of GDB.
-
-   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 3 of the License, or
-   (at your option) any later version.
-
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   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, see <http://www.gnu.org/licenses/>.  */
-
-/* In xcoff, we cannot process line numbers when we see them. This is
-   mainly because we don't know the boundaries of the include files. So,
-   we postpone that, and then enter and sort(?) the whole line table at
-   once, when we are closing the current symbol table in end_symtab(). */
-
-#define        PROCESS_LINENUMBER_HOOK()       aix_process_linenos ()
-extern void aix_process_linenos (void);
-
index f0129f659870c30c326a4cea77e14b4e993af7f3..95f8cd8bd74b7c2ade494e1d420b57f9c92c9048 100644 (file)
@@ -3513,6 +3513,7 @@ static struct sym_fns aout_sym_fns =
   default_symfile_offsets,     /* sym_offsets: parse user's offsets to internal form */
   default_symfile_segments,    /* sym_segments: Get segment information from
                                   a file.  */
+  NULL,                         /* sym_read_linetable */
   NULL                         /* next: pointer to next struct sym_fns */
 };
 
index d139bdeb18d49618a8a07749db4fa00a4b99cadd..9e3ed6cbad3dc3fe71ca86ae25b0597f89c05890 100644 (file)
@@ -813,6 +813,7 @@ static struct sym_fns elf_sym_fns =
   default_symfile_offsets,     /* sym_offsets:  Translate ext. to int. relocation */
   elf_symfile_segments,                /* sym_segments: Get segment information from
                                   a file.  */
+  NULL,                         /* sym_read_linetable */
   NULL                         /* next: pointer to next struct sym_fns */
 };
 
index 280e605749fa408eeb6b14175baa1251d8bc2b3d..6f7cad899702237e3a3d24aecbed8b0354d0228c 100644 (file)
@@ -394,6 +394,7 @@ static struct sym_fns ecoff_sym_fns =
   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 */
 };
 
index 21281ef6e8acf411562451cae7f86326b00bd389..b0b1615d818bada9d5c5cefdb0a1cf46802c838f 100644 (file)
@@ -438,6 +438,7 @@ static struct sym_fns som_sym_fns =
   som_symfile_offsets,         /* sym_offsets:  Translate ext. to int. relocation */
   default_symfile_segments,    /* sym_segments: Get segment information from
                                   a file.  */
+  NULL,                         /* sym_read_linetable */
   NULL                         /* next: pointer to next struct sym_fns */
 };
 
index 49c12337b388a3f12fb282aaaca1ae0230f98806..15f60cc988fff2c7ed6759a01c54cb425d7ccaf4 100644 (file)
@@ -157,6 +157,11 @@ struct sym_fns
 
   struct symfile_segment_data *(*sym_segments) (bfd *abfd);
 
+  /* This function should read the linetable from the objfile when
+     the line table cannot be read while processing the debugging
+     information.  */
+  void (*sym_read_linetable) (void);
+
   /* Finds the next struct sym_fns.  They are allocated and
      initialized in whatever module implements the functions pointed
      to; an initializer calls add_symtab_fns to add them to the global
index 08e1de3e30438e1e26c2e0080849655af40f54d3..49bf023679a2923b2906fc078183aaee81d648d1 100644 (file)
@@ -727,7 +727,7 @@ return_after_cleanup:
   memset (&main_subfile, '\0', sizeof (struct subfile));
 }
 
-void
+static void
 aix_process_linenos (void)
 {
   /* process line numbers and enter them into line vector */
@@ -3012,6 +3012,7 @@ static struct sym_fns xcoff_sym_fns =
   xcoff_symfile_offsets,       /* sym_offsets: xlate offsets ext->int form */
   default_symfile_segments,    /* sym_segments: Get segment information from
                                   a file.  */
+  aix_process_linenos,          /* sym_read_linetable */
   NULL                         /* next: pointer to next struct sym_fns */
 };