From: Jim Kingdon Date: Tue, 7 Sep 1993 18:12:26 +0000 (+0000) Subject: * dbxread.c (process_one_symbol): If the value of an N_FUN for a X-Git-Tag: gdb-4_18~17518 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=8adcfb97ad106747ac5eb14d50c97540b288e693;p=external%2Fbinutils.git * dbxread.c (process_one_symbol): If the value of an N_FUN for a function is zero, use minimal symbols to get the address. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index aeac2c7..d8e50e4 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +Tue Sep 7 13:06:44 1993 Jim Kingdon (kingdon@lioth.cygnus.com) + + * dbxread.c (process_one_symbol): If the value of an N_FUN for a + function is zero, use minimal symbols to get the address. + Mon Sep 6 15:01:57 1993 Jeffrey Wheat (cassidy@cygnus.com) * elfread.c: change elf32_symbol_type to elf_symbol_type diff --git a/gdb/dbxread.c b/gdb/dbxread.c index e50cd04..8c35def 100644 --- a/gdb/dbxread.c +++ b/gdb/dbxread.c @@ -1911,7 +1911,15 @@ process_one_symbol (type, desc, valu, name, section_offsets, objfile) previous function. This means that we can use the minimal symbol table to get the address. */ - if (type == N_GSYM || type == N_STSYM) + /* On solaris up to 2.2, the N_FUN stab gets relocated. + On Solaris 2.3, ld no longer relocates stabs (which + is good), and the N_FUN's value is now always zero. + We only provide this correction for functions, not for + all N_FUN symbols, because that is easiest and all + readonly variables seem to go in the .rodata on Solaris. */ + + if (type == N_GSYM || type == N_STSYM + || (type == N_FUN && valu == 0)) { struct minimal_symbol *m; int l = colon_pos - name;