From 60718890ae203c5e84c8b90f13763bf7a87e7afb Mon Sep 17 00:00:00 2001 From: jdp Date: Mon, 14 Sep 1998 22:43:40 +0000 Subject: Add new functions fill_fpregs() and set_fpregs(), like fill_regs() and set_regs() but for the floating point register state. The code is stolen from procfs_machdep.c, and moved out of there into machdep.c. These functions are needed for generating ELF core dumps. --- sys/powerpc/include/md_var.h | 8 +++++++- sys/powerpc/powerpc/procfs_machdep.c | 19 +++---------------- 2 files changed, 10 insertions(+), 17 deletions(-) (limited to 'sys/powerpc') diff --git a/sys/powerpc/include/md_var.h b/sys/powerpc/include/md_var.h index 3dfdad2..cd2e667 100644 --- a/sys/powerpc/include/md_var.h +++ b/sys/powerpc/include/md_var.h @@ -23,7 +23,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: md_var.h,v 1.1 1998/06/10 10:55:11 dfr Exp $ + * $Id: md_var.h,v 1.2 1998/07/12 16:32:09 dfr Exp $ */ #ifndef _MACHINE_MD_VAR_H_ @@ -39,6 +39,10 @@ extern int szsigcode; extern int Maxmem; extern void (*netisrs[32]) __P((void)); +struct fpreg; +struct proc; +struct reg; + void cpu_power_down __P((void)); void cpu_halt __P((void)); void cpu_reset __P((void)); @@ -47,5 +51,7 @@ void swi_vm __P((void)); int vm_page_zero_idle __P((void)); int fill_regs __P((struct proc *, struct reg *)); int set_regs __P((struct proc *, struct reg *)); +int fill_fpregs __P((struct proc *, struct fpreg *)); +int set_fpregs __P((struct proc *, struct fpreg *)); #endif /* !_MACHINE_MD_VAR_H_ */ diff --git a/sys/powerpc/powerpc/procfs_machdep.c b/sys/powerpc/powerpc/procfs_machdep.c index 11898d0..621280a 100644 --- a/sys/powerpc/powerpc/procfs_machdep.c +++ b/sys/powerpc/powerpc/procfs_machdep.c @@ -37,7 +37,7 @@ * @(#)procfs_machdep.c 8.3 (Berkeley) 1/27/94 * * From: - * $Id: procfs_machdep.c,v 1.10 1997/07/20 08:37:22 bde Exp $ + * $Id: procfs_machdep.c,v 1.1 1998/06/10 10:53:04 dfr Exp $ */ /* @@ -112,15 +112,7 @@ procfs_read_fpregs(p, fpregs) { if ((p->p_flag & P_INMEM) == 0) return (EIO); - - if (p == fpcurproc) { - alpha_pal_wrfen(1); - savefpstate(&p->p_addr->u_pcb.pcb_fp); - alpha_pal_wrfen(0); - } - - bcopy(&p->p_addr->u_pcb.pcb_fp, fpregs, sizeof *fpregs); - return (0); + return (fill_fpregs(p, fpregs)); } int @@ -130,12 +122,7 @@ procfs_write_fpregs(p, fpregs) { if ((p->p_flag & P_INMEM) == 0) return (EIO); - - if (p == fpcurproc) - fpcurproc = NULL; - - bcopy(fpregs, &p->p_addr->u_pcb.pcb_fp, sizeof *fpregs); - return (0); + return (set_fpregs(p, fpregs)); } int -- cgit v1.1