aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
Diffstat (limited to 'gdb')
-rw-r--r--gdb/dbxread.c66
1 files changed, 42 insertions, 24 deletions
diff --git a/gdb/dbxread.c b/gdb/dbxread.c
index 4c33fe6..06636fe 100644
--- a/gdb/dbxread.c
+++ b/gdb/dbxread.c
@@ -1524,10 +1524,15 @@ process_one_symbol (type, desc, valu, name, section_offsets, objfile)
case N_FUN:
case N_FNAME:
#if 0
-/* It seems that the Sun ANSI C compiler (acc) replaces N_FUN with N_GSYM and
- N_STSYM with a type code of f or F. Can't enable this until we get some
- stuff straightened out with psymtabs. FIXME. */
-
+ /* The Sun acc compiler, under SunOS4, puts out functions with N_GSYM
+ or N_STSYM. The problem is that the address of the symbol is no
+ good (for N_GSYM it doesn't even attept an address; for N_STSYM
+ it puts out an address but then it gets relocated relative to the
+ data segment, not the text segment), so we would have to keep track of
+ where we would use the address (e.g. to close off the block for
+ the previous function), and patch it later (we already do this for
+ some symbols, e.g. 'G', but in that case we just need to patch the
+ symbol, not other data structures). */
case N_GSYM:
case N_STSYM:
#endif /* 0 */
@@ -1844,6 +1849,24 @@ process_one_symbol (type, desc, valu, name, section_offsets, objfile)
valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
goto define_a_symbol;
+ /* The following symbol types we don't know how to process. Handle
+ them in a "default" way, but complain to people who care. */
+ default:
+ case N_CATCH: /* Exception handler catcher */
+ case N_EHDECL: /* Exception handler name */
+ case N_PC: /* Global symbol in Pascal */
+ case N_M2C: /* Modula-2 compilation unit */
+ /* N_MOD2: overlaps with N_EHDECL */
+ case N_SCOPE: /* Modula-2 scope information */
+ case N_ECOML: /* End common (local name) */
+ case N_NBTEXT: /* Gould Non-Base-Register symbols??? */
+ case N_NBDATA:
+ case N_NBBSS:
+ case N_NBSTS:
+ case N_NBLCS:
+ complain (&unknown_symtype_complaint, local_hex_string(type));
+ /* FALLTHROUGH */
+
/* The following symbol types don't need the address field relocated,
since it is either unused, or is absolute. */
define_a_symbol:
@@ -1857,7 +1880,21 @@ process_one_symbol (type, desc, valu, name, section_offsets, objfile)
case N_PSYM: /* Parameter variable */
case N_LENG: /* Length of preceding symbol type */
if (name)
- define_symbol (valu, name, desc, type, objfile);
+ {
+ struct symbol *sym;
+ sym = define_symbol (valu, name, desc, type, objfile);
+ if (sym != NULL && SYMBOL_CLASS (sym) == LOC_BLOCK)
+ {
+ /* We're not prepared to deal with this case; we won't
+ patch up the SYMBOL_BLOCK_VALUE in finish_block.
+ Setting the class to LOC_STATIC isn't particularly useful,
+ but at least we won't dump core. */
+ static struct complaint msg = {
+ "function encountered with unexpected n_type", 0, 0};
+ complain (&msg);
+ SYMBOL_CLASS (sym) = LOC_STATIC;
+ }
+ }
break;
/* We use N_OPT to carry the gcc2_compiled flag. Sun uses it
@@ -1889,25 +1926,6 @@ process_one_symbol (type, desc, valu, name, section_offsets, objfile)
case N_ENDM: /* Solaris 2: End of module */
case N_MAIN: /* Name of main routine. */
break;
-
- /* The following symbol types we don't know how to process. Handle
- them in a "default" way, but complain to people who care. */
- default:
- case N_CATCH: /* Exception handler catcher */
- case N_EHDECL: /* Exception handler name */
- case N_PC: /* Global symbol in Pascal */
- case N_M2C: /* Modula-2 compilation unit */
- /* N_MOD2: overlaps with N_EHDECL */
- case N_SCOPE: /* Modula-2 scope information */
- case N_ECOML: /* End common (local name) */
- case N_NBTEXT: /* Gould Non-Base-Register symbols??? */
- case N_NBDATA:
- case N_NBBSS:
- case N_NBSTS:
- case N_NBLCS:
- complain (&unknown_symtype_complaint, local_hex_string(type));
- if (name)
- define_symbol (valu, name, desc, type, objfile);
}
previous_stab_code = type;