* utils.c (string_to_core_addr): If the executable format
authorMaciej W. Rozycki <macro@linux-mips.org>
Mon, 17 Dec 2007 17:49:29 +0000 (17:49 +0000)
committerMaciej W. Rozycki <macro@linux-mips.org>
Mon, 17 Dec 2007 17:49:29 +0000 (17:49 +0000)
indicates that addresses should be sign-extended and there are
only 8 hex digits in the address, then do so.
* Makefile.in (utils.o): Depend on $(gdbcore_h).

gdb/ChangeLog
gdb/Makefile.in
gdb/utils.c

index af731981c06233e4fd1bd0fe7dc112802010ba66..b5ba6da8383f54e0c8b6ef16f49e2b5688184f4b 100644 (file)
@@ -1,3 +1,11 @@
+2007-12-17  Nigel Stephens  <nigel@mips.com>
+            Maciej W. Rozycki  <macro@mips.com>
+
+       * utils.c (string_to_core_addr): If the executable format
+       indicates that addresses should be sign-extended and there are
+       only 8 hex digits in the address, then do so.
+       * Makefile.in (utils.o): Depend on $(gdbcore_h).
+
 2007-12-17  Chris Dearman  <chris@mips.com>
 
        * symfile.c (init_filename_language_table): Recognise .sx as
index 961b730e82a3e6fcda4f37eeddbaee024e6190b4..a46c9d45c945e9ff8537f5bbc6b094a76aa50d95 100644 (file)
@@ -2903,7 +2903,7 @@ utils.o: utils.c $(defs_h) $(gdb_assert_h) $(gdb_string_h) $(event_top_h) \
        $(exceptions_h) $(tui_h) $(gdbcmd_h) $(serial_h) $(bfd_h) \
        $(target_h) $(demangle_h) $(expression_h) $(language_h) $(charset_h) \
        $(annotate_h) $(filenames_h) $(symfile_h) $(inferior_h) $(top_h) \
-       $(gdb_curses_h) $(readline_h) $(gdb_obstack_h)
+       $(gdb_curses_h) $(readline_h) $(gdb_obstack_h) $(gdbcore_h)
 v850-tdep.o: v850-tdep.c $(defs_h) $(frame_h) $(frame_base_h) $(trad_frame_h) \
        $(frame_unwind_h) $(dwarf2_frame_h) $(gdbtypes_h) $(inferior_h) \
        $(gdb_string_h) $(gdb_assert_h) $(gdbcore_h) $(arch_utils_h) \
index 3be084e804e51c1559fa8f97cc10f063fb74f84d..9e796263600aa6c68f829189109f643879bf6430 100644 (file)
@@ -52,6 +52,7 @@
 #include "filenames.h"
 #include "symfile.h"
 #include "gdb_obstack.h"
+#include "gdbcore.h"
 #include "top.h"
 
 #include "inferior.h"          /* for signed_pointer_to_address */
@@ -2824,7 +2825,9 @@ core_addr_to_string_nz (const CORE_ADDR addr)
 CORE_ADDR
 string_to_core_addr (const char *my_string)
 {
+  int addr_bit = gdbarch_addr_bit (current_gdbarch);
   CORE_ADDR addr = 0;
+
   if (my_string[0] == '0' && tolower (my_string[1]) == 'x')
     {
       /* Assume that it is in hex.  */
@@ -2838,6 +2841,17 @@ string_to_core_addr (const char *my_string)
          else
            error (_("invalid hex \"%s\""), my_string);
        }
+
+      /* Not very modular, but if the executable format expects
+         addresses to be sign-extended, then do so if the address was
+         specified with only 32 significant bits.  Really this should
+         be determined by the target architecture, not by the object
+         file.  */
+      if (i - 2 == addr_bit / 4
+         && exec_bfd
+         && bfd_get_sign_extend_vma (exec_bfd))
+       addr = (addr ^ ((CORE_ADDR) 1 << (addr_bit - 1)))
+              - ((CORE_ADDR) 1 << (addr_bit - 1));
     }
   else
     {
@@ -2851,6 +2865,7 @@ string_to_core_addr (const char *my_string)
            error (_("invalid decimal \"%s\""), my_string);
        }
     }
+
   return addr;
 }