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