1 /* Host-dependent code for Sun-3 for GDB, the GNU debugger.
2 Copyright 1986, 1987, 1989, 1991 Free Software Foundation, Inc.
4 This file is part of GDB.
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
24 #include <sys/ptrace.h>
25 #define KERNEL /* To get floating point reg definitions */
26 #include <machine/reg.h>
30 #if defined (GDB_TARGET_IS_SUN3)
31 /* All of this stuff is only relevant if both host and target are sun3. */
33 fetch_inferior_registers ()
35 struct regs inferior_registers
;
37 struct fp_status inferior_fp_registers
;
39 extern char registers
[];
43 ptrace (PTRACE_GETREGS
, inferior_pid
, &inferior_registers
);
45 ptrace (PTRACE_GETFPREGS
, inferior_pid
, &inferior_fp_registers
);
48 bcopy (&inferior_registers
, registers
, 16 * 4);
50 bcopy (&inferior_fp_registers
, ®isters
[REGISTER_BYTE (FP0_REGNUM
)],
51 sizeof inferior_fp_registers
.fps_regs
);
53 *(int *)®isters
[REGISTER_BYTE (PS_REGNUM
)] = inferior_registers
.r_ps
;
54 *(int *)®isters
[REGISTER_BYTE (PC_REGNUM
)] = inferior_registers
.r_pc
;
56 bcopy (&inferior_fp_registers
.fps_control
,
57 ®isters
[REGISTER_BYTE (FPC_REGNUM
)],
58 sizeof inferior_fp_registers
- sizeof inferior_fp_registers
.fps_regs
);
62 /* Store our register values back into the inferior.
63 If REGNO is -1, do this for all registers.
64 Otherwise, REGNO specifies which register (so we can save time). */
66 store_inferior_registers (regno
)
69 struct regs inferior_registers
;
71 struct fp_status inferior_fp_registers
;
73 extern char registers
[];
75 bcopy (registers
, &inferior_registers
, 16 * 4);
77 bcopy (®isters
[REGISTER_BYTE (FP0_REGNUM
)], &inferior_fp_registers
,
78 sizeof inferior_fp_registers
.fps_regs
);
80 inferior_registers
.r_ps
= *(int *)®isters
[REGISTER_BYTE (PS_REGNUM
)];
81 inferior_registers
.r_pc
= *(int *)®isters
[REGISTER_BYTE (PC_REGNUM
)];
84 bcopy (®isters
[REGISTER_BYTE (FPC_REGNUM
)],
85 &inferior_fp_registers
.fps_control
,
86 sizeof inferior_fp_registers
- sizeof inferior_fp_registers
.fps_regs
);
89 ptrace (PTRACE_SETREGS
, inferior_pid
, &inferior_registers
);
91 ptrace (PTRACE_SETFPREGS
, inferior_pid
, &inferior_fp_registers
);
95 /* Machine-dependent code for pulling registers out of a Sun-3 core file. */
98 fetch_core_registers (core_reg_sect
, core_reg_size
, which
)
100 unsigned core_reg_size
;
103 extern char registers
[];
104 struct regs
*regs
= (struct regs
*) core_reg_sect
;
107 if (core_reg_size
< sizeof (struct regs
))
108 error ("Can't find registers in core file");
110 bcopy ((char *)regs
, registers
, 16 * 4);
111 supply_register (PS_REGNUM
, ®s
->r_ps
);
112 supply_register (PC_REGNUM
, ®s
->r_pc
);
114 } else if (which
== 2) {
116 #define fpustruct ((struct fpu *) core_reg_sect)
118 if (core_reg_size
>= sizeof (struct fpu
))
121 bcopy (fpustruct
->f_fpstatus
.fps_regs
,
122 ®isters
[REGISTER_BYTE (FP0_REGNUM
)],
123 sizeof fpustruct
->f_fpstatus
.fps_regs
);
124 bcopy (&fpustruct
->f_fpstatus
.fps_control
,
125 ®isters
[REGISTER_BYTE (FPC_REGNUM
)],
126 sizeof fpustruct
->f_fpstatus
-
127 sizeof fpustruct
->f_fpstatus
.fps_regs
);
131 fprintf (stderr
, "Couldn't read float regs from core file\n");
134 #else /* Not sun3 target. */
135 /* These functions shouldn't be called when we're cross-debugging. */
138 fetch_inferior_registers ()
143 store_inferior_registers (regno
)
150 fetch_core_registers (core_reg_sect
, core_reg_size
, which
)
152 unsigned core_reg_size
;
156 #endif /* Not sun3 target. */