+
+#include "alpha-tdep.h"
+
+#include <sys/ptrace.h>
+#include <alpha/ptrace.h>
+
+#include <sys/procfs.h>
+#include "gregset.h"
+
+/* The address of UNIQUE for ptrace. */
+#define ALPHA_UNIQUE_PTRACE_ADDR 65
+
+
+/*
+ * See the comment in m68k-tdep.c regarding the utility of these functions.
+ */
+
+void
+supply_gregset (struct regcache *regcache, const gdb_gregset_t *gregsetp)
+{
+ const long *regp = (const long *)gregsetp;
+
+ /* PC is in slot 32, UNIQUE is in slot 33. */
+ alpha_supply_int_regs (regcache, -1, regp, regp + 31, regp + 32);
+}
+
+void
+fill_gregset (const struct regcache *regcache,
+ gdb_gregset_t *gregsetp, int regno)
+{
+ long *regp = (long *)gregsetp;
+
+ /* PC is in slot 32, UNIQUE is in slot 33. */
+ alpha_fill_int_regs (regcache, regno, regp, regp + 31, regp + 32);
+}
+
+/*
+ * Now we do the same thing for floating-point registers.
+ * Again, see the comments in m68k-tdep.c.
+ */
+
+void
+supply_fpregset (struct regcache *regcache, const gdb_fpregset_t *fpregsetp)
+{
+ const long *regp = (const long *)fpregsetp;
+
+ /* FPCR is in slot 32. */
+ alpha_supply_fp_regs (regcache, -1, regp, regp + 31);
+}
+
+void
+fill_fpregset (const struct regcache *regcache,
+ gdb_fpregset_t *fpregsetp, int regno)
+{
+ long *regp = (long *)fpregsetp;
+
+ /* FPCR is in slot 32. */
+ alpha_fill_fp_regs (regcache, regno, regp, regp + 31);
+}
+