cpu.h revision 1.12 1 1.12 tsubai /* $NetBSD: cpu.h,v 1.12 2000/07/06 22:56:22 tsubai Exp $ */
2 1.1 tsubai
3 1.1 tsubai /*
4 1.1 tsubai * Copyright (C) 1995-1997 Wolfgang Solfrank.
5 1.1 tsubai * Copyright (C) 1995-1997 TooLs GmbH.
6 1.1 tsubai * All rights reserved.
7 1.1 tsubai *
8 1.1 tsubai * Redistribution and use in source and binary forms, with or without
9 1.1 tsubai * modification, are permitted provided that the following conditions
10 1.1 tsubai * are met:
11 1.1 tsubai * 1. Redistributions of source code must retain the above copyright
12 1.1 tsubai * notice, this list of conditions and the following disclaimer.
13 1.1 tsubai * 2. Redistributions in binary form must reproduce the above copyright
14 1.1 tsubai * notice, this list of conditions and the following disclaimer in the
15 1.1 tsubai * documentation and/or other materials provided with the distribution.
16 1.1 tsubai * 3. All advertising materials mentioning features or use of this software
17 1.1 tsubai * must display the following acknowledgement:
18 1.1 tsubai * This product includes software developed by TooLs GmbH.
19 1.1 tsubai * 4. The name of TooLs GmbH may not be used to endorse or promote products
20 1.1 tsubai * derived from this software without specific prior written permission.
21 1.1 tsubai *
22 1.1 tsubai * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
23 1.1 tsubai * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 1.1 tsubai * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 1.1 tsubai * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 1.1 tsubai * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
27 1.1 tsubai * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
28 1.1 tsubai * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
29 1.1 tsubai * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
30 1.1 tsubai * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
31 1.1 tsubai * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 1.1 tsubai */
33 1.1 tsubai #ifndef _MACHINE_CPU_H_
34 1.1 tsubai #define _MACHINE_CPU_H_
35 1.1 tsubai
36 1.11 thorpej #if defined(_KERNEL) && !defined(_LKM)
37 1.11 thorpej #include "opt_lockdebug.h"
38 1.12 tsubai #include "opt_multiprocessor.h"
39 1.11 thorpej #endif
40 1.11 thorpej
41 1.1 tsubai #include <machine/frame.h>
42 1.1 tsubai #include <machine/psl.h>
43 1.1 tsubai #include <machine/intr.h>
44 1.11 thorpej
45 1.12 tsubai #ifdef _KERNEL
46 1.11 thorpej #include <sys/sched.h>
47 1.11 thorpej struct cpu_info {
48 1.11 thorpej struct schedstate_percpu ci_schedstate; /* scheduler state */
49 1.11 thorpej #if defined(DIAGNOSTIC) || defined(LOCKDEBUG)
50 1.11 thorpej u_long ci_spin_locks; /* # of spin locks held */
51 1.11 thorpej u_long ci_simple_locks; /* # of simple locks held */
52 1.11 thorpej #endif
53 1.12 tsubai struct proc *ci_curproc; /* current owner of the processor */
54 1.12 tsubai
55 1.12 tsubai struct pcb *ci_curpcb;
56 1.12 tsubai struct pmap *ci_curpm;
57 1.12 tsubai struct proc *ci_fpuproc;
58 1.12 tsubai struct pcb *ci_idle_pcb; /* PA of our idle pcb */
59 1.12 tsubai int ci_cpuid;
60 1.11 thorpej };
61 1.11 thorpej
62 1.12 tsubai #ifdef MULTIPROCESSOR
63 1.12 tsubai static __inline int
64 1.12 tsubai cpu_number()
65 1.12 tsubai {
66 1.12 tsubai int pir;
67 1.12 tsubai
68 1.12 tsubai asm ("mfspr %0,1023" : "=r"(pir));
69 1.12 tsubai return pir;
70 1.12 tsubai }
71 1.12 tsubai
72 1.12 tsubai extern struct cpu_info cpu_info[];
73 1.12 tsubai
74 1.12 tsubai #define CPU_IS_PRIMARY(ci) ((ci)->ci_cpuid == 0)
75 1.12 tsubai #define curcpu() (&cpu_info[cpu_number()])
76 1.12 tsubai #define curproc curcpu()->ci_curproc
77 1.12 tsubai #define fpuproc curcpu()->ci_fpuproc
78 1.12 tsubai #define curpcb curcpu()->ci_curpcb
79 1.12 tsubai #define curpm curcpu()->ci_curpm
80 1.12 tsubai
81 1.12 tsubai #else
82 1.11 thorpej extern struct cpu_info cpu_info_store;
83 1.11 thorpej
84 1.12 tsubai #define curcpu() (&cpu_info_store)
85 1.12 tsubai #define cpu_number() 0
86 1.12 tsubai
87 1.12 tsubai #endif /* MULTIPROCESSOR */
88 1.1 tsubai
89 1.1 tsubai #define CLKF_USERMODE(frame) (((frame)->srr1 & PSL_PR) != 0)
90 1.1 tsubai #define CLKF_BASEPRI(frame) ((frame)->pri == 0)
91 1.1 tsubai #define CLKF_PC(frame) ((frame)->srr0)
92 1.2 tsubai #define CLKF_INTR(frame) ((frame)->depth > 0)
93 1.1 tsubai
94 1.1 tsubai #define cpu_swapout(p)
95 1.1 tsubai #define cpu_wait(p)
96 1.1 tsubai
97 1.1 tsubai extern void delay __P((unsigned));
98 1.1 tsubai #define DELAY(n) delay(n)
99 1.1 tsubai
100 1.1 tsubai extern __volatile int want_resched;
101 1.1 tsubai extern __volatile int astpending;
102 1.1 tsubai
103 1.1 tsubai #define need_resched() (want_resched = 1, astpending = 1)
104 1.1 tsubai #define need_proftick(p) ((p)->p_flag |= P_OWEUPC, astpending = 1)
105 1.1 tsubai #define signotify(p) (astpending = 1)
106 1.1 tsubai
107 1.10 tsubai extern char bootpath[];
108 1.12 tsubai
109 1.12 tsubai #endif /* _KERNEL */
110 1.4 tsubai
111 1.7 tsubai #if defined(_KERNEL) || defined(_STANDALONE)
112 1.6 ws #define CACHELINESIZE 32
113 1.6 ws #endif
114 1.1 tsubai
115 1.6 ws #include <powerpc/cpu.h>
116 1.1 tsubai
117 1.1 tsubai #endif /* _MACHINE_CPU_H_ */
118