pcb.h revision 1.21 1 1.21 perry /* $NetBSD: pcb.h,v 1.21 2005/12/24 20:07:28 perry 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.11 matt #ifndef _POWERPC_PCB_H_
34 1.11 matt #define _POWERPC_PCB_H_
35 1.1 ws
36 1.6 matt #include <powerpc/reg.h>
37 1.6 matt
38 1.13 matt struct faultbuf {
39 1.13 matt register_t fb_pc; /* PC */
40 1.13 matt register_t fb_sp; /* R1 */
41 1.13 matt register_t fb_r2; /* R2 (why?) */
42 1.13 matt register_t fb_cr; /* CR */
43 1.13 matt register_t fb_fixreg[19]; /* R13-R31 */
44 1.13 matt };
45 1.13 matt
46 1.1 ws struct pcb {
47 1.1 ws struct pmap *pcb_pm; /* pmap of our vmspace */
48 1.1 ws register_t pcb_sp; /* saved SP */
49 1.12 matt int pcb_flags;
50 1.19 matt #define PCB_OWNFPU 1 /* Process owns FPU resources */
51 1.19 matt #define PCB_OWNALTIVEC 2 /* Process owns AltiVec resources */
52 1.19 matt #define PCB_FPU 4 /* Process had FPU initialized */
53 1.19 matt #define PCB_ALTIVEC 8 /* Process had AltiVec initialized */
54 1.17 matt #define PCB_FE1 PSL_FE1 /* 0x100 */
55 1.17 matt #define PCB_FE0 PSL_FE0 /* 0x800 */
56 1.21 perry struct cpu_info * volatile pcb_fpcpu; /* CPU with our FP state */
57 1.21 perry struct cpu_info * volatile pcb_veccpu;/* CPU with our VECTOR state */
58 1.13 matt struct faultbuf *pcb_onfault; /* For use during copyin/copyout */
59 1.12 matt vaddr_t pcb_kmapsr; /* where to map user segment in kernel */
60 1.12 matt vaddr_t pcb_umapsr; /* the user segment mapped in kernel */
61 1.18 matt struct fpreg pcb_fpu; /* Floating point processor */
62 1.14 matt struct vreg pcb_vr __attribute__((aligned(16)));
63 1.1 ws };
64 1.1 ws
65 1.1 ws struct md_coredump {
66 1.1 ws struct trapframe frame;
67 1.18 matt struct fpreg fpstate;
68 1.6 matt struct vreg vstate;
69 1.1 ws };
70 1.1 ws
71 1.13 matt #ifdef _KERNEL
72 1.13 matt int setfault(struct faultbuf *);
73 1.1 ws #endif
74 1.5 tsubai
75 1.11 matt #endif /* _POWERPC_PCB_H_ */
76