* win32-nat.c (mappings): Add ppc registers.
authorSteve Chamberlain <sac@cygnus>
Fri, 2 Feb 1996 21:42:12 +0000 (21:42 +0000)
committerSteve Chamberlain <sac@cygnus>
Fri, 2 Feb 1996 21:42:12 +0000 (21:42 +0000)
(child_resume): Turn of step for ppc.

gdb/ChangeLog
gdb/win32-nat.c

index 96b65602909c485ef9bb947b98af4c13aa9dc6d1..23fd86ea94093ea1a1859789e44fcb80f5c7c795 100644 (file)
@@ -1,3 +1,8 @@
+Fri Feb  2 13:40:50 1996  Steve Chamberlain  <sac@slash.cygnus.com>
+
+       * win32-nat.c (mappings): Add ppc registers.
+       (child_resume): Turn of step for ppc.
+
 Thu Feb  1 10:29:31 1996  Steve Chamberlain  <sac@slash.cygnus.com>
 
        * config/powerpc/(cygwin32.mh, cygwin32.mt, tm-cygwin32.h,
index eee2474f673bba06a71584640806920b1bb2a1b2..bd624437e5a73c3f9ffc8c138fdab42148f45db1 100644 (file)
@@ -1,5 +1,5 @@
 /* Target-vector operations for controlling win32 child processes, for GDB.
-   Copyright 1995
+   Copyright 1995, 1996
    Free Software Foundation, Inc.
 
    Contributed by Cygnus Support.
@@ -83,9 +83,92 @@ struct regmappings
     int mask;
   };
 
-static const struct regmappings
-  mappings[] =
+
+static const struct regmappings  mappings[] =
 {
+#ifdef __PPC__
+  {(char *) &context.Gpr0, CONTEXT_INTEGER},
+  {(char *) &context.Gpr1, CONTEXT_INTEGER},
+  {(char *) &context.Gpr2, CONTEXT_INTEGER},
+  {(char *) &context.Gpr3, CONTEXT_INTEGER},
+  {(char *) &context.Gpr4, CONTEXT_INTEGER},
+  {(char *) &context.Gpr5, CONTEXT_INTEGER},
+  {(char *) &context.Gpr6, CONTEXT_INTEGER},
+  {(char *) &context.Gpr7, CONTEXT_INTEGER},
+
+  {(char *) &context.Gpr8, CONTEXT_INTEGER},
+  {(char *) &context.Gpr9, CONTEXT_INTEGER},
+  {(char *) &context.Gpr10, CONTEXT_INTEGER},
+  {(char *) &context.Gpr11, CONTEXT_INTEGER},
+  {(char *) &context.Gpr12, CONTEXT_INTEGER},
+  {(char *) &context.Gpr13, CONTEXT_INTEGER},
+  {(char *) &context.Gpr14, CONTEXT_INTEGER},
+  {(char *) &context.Gpr15, CONTEXT_INTEGER},
+
+  {(char *) &context.Gpr16, CONTEXT_INTEGER},
+  {(char *) &context.Gpr17, CONTEXT_INTEGER},
+  {(char *) &context.Gpr18, CONTEXT_INTEGER},
+  {(char *) &context.Gpr19, CONTEXT_INTEGER},
+  {(char *) &context.Gpr20, CONTEXT_INTEGER},
+  {(char *) &context.Gpr21, CONTEXT_INTEGER},
+  {(char *) &context.Gpr22, CONTEXT_INTEGER},
+  {(char *) &context.Gpr23, CONTEXT_INTEGER},
+
+  {(char *) &context.Gpr24, CONTEXT_INTEGER},
+  {(char *) &context.Gpr25, CONTEXT_INTEGER},
+  {(char *) &context.Gpr26, CONTEXT_INTEGER},
+  {(char *) &context.Gpr27, CONTEXT_INTEGER},
+  {(char *) &context.Gpr28, CONTEXT_INTEGER},
+  {(char *) &context.Gpr29, CONTEXT_INTEGER},
+  {(char *) &context.Gpr30, CONTEXT_INTEGER},
+  {(char *) &context.Gpr31, CONTEXT_INTEGER},
+
+  {(char *) &context.Fpr0, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr1, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr2, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr3, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr4, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr5, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr6, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr7, CONTEXT_FLOATING_POINT},
+
+  {(char *) &context.Fpr8, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr9, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr10, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr11, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr12, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr13, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr14, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr15, CONTEXT_FLOATING_POINT},
+
+  {(char *) &context.Fpr16, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr17, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr18, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr19, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr20, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr21, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr22, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr23, CONTEXT_FLOATING_POINT},
+
+  {(char *) &context.Fpr24, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr25, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr26, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr27, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr28, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr29, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr30, CONTEXT_FLOATING_POINT},
+  {(char *) &context.Fpr31, CONTEXT_FLOATING_POINT},
+
+
+  {(char *) &context.Iar, CONTEXT_CONTROL},
+  {(char *) &context.Msr, CONTEXT_CONTROL},
+  {(char *) &context.Cr,  CONTEXT_INTEGER},
+  {(char *) &context.Lr,  CONTEXT_CONTROL},
+  {(char *) &context.Ctr, CONTEXT_CONTROL},
+
+  {(char *) &context.Xer, CONTEXT_INTEGER},
+  {0,0}, /* MQ, but there isn't one */
+#else
   {(char *) &context.Eax, CONTEXT_INTEGER},
   {(char *) &context.Ecx, CONTEXT_INTEGER},
   {(char *) &context.Edx, CONTEXT_INTEGER},
@@ -110,6 +193,7 @@ static const struct regmappings
   {&context.FloatSave.RegisterArea[5 * 10], CONTEXT_FLOATING_POINT},
   {&context.FloatSave.RegisterArea[6 * 10], CONTEXT_FLOATING_POINT},
   {&context.FloatSave.RegisterArea[7 * 10], CONTEXT_FLOATING_POINT},
+#endif
 };
 
 
@@ -580,9 +664,14 @@ child_resume (int pid, int step, enum target_signal signal)
 
   if (step)
     {
+#ifdef __PPC__
+      warning ("Single stepping not done.\n");
+#endif
+#ifdef __I386__
       /* Single step by setting t bit */
       child_fetch_inferior_registers (PS_REGNUM);
       context.EFlags |= FLAG_TRACE_BIT;
+#endif
     }
 
   if (context.ContextFlags)