summaryrefslogtreecommitdiff
path: root/sys/arch/mvme88k/include/pcb.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/mvme88k/include/pcb.h')
-rw-r--r--sys/arch/mvme88k/include/pcb.h152
1 files changed, 3 insertions, 149 deletions
diff --git a/sys/arch/mvme88k/include/pcb.h b/sys/arch/mvme88k/include/pcb.h
index 4f03e38182b..22e82738981 100644
--- a/sys/arch/mvme88k/include/pcb.h
+++ b/sys/arch/mvme88k/include/pcb.h
@@ -1,149 +1,3 @@
-/* $OpenBSD: pcb.h,v 1.13 2004/01/12 21:33:15 miod Exp $ */
-/*
- * Copyright (c) 1996 Nivas Madhur
- * Mach Operating System
- * Copyright (c) 1993-1992 Carnegie Mellon University
- * All Rights Reserved.
- *
- * Permission to use, copy, modify and distribute this software and its
- * documentation is hereby granted, provided that both the copyright
- * notice and this permission notice appear in all copies of the
- * software, derivative works or modified versions, and any portions
- * thereof, and that both notices appear in supporting documentation.
- *
- * CARNEGIE MELLON AND OMRON ALLOW FREE USE OF THIS SOFTWARE IN ITS "AS IS"
- * CONDITION. CARNEGIE MELLON AND OMRON DISCLAIM ANY LIABILITY OF ANY KIND
- * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
- *
- * Carnegie Mellon requests users of this software to return to
- *
- * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
- * School of Computer Science
- * Carnegie Mellon University
- * Pittsburgh PA 15213-3890
- *
- * any improvements or extensions that they make and grant Carnegie Mellon
- * the rights to redistribute these changes.
- */
-/*
- * Motorola 88100 pcb definitions
- *
- */
-/*
- */
-#ifndef _M88K_PCB_H_
-#define _M88K_PCB_H_
-
-#include <machine/reg.h>
-
-/*
- * Our PCB is the regular PCB+Save area for kernel frame.
- * Upon entering kernel mode from user land, save the user context
- * in the saved_state area - this is passed as the exception frame.
- * On a context switch, only registers that need to be saved by the
- * C calling convention and few other regs (pc, psr etc) are saved
- * in the kernel_state part of the PCB. Typically, trap frames are
- * saved on the stack (by low level handlers or by hardware) but,
- * we just decided to do it in the PCB.
- */
-
-struct m88100_pcb {
- unsigned pcb_pc; /* address to return */
- unsigned pcb_ipl;
- unsigned pcb_r14;
- unsigned pcb_r15;
- unsigned pcb_r16;
- unsigned pcb_r17;
- unsigned pcb_r18;
- unsigned pcb_r19;
- unsigned pcb_r20;
- unsigned pcb_r21;
- unsigned pcb_r22;
- unsigned pcb_r23;
- unsigned pcb_r24;
- unsigned pcb_r25;
- unsigned pcb_r26;
- unsigned pcb_r27;
- unsigned pcb_r28;
- unsigned pcb_r29;
- unsigned pcb_r30;
- unsigned pcb_sp; /* kernel stack pointer */
- /* floating-point state */
- unsigned pcb_fcr62;
- unsigned pcb_fcr63;
-};
-
-struct trapframe {
- struct reg tf_regs;
- register_t tf_vector; /* exception vector number */
- register_t tf_mask; /* interrupt mask level */
- register_t tf_mode; /* interrupt mode */
- register_t tf_scratch1; /* reserved for use by locore */
- register_t tf_ipfsr; /* P BUS status */
- register_t tf_dpfsr; /* P BUS status */
- register_t tf_cpu; /* cpu number */
-};
-
-#define tf_r tf_regs.r
-#define tf_sp tf_regs.r[31]
-#define tf_epsr tf_regs.epsr
-#define tf_fpsr tf_regs.fpsr
-#define tf_fpcr tf_regs.fpcr
-#define tf_sxip tf_regs.sxip
-#define tf_snip tf_regs.snip
-#define tf_sfip tf_regs.sfip
-#define tf_exip tf_regs.sxip
-#define tf_enip tf_regs.snip
-#define tf_ssbr tf_regs.ssbr
-#define tf_dmt0 tf_regs.dmt0
-#define tf_dmd0 tf_regs.dmd0
-#define tf_dma0 tf_regs.dma0
-#define tf_dmt1 tf_regs.dmt1
-#define tf_dmd1 tf_regs.dmd1
-#define tf_dma1 tf_regs.dma1
-#define tf_dmt2 tf_regs.dmt2
-#define tf_dmd2 tf_regs.dmd2
-#define tf_dma2 tf_regs.dma2
-#define tf_duap tf_regs.ssbr
-#define tf_dsr tf_regs.dmt0
-#define tf_dlar tf_regs.dmd0
-#define tf_dpar tf_regs.dma0
-#define tf_isr tf_regs.dmt1
-#define tf_ilar tf_regs.dmd1
-#define tf_ipar tf_regs.dma1
-#define tf_isap tf_regs.dmt2
-#define tf_dsap tf_regs.dmd2
-#define tf_iuap tf_regs.dma2
-#define tf_fpecr tf_regs.fpecr
-#define tf_fphs1 tf_regs.fphs1
-#define tf_fpls1 tf_regs.fpls1
-#define tf_fphs2 tf_regs.fphs2
-#define tf_fpls2 tf_regs.fpls2
-#define tf_fppt tf_regs.fppt
-#define tf_fprh tf_regs.fprh
-#define tf_fprl tf_regs.fprl
-#define tf_fpit tf_regs.fpit
-
-struct pcb
-{
- struct m88100_pcb kernel_state;
- struct trapframe user_state;
- int pcb_onfault;
-};
-
-/*
- * Location of saved user registers for the proc.
- */
-#define USER_REGS(p) \
- (((struct reg *)(&((p)->p_addr->u_pcb.user_state))))
-/*
- * The pcb is augmented with machine-dependent additional data for
- * core dumps. Note that the trapframe here is a copy of the one
- * from the top of the kernel stack (included here so that the kernel
- * stack itself need not be dumped).
- */
-struct md_coredump {
- struct trapframe md_tf;
-};
-
-#endif /* _M88K_PCB_H_ */
+/* $OpenBSD */
+/* public domain */
+#include <m88k/pcb.h>