summaryrefslogtreecommitdiffstats
path: root/sys/powerpc
diff options
context:
space:
mode:
authorjdp <jdp@FreeBSD.org>1998-09-14 22:43:40 +0000
committerjdp <jdp@FreeBSD.org>1998-09-14 22:43:40 +0000
commit60718890ae203c5e84c8b90f13763bf7a87e7afb (patch)
tree3631f22c088f449c222f0399cb2d77033762962b /sys/powerpc
parentbf32f01fb996d7e78702cb9d770b1459c413f597 (diff)
downloadFreeBSD-src-60718890ae203c5e84c8b90f13763bf7a87e7afb.zip
FreeBSD-src-60718890ae203c5e84c8b90f13763bf7a87e7afb.tar.gz
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.
Diffstat (limited to 'sys/powerpc')
-rw-r--r--sys/powerpc/include/md_var.h8
-rw-r--r--sys/powerpc/powerpc/procfs_machdep.c19
2 files changed, 10 insertions, 17 deletions
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
OpenPOWER on IntegriCloud