pcb.h revision 1.7 1 1.7 tsubai /* $NetBSD: pcb.h,v 1.7 2001/03/22 04:11:46 tsubai Exp $ */
2 1.1 ws
3 1.1 ws /*-
4 1.1 ws * Copyright (C) 1995, 1996 Wolfgang Solfrank.
5 1.1 ws * Copyright (C) 1995, 1996 TooLs GmbH.
6 1.1 ws * All rights reserved.
7 1.1 ws *
8 1.1 ws * Redistribution and use in source and binary forms, with or without
9 1.1 ws * modification, are permitted provided that the following conditions
10 1.1 ws * are met:
11 1.1 ws * 1. Redistributions of source code must retain the above copyright
12 1.1 ws * notice, this list of conditions and the following disclaimer.
13 1.1 ws * 2. Redistributions in binary form must reproduce the above copyright
14 1.1 ws * notice, this list of conditions and the following disclaimer in the
15 1.1 ws * documentation and/or other materials provided with the distribution.
16 1.1 ws * 3. All advertising materials mentioning features or use of this software
17 1.1 ws * must display the following acknowledgement:
18 1.1 ws * This product includes software developed by TooLs GmbH.
19 1.1 ws * 4. The name of TooLs GmbH may not be used to endorse or promote products
20 1.1 ws * derived from this software without specific prior written permission.
21 1.1 ws *
22 1.1 ws * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
23 1.1 ws * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 1.1 ws * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 1.1 ws * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 1.1 ws * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
27 1.1 ws * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
28 1.1 ws * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
29 1.1 ws * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
30 1.1 ws * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
31 1.1 ws * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 1.1 ws */
33 1.1 ws #ifndef _MACHINE_PCB_H_
34 1.1 ws #define _MACHINE_PCB_H_
35 1.1 ws
36 1.6 matt #include <powerpc/reg.h>
37 1.6 matt
38 1.2 ws typedef int faultbuf[23];
39 1.1 ws
40 1.1 ws struct pcb {
41 1.1 ws struct pmap *pcb_pm; /* pmap of our vmspace */
42 1.1 ws struct pmap *pcb_pmreal; /* real address of above */
43 1.1 ws register_t pcb_sp; /* saved SP */
44 1.1 ws int pcb_spl; /* saved SPL */
45 1.1 ws faultbuf *pcb_onfault; /* For use during copyin/copyout */
46 1.1 ws int pcb_flags;
47 1.1 ws #define PCB_FPU 1 /* Process had FPU initialized */
48 1.1 ws struct fpu {
49 1.1 ws double fpr[32];
50 1.3 danw double fpscr; /* FPSCR stored as double for easier access */
51 1.1 ws } pcb_fpu; /* Floating point processor */
52 1.7 tsubai struct cpu_info *pcb_fpcpu; /* CPU with our FP state */
53 1.6 matt struct vreg *pcb_vr;
54 1.1 ws };
55 1.1 ws
56 1.1 ws struct md_coredump {
57 1.1 ws struct trapframe frame;
58 1.4 tsubai struct fpu fpstate;
59 1.6 matt struct vreg vstate;
60 1.1 ws };
61 1.1 ws
62 1.5 tsubai #if defined(_KERNEL) && !defined(MULTIPROCESSOR)
63 1.1 ws extern struct pcb *curpcb;
64 1.1 ws extern struct pmap *curpm;
65 1.6 matt extern struct proc *fpuproc, *vecproc;
66 1.6 matt extern struct pool *vecpl;
67 1.1 ws #endif
68 1.5 tsubai
69 1.1 ws #endif /* _MACHINE_PCB_H_ */
70