2001-08-14 Daniel Jacobowitz <drow@mvista.com>
authorH.J. Lu <hjl.tools@gmail.com>
Wed, 15 Aug 2001 05:02:28 +0000 (05:02 +0000)
committerH.J. Lu <hjl.tools@gmail.com>
Wed, 15 Aug 2001 05:02:28 +0000 (05:02 +0000)
    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.

gdb/ChangeLog
gdb/dbxread.c
gdb/partial-stab.h

index c1567aa..51b5a87 100644 (file)
@@ -1,3 +1,13 @@
+2001-08-14  Daniel Jacobowitz  <drow@mvista.com>
+           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  <cgf@cygnus.com>
 
        * top.c (SIGSETJMP): Protect env argument with parentheses.
index 5d7ed74..f1382e7 100644 (file)
@@ -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
index ebedef7..fe772ba 100644 (file)
@@ -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