From: H.J. Lu Date: Wed, 15 Aug 2001 05:02:28 +0000 (+0000) Subject: 2001-08-14 Daniel Jacobowitz X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=40b3352ba7d2717b5cf0ec7b1756c189c2fd6076;p=binutils-gdb.git 2001-08-14 Daniel Jacobowitz H.J. Lu (hjl@gnu.org) * partial-stab.h: valu should be a CORE_ADDR. 2001-08-14 H.J. Lu (hjl@gnu.org) * dbxread.c (SWAP_SYMBOL): Removed. (INTERNALIZE_SYMBOL): Check sign extended vma. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index c1567aa8040..51b5a871440 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,13 @@ +2001-08-14 Daniel Jacobowitz + H.J. Lu (hjl@gnu.org) + + * partial-stab.h: valu should be a CORE_ADDR. + +2001-08-14 H.J. Lu (hjl@gnu.org) + + * dbxread.c (SWAP_SYMBOL): Removed. + (INTERNALIZE_SYMBOL): Check sign extended vma. + 2001-08-13 Christopher Faylor * top.c (SIGSETJMP): Protect env argument with parentheses. diff --git a/gdb/dbxread.c b/gdb/dbxread.c index 5d7ed74e8af..f1382e7ef04 100644 --- a/gdb/dbxread.c +++ b/gdb/dbxread.c @@ -946,22 +946,15 @@ fill_symbuf (bfd *sym_bfd) symbuf_read += nbytes; } -#define SWAP_SYMBOL(symp, abfd) \ - { \ - (symp)->n_strx = bfd_h_get_32(abfd, \ - (unsigned char *)&(symp)->n_strx); \ - (symp)->n_desc = bfd_h_get_16 (abfd, \ - (unsigned char *)&(symp)->n_desc); \ - (symp)->n_value = bfd_h_get_32 (abfd, \ - (unsigned char *)&(symp)->n_value); \ - } - #define INTERNALIZE_SYMBOL(intern, extern, abfd) \ { \ (intern).n_type = bfd_h_get_8 (abfd, (extern)->e_type); \ (intern).n_strx = bfd_h_get_32 (abfd, (extern)->e_strx); \ (intern).n_desc = bfd_h_get_16 (abfd, (extern)->e_desc); \ - (intern).n_value = bfd_h_get_32 (abfd, (extern)->e_value); \ + if (bfd_get_sign_extend_vma (abfd)) \ + (intern).n_value = bfd_h_get_signed_32 (abfd, (extern)->e_value); \ + else \ + (intern).n_value = bfd_h_get_32 (abfd, (extern)->e_value); \ } /* Invariant: The symbol pointed to by symbuf_idx is the first one diff --git a/gdb/partial-stab.h b/gdb/partial-stab.h index ebedef72c53..fe772ba588a 100644 --- a/gdb/partial-stab.h +++ b/gdb/partial-stab.h @@ -201,7 +201,7 @@ switch (CUR_SYMBOL_TYPE) case N_SO: { - unsigned long valu; + CORE_ADDR valu; static int prev_so_symnum = -10; static int first_so_symnum; char *p; @@ -399,7 +399,7 @@ switch (CUR_SYMBOL_TYPE) /* See if this is an end of function stab. */ if (pst && CUR_SYMBOL_TYPE == N_FUN && *namestring == '\000') { - unsigned long valu; + CORE_ADDR valu; /* It's value is the size (in bytes) of the function for function relative stabs, or the address of the function's