* dbxread.c (read_dbx_symtab): Don't report an internal error if
authorJim Blandy <jimb@codesourcery.com>
Sat, 13 Sep 2003 00:17:36 +0000 (00:17 +0000)
committerJim Blandy <jimb@codesourcery.com>
Sat, 13 Sep 2003 00:17:36 +0000 (00:17 +0000)
the file has no .data, .bss, or .rodata sections.  Instead wait
until we see a variable alleged to live in one of those sections.

gdb/ChangeLog
gdb/dbxread.c

index 2f470b8..48e36c9 100644 (file)
@@ -1,5 +1,9 @@
 2003-09-12  Jim Blandy  <jimb@redhat.com>
 
+       * dbxread.c (read_dbx_symtab): Don't report an internal error if
+       the file has no .data, .bss, or .rodata sections.  Instead wait
+       until we see a variable alleged to live in one of those sections.
+
        * dbxread.c (read_dbx_symtab): If we have no .data section and no
        .bss section, presume that any variables we find live in the
        .rodata section.
index 8bfaf1c..d58fc5b 100644 (file)
@@ -1382,7 +1382,12 @@ read_dbx_symtab (struct objfile *objfile)
     data_sect_index = SECT_OFF_BSS (objfile);
   if (data_sect_index == -1)
     data_sect_index = SECT_OFF_RODATA (objfile);
-  gdb_assert (data_sect_index != -1);
+
+  /* If data_sect_index is still -1, that's okay.  It's perfectly fine
+     for the file to have no .data, no .bss, and no .text at all, if
+     it also has no global or static variables.  If it does, we will
+     get an internal error from an ANOFFSET macro below when we try to
+     use data_sect_index.  */
 
   for (symnum = 0; symnum < DBX_SYMCOUNT (objfile); symnum++)
     {