* findvar.c (read_register): Provide some support for 64 bit regs.
authorDavid Edelsohn <dje.gcc@gmail.com>
Thu, 8 Jul 1993 15:27:23 +0000 (15:27 +0000)
committerDavid Edelsohn <dje.gcc@gmail.com>
Thu, 8 Jul 1993 15:27:23 +0000 (15:27 +0000)
(write_register): Ditto.

gdb/ChangeLog
gdb/findvar.c

index 1e28508778ca21270b3d09a18017f715b79e12b0..6d2fd2f6255bab089ecc05a8c58f8875edba549d 100644 (file)
@@ -1,3 +1,8 @@
+Thu Jul  8 08:22:05 1993  Doug Evans  (dje@canuck.cygnus.com)
+
+       * findvar.c (read_register): Provide some support for 64 bit regs.
+       (write_register): Ditto.
+
 Wed Jul  7 14:30:00 1993  Jim Kingdon  (kingdon@lioth.cygnus.com)
 
        * config/mips/nm-riscos.h: machine/machparam.h is always the right
index 214870cb93b0e1eebbabc99b26ecff707cbb5af5..e38240521ebae5e40fd78c554124959c69df9a00 100644 (file)
@@ -306,6 +306,7 @@ read_register (regno)
   unsigned short sval;
   unsigned int ival;
   unsigned long lval;
+  LONGEST llval;
 
   int size;
   
@@ -334,6 +335,12 @@ read_register (regno)
       SWAP_TARGET_AND_HOST (&lval, sizeof (lval));
       return lval;
     }
+  else if (size == sizeof (llval))
+    {
+      memcpy (&llval, &registers[REGISTER_BYTE (regno)], sizeof (llval));
+      SWAP_TARGET_AND_HOST (&llval, sizeof (llval));
+      return llval;
+    }
   else
     {
       error ("GDB Internal Error in read_register() for register %d, size %d",
@@ -358,6 +365,7 @@ write_register (regno, val)
   unsigned short sval;
   unsigned int ival;
   unsigned long lval;
+  LONGEST llval;
   int size;
   PTR ptr;
   
@@ -391,15 +399,20 @@ write_register (regno, val)
       ptr = (PTR) &lval;
       lval = val;
     }
-  else 
+  else if (size == sizeof(llval))
+    {
+      ptr = (PTR) &llval;
+      llval = val;
+    }
+  else
     {
       error ("GDB Internal Error in write_register() for register %d, size %d",
             regno, size);
     }
   
+  SWAP_TARGET_AND_HOST (ptr, size);
   if (register_valid [regno]) 
     {
-      SWAP_TARGET_AND_HOST (ptr, size);
       if (memcmp (&registers[REGISTER_BYTE (regno)],
                  ptr, size) == 0)
        return;