merge from gcc
[deliverable/binutils-gdb.git] / gdb / mips-linux-nat.c
index cec16d3175fdd943aa16edb2753c4372e5441d5e..e05c373175ac7ad697f4dc9f560bbdc8d093e93f 100644 (file)
@@ -1,5 +1,6 @@
 /* Native-dependent code for GNU/Linux on MIPS processors.
-   Copyright 2001 Free Software Foundation, Inc.
+
+   Copyright 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
 
    This file is part of GDB.
 
    Boston, MA 02111-1307, USA.  */
 
 #include "defs.h"
+#include "mips-tdep.h"
+#include "target.h"
+#include "linux-nat.h"
 
 /* Pseudo registers can not be read.  ptrace does not provide a way to
-   read (or set) PS_REGNUM, and there's no point in reading or setting
-   ZERO_REGNUM.  We also can not set BADVADDR, CAUSE, or FCRIR via
-   ptrace().  */
+   read (or set) MIPS_PS_REGNUM, and there's no point in reading or
+   setting MIPS_ZERO_REGNUM.  We also can not set BADVADDR, CAUSE, or
+   FCRIR via ptrace().  */
 
 int
 mips_linux_cannot_fetch_register (int regno)
 {
-  if (regno >= FP_REGNUM)
-    return 1;
-  else if (regno == PS_REGNUM)
-    return 1;
-  else if (regno == ZERO_REGNUM)
-    return 1;
-  else
+  if (regno > MIPS_ZERO_REGNUM && regno < MIPS_ZERO_REGNUM + 32)
+    return 0;
+  else if (regno >= mips_regnum (current_gdbarch)->fp0
+          && regno <= mips_regnum (current_gdbarch)->fp0 + 32)
     return 0;
+  else if (regno == mips_regnum (current_gdbarch)->lo
+          || regno == mips_regnum (current_gdbarch)->hi
+          || regno == mips_regnum (current_gdbarch)->badvaddr
+          || regno == mips_regnum (current_gdbarch)->cause
+          || regno == mips_regnum (current_gdbarch)->pc
+          || regno == mips_regnum (current_gdbarch)->fp_control_status
+          || regno == mips_regnum (current_gdbarch)->fp_implementation_revision)
+    return 0;
+  else
+    return 1;
 }
 
 int
 mips_linux_cannot_store_register (int regno)
 {
-  if (regno >= FP_REGNUM)
-    return 1;
-  else if (regno == PS_REGNUM)
-    return 1;
-  else if (regno == ZERO_REGNUM)
-    return 1;
-  else if (regno == BADVADDR_REGNUM)
-    return 1;
-  else if (regno == CAUSE_REGNUM)
-    return 1;
-  else if (regno == FCRIR_REGNUM)
-    return 1;
-  else
+  if (regno > MIPS_ZERO_REGNUM && regno < MIPS_ZERO_REGNUM + 32)
+    return 0;
+  else if (regno >= FP0_REGNUM && regno <= FP0_REGNUM + 32)
+    return 0;
+  else if (regno == mips_regnum (current_gdbarch)->lo
+          || regno == mips_regnum (current_gdbarch)->hi
+          || regno == mips_regnum (current_gdbarch)->pc
+          || regno == mips_regnum (current_gdbarch)->fp_control_status)
     return 0;
+  else
+    return 1;
+}
+
+void _initialize_mips_linux_nat (void);
+
+void
+_initialize_mips_linux_nat (void)
+{
+  add_target (linux_target ());
 }
This page took 0.024416 seconds and 4 git commands to generate.