* gdbarch.sh (convert_register_p): Add gdbarch as parameter.
authorMarkus Deuling <deuling@de.ibm.com>
Fri, 9 Nov 2007 05:32:19 +0000 (05:32 +0000)
committerMarkus Deuling <deuling@de.ibm.com>
Fri, 9 Nov 2007 05:32:19 +0000 (05:32 +0000)
* ia64-tdep.c (ia64_convert_register_p): Likewise.
* i387-tdep.c (i387_convert_register_p): Likewise.
* i387-tdep.h (i387_convert_register_p): Likewise.
* alpha-tdep.c (alpha_convert_register_p): Likewise.
* gdbarch.{c,h}: Regenerate.

* rs6000-tdep.c (rs6000_convert_register_p): Add gdbarch as parameter.
Replace current_gdbarch by gdbarch.
* mips-tdep.c (mips_convert_register_p): Likewise.
* m68k-tdep.c (m68k_convert_register_p): Likewise.
* i386-tdep.c (i386_convert_register_p): Likewise.

12 files changed:
gdb/ChangeLog
gdb/alpha-tdep.c
gdb/gdbarch.c
gdb/gdbarch.h
gdb/gdbarch.sh
gdb/i386-tdep.c
gdb/i387-tdep.c
gdb/i387-tdep.h
gdb/ia64-tdep.c
gdb/m68k-tdep.c
gdb/mips-tdep.c
gdb/rs6000-tdep.c

index ebddce75edfc3484a232fe2cbca2d9220321eb19..b61a1236f17463c848abca5047faa185bf1d115f 100644 (file)
@@ -1,3 +1,18 @@
+2007-11-09  Markus Deuling  <deuling@de.ibm.com>
+
+       * gdbarch.sh (convert_register_p): Add gdbarch as parameter.
+       * ia64-tdep.c (ia64_convert_register_p): Likewise.
+       * i387-tdep.c (i387_convert_register_p): Likewise.
+       * i387-tdep.h (i387_convert_register_p): Likewise.
+       * alpha-tdep.c (alpha_convert_register_p): Likewise.
+       * gdbarch.{c,h}: Regenerate.
+
+       * rs6000-tdep.c (rs6000_convert_register_p): Add gdbarch as parameter.
+       Replace current_gdbarch by gdbarch.
+       * mips-tdep.c (mips_convert_register_p): Likewise.
+       * m68k-tdep.c (m68k_convert_register_p): Likewise.
+       * i386-tdep.c (i386_convert_register_p): Likewise.
+
 2007-11-08  Aleksandar Ristovski  <aristovski@qnx.com>
 
        * gdb_string.h: Include <strings.h>.
index a77ad25b49df948ffa2543d0c36fb25d67f409c2..d3bc0c840ab752c9774d1d23b1876a05e9557edc 100644 (file)
@@ -198,7 +198,7 @@ alpha_sts (void *out, const void *in)
    registers is different. */
 
 static int
-alpha_convert_register_p (int regno, struct type *type)
+alpha_convert_register_p (struct gdbarch *gdbarch, int regno, struct type *type)
 {
   return (regno >= ALPHA_FP0_REGNUM && regno < ALPHA_FP0_REGNUM + 31
          && TYPE_LENGTH (type) != 8);
index ea8c4d4a890a840aba95fbff05f864a8ca5b6796..11e86705bf6d71295e7887ed23e47c9262a0bcce 100644 (file)
@@ -295,7 +295,7 @@ struct gdbarch startup_gdbarch =
   0,  /* cannot_store_register */
   0,  /* get_longjmp_target */
   0,  /* believe_pcc_promotion */
-  0,  /* convert_register_p */
+  generic_convert_register_p,  /* convert_register_p */
   0,  /* register_to_value */
   0,  /* value_to_register */
   0,  /* value_from_register */
@@ -1922,7 +1922,7 @@ gdbarch_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *ty
   gdb_assert (gdbarch->convert_register_p != NULL);
   if (gdbarch_debug >= 2)
     fprintf_unfiltered (gdb_stdlog, "gdbarch_convert_register_p called\n");
-  return gdbarch->convert_register_p (regnum, type);
+  return gdbarch->convert_register_p (gdbarch, regnum, type);
 }
 
 void
index 8874d3e61c6fad0eba391d5ceb5e0c495d812adc..355054ae59da6f5290f868b3f2453a4a25830abe 100644 (file)
@@ -319,7 +319,7 @@ extern void set_gdbarch_get_longjmp_target (struct gdbarch *gdbarch, gdbarch_get
 extern int gdbarch_believe_pcc_promotion (struct gdbarch *gdbarch);
 extern void set_gdbarch_believe_pcc_promotion (struct gdbarch *gdbarch, int believe_pcc_promotion);
 
-typedef int (gdbarch_convert_register_p_ftype) (int regnum, struct type *type);
+typedef int (gdbarch_convert_register_p_ftype) (struct gdbarch *gdbarch, int regnum, struct type *type);
 extern int gdbarch_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *type);
 extern void set_gdbarch_convert_register_p (struct gdbarch *gdbarch, gdbarch_convert_register_p_ftype *convert_register_p);
 
index 7a0f0358b409717db330d7504d037f9c2bd0ac42..51c6d6b659fdf0791818e85326f7d9446e7d1114 100755 (executable)
@@ -452,7 +452,7 @@ F:int:get_longjmp_target:struct frame_info *frame, CORE_ADDR *pc:frame, pc
 #
 v:int:believe_pcc_promotion:::::::
 #
-f:int:convert_register_p:int regnum, struct type *type:regnum, type:0:generic_convert_register_p::0
+m:int:convert_register_p:int regnum, struct type *type:regnum, type:0:generic_convert_register_p::0
 f:void:register_to_value:struct frame_info *frame, int regnum, struct type *type, gdb_byte *buf:frame, regnum, type, buf:0
 f:void:value_to_register:struct frame_info *frame, int regnum, struct type *type, const gdb_byte *buf:frame, regnum, type, buf:0
 # Construct a value representing the contents of register REGNUM in
index f385c20982bc96db0207381c830666180052832b..710a01b55041a799b3c08afd0d1a1a6ddf6c289c 100644 (file)
@@ -1857,7 +1857,7 @@ i386_next_regnum (int regnum)
    needs any special handling.  */
 
 static int
-i386_convert_register_p (int regnum, struct type *type)
+i386_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *type)
 {
   int len = TYPE_LENGTH (type);
 
@@ -1880,7 +1880,7 @@ i386_convert_register_p (int regnum, struct type *type)
        return 1;
     }
 
-  return i387_convert_register_p (regnum, type);
+  return i387_convert_register_p (gdbarch, regnum, type);
 }
 
 /* Read a value of type TYPE from register REGNUM in frame FRAME, and
index e665989e043946c2803f8766137e5988defc6c69..a940e88b6a9c19a72e20b8439cad4f05bba25b14 100644 (file)
@@ -289,7 +289,7 @@ i387_print_float_info (struct gdbarch *gdbarch, struct ui_file *file,
    needs any special handling.  */
 
 int
-i387_convert_register_p (int regnum, struct type *type)
+i387_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *type)
 {
   if (i386_fp_regnum_p (regnum))
     {
index a94b27ae13f234e2cdf4831cc215b1f1bf1fc0b6..3ff1c379a38a0e4d9ee0e43279181f032408f815 100644 (file)
@@ -58,7 +58,8 @@ extern void i387_print_float_info (struct gdbarch *gdbarch,
 /* Return nonzero if a value of type TYPE stored in register REGNUM
    needs any special handling.  */
 
-extern int i387_convert_register_p (int regnum, struct type *type);
+extern int i387_convert_register_p (struct gdbarch *gdbarch, int regnum,
+                                   struct type *type);
 
 /* Read a value of type TYPE from register REGNUM in frame FRAME, and
    return its contents in TO.  */
index 47f7f549c0f28a8035d5e79a4aef45b4392c2856..1d6743a7ae5b8849136b40f3352585a22d2d3665 100644 (file)
@@ -918,7 +918,7 @@ ia64_pseudo_register_write (struct gdbarch *gdbarch, struct regcache *regcache,
    and the special ia64 floating point register format.  */
 
 static int
-ia64_convert_register_p (int regno, struct type *type)
+ia64_convert_register_p (struct gdbarch *gdbarch, int regno, struct type *type)
 {
   return (regno >= IA64_FR0_REGNUM && regno <= IA64_FR127_REGNUM
          && type != builtin_type_ia64_ext);
index 98f048ef84a25306a772e3bc4bea452764b4c668..39b70c593476c3493d487003f3cbb87f75d1bc13 100644 (file)
@@ -168,9 +168,9 @@ m68k_register_name (struct gdbarch *gdbarch, int regnum)
    needs any special handling.  */
 
 static int
-m68k_convert_register_p (int regnum, struct type *type)
+m68k_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *type)
 {
-  if (!gdbarch_tdep (current_gdbarch)->fpregs_present)
+  if (!gdbarch_tdep (gdbarch)->fpregs_present)
     return 0;
   return (regnum >= M68K_FP0_REGNUM && regnum <= M68K_FP0_REGNUM + 7
          && type != builtin_type_m68881_ext);
index 98757c98d736271f196a92f4b7f27c50e8f60d31..b9d65d6300f5769823cc5b68479ea11c5a73dff5 100644 (file)
@@ -660,14 +660,14 @@ set_mips64_transfers_32bit_regs (char *args, int from_tty,
 /* Convert to/from a register and the corresponding memory value.  */
 
 static int
-mips_convert_register_p (int regnum, struct type *type)
-{
-  return (gdbarch_byte_order (current_gdbarch) == BFD_ENDIAN_BIG
-         && register_size (current_gdbarch, regnum) == 4
-         && (regnum % gdbarch_num_regs (current_gdbarch))
-               >= mips_regnum (current_gdbarch)->fp0
-         && (regnum % gdbarch_num_regs (current_gdbarch))
-               < mips_regnum (current_gdbarch)->fp0 + 32
+mips_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *type)
+{
+  return (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG
+         && register_size (gdbarch, regnum) == 4
+         && (regnum % gdbarch_num_regs (gdbarch))
+               >= mips_regnum (gdbarch)->fp0
+         && (regnum % gdbarch_num_regs (gdbarch))
+               < mips_regnum (gdbarch)->fp0 + 32
          && TYPE_CODE (type) == TYPE_CODE_FLT && TYPE_LENGTH (type) == 8);
 }
 
index 9cb560a169e065fa6c6b73486c406ac7554edff9..713dfff70d57836c7ea2ea4f5f417db5b6deed9f 100644 (file)
@@ -2424,9 +2424,10 @@ rs6000_pseudo_register_reggroup_p (struct gdbarch *gdbarch, int regnum,
    double, we need a conversion if the memory format is float.  */
 
 static int
-rs6000_convert_register_p (int regnum, struct type *type)
+rs6000_convert_register_p (struct gdbarch *gdbarch, int regnum,
+                          struct type *type)
 {
-  struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
+  struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
 
   return (tdep->ppc_fp0_regnum >= 0
          && regnum >= tdep->ppc_fp0_regnum