-/* Native-dependent code for Linux/SPARC.
- Copyright 2001 Free Software Foundation, Inc.
+/* Native-dependent code for GNU/Linux SPARC.
+ Copyright (C) 2005, 2006
+ Free Software Foundation, Inc.
This file is part of GDB.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
- Foundation, Inc., 59 Temple Place - Suite 330,
- Boston, MA 02111-1307, USA. */
+ Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ Boston, MA 02110-1301, USA. */
#include "defs.h"
#include "regcache.h"
-
-#include <sys/procfs.h>
-/* Prototypes for supply_gregset etc. */
+#include <sys/procfs.h>
#include "gregset.h"
+#include "sparc-tdep.h"
+#include "sparc-nat.h"
+#include "inferior.h"
+#include "target.h"
+#include "linux-nat.h"
+
void
-supply_gregset (elf_gregset_t *gregsetp)
+supply_gregset (prgregset_t *gregs)
{
- elf_greg_t *regp = (elf_greg_t *) gregsetp;
- int i;
-
- for (i = G0_REGNUM; i <= I7_REGNUM; i++)
- supply_register (i, (char *) (regp + (i - G0_REGNUM)));
-
- supply_register (PS_REGNUM, (char *) (regp + 32));
-
- supply_register (PC_REGNUM, (char *) (regp + 33));
- supply_register (NPC_REGNUM, (char *) (regp + 34));
- supply_register (Y_REGNUM, (char *) (regp + 35));
-
- supply_register (WIM_REGNUM, (char *) (regp + 36));
- supply_register (TBR_REGNUM, (char *) (regp + 37));
-
- /* Fill inaccessible registers with zero. */
- supply_register (CPS_REGNUM, NULL);
+ sparc32_supply_gregset (sparc_gregset, current_regcache, -1, gregs);
}
void
-fill_gregset (elf_gregset_t *gregsetp, int regno)
+supply_fpregset (prfpregset_t *fpregs)
{
- elf_greg_t *regp = (elf_greg_t *) gregsetp;
- int i;
-
- for (i = G0_REGNUM; i <= I7_REGNUM; i++)
- if (regno == -1 || regno == i)
- read_register_gen (i, (char *) (regp + (i - G0_REGNUM)));
-
- if (regno == -1 || regno == PS_REGNUM)
- read_register_gen (PS_REGNUM, (char *) (regp + 32));
-
- if (regno == -1 || regno == PC_REGNUM)
- read_register_gen (PC_REGNUM, (char *) (regp + 33));
- if (regno == -1 || regno == NPC_REGNUM)
- read_register_gen (NPC_REGNUM, (char *) (regp + 34));
- if (regno == -1 || regno == Y_REGNUM)
- read_register_gen (Y_REGNUM, (char *) (regp + 35));
-
- if (regno == -1 || regno == WIM_REGNUM)
- read_register_gen (WIM_REGNUM, (char *) (regp + 36));
- if (regno == -1 || regno == TBR_REGNUM)
- read_register_gen (TBR_REGNUM, (char *) (regp + 37));
+ sparc32_supply_fpregset (current_regcache, -1, fpregs);
}
void
-supply_fpregset (elf_fpregset_t *fpregsetp)
+fill_gregset (prgregset_t *gregs, int regnum)
{
- int i;
-
- for (i = FP0_REGNUM; i < FP0_REGNUM + 32; i++)
- supply_register (i, (char *) &fpregsetp->pr_fr.pr_regs[i - FP0_REGNUM]);
+ sparc32_collect_gregset (sparc_gregset, current_regcache, regnum, gregs);
+}
- supply_register (FPS_REGNUM, (char *) &fpregsetp->pr_fsr);
+void
+fill_fpregset (prfpregset_t *fpregs, int regnum)
+{
+ sparc32_collect_fpregset (current_regcache, regnum, fpregs);
}
+void _initialialize_sparc_linux_nat (void);
+
void
-fill_fpregset (elf_fpregset_t *fpregsetp, int regno)
+_initialize_sparc_linux_nat (void)
{
- int i;
+ struct target_ops *t;
+
+ /* Fill in the generic GNU/Linux methods. */
+ t = linux_target ();
- for (i = FP0_REGNUM; i < FP0_REGNUM + 32; i++)
- if (regno == -1 || regno == i)
- read_register_gen (i, (char *) &fpregsetp->pr_fr.pr_regs[i - FP0_REGNUM]);
+ /* Add our register access methods. */
+ t->to_fetch_registers = fetch_inferior_registers;
+ t->to_store_registers = store_inferior_registers;
- if (regno == -1 || regno == FPS_REGNUM)
- read_register_gen (FPS_REGNUM, (char *) &fpregsetp->pr_fsr);
+ /* Register the target. */
+ linux_nat_add_target (t);
}