Home | History | Annotate | Line # | Download | only in include
cpu.h revision 1.15
      1 /*	$NetBSD: cpu.h,v 1.15 2001/01/01 04:33:40 tsubai 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 #include "opt_multiprocessor.h"
     39 #endif
     40 
     41 #include <machine/frame.h>
     42 #include <machine/psl.h>
     43 #include <machine/intr.h>
     44 
     45 #ifdef _KERNEL
     46 #include <sys/sched.h>
     47 struct cpu_info {
     48 	struct schedstate_percpu ci_schedstate; /* scheduler state */
     49 #if defined(DIAGNOSTIC) || defined(LOCKDEBUG)
     50 	u_long ci_spin_locks;		/* # of spin locks held */
     51 	u_long ci_simple_locks;		/* # of simple locks held */
     52 #endif
     53 	struct proc *ci_curproc;	/* current owner of the processor */
     54 
     55 	struct pcb *ci_curpcb;
     56 	struct pmap *ci_curpm;
     57 	struct proc *ci_fpuproc;
     58 	struct pcb *ci_idle_pcb;	/* PA of our idle pcb */
     59 	int ci_cpuid;
     60 
     61 	int ci_astpending;
     62 	int ci_want_resched;
     63 	u_long ci_lasttb;
     64 	int ci_tickspending;
     65 	int ci_cpl;
     66 	int ci_ipending;
     67 	int ci_intrdepth;
     68 	char *ci_intstk;
     69 	char *ci_spillstk;
     70 	int ci_tempsave[8];
     71 	int ci_ddbsave[8];
     72 	int ci_ipkdbsave[8];
     73 	int ci_disisave[4];
     74 };
     75 
     76 #ifdef MULTIPROCESSOR
     77 static __inline int
     78 cpu_number()
     79 {
     80 	int pir;
     81 
     82 	asm ("mfspr %0,1023" : "=r"(pir));
     83 	return pir;
     84 }
     85 
     86 extern struct cpu_info cpu_info[];
     87 
     88 #define CPU_IS_PRIMARY(ci)	((ci)->ci_cpuid == 0)
     89 #define curcpu()		(&cpu_info[cpu_number()])
     90 #define curproc			curcpu()->ci_curproc
     91 #define fpuproc			curcpu()->ci_fpuproc
     92 #define curpcb			curcpu()->ci_curpcb
     93 #define curpm			curcpu()->ci_curpm
     94 #define want_resched		curcpu()->ci_want_resched
     95 #define astpending		curcpu()->ci_astpending
     96 
     97 #else
     98 extern struct cpu_info cpu_info_store;
     99 extern volatile int want_resched;
    100 extern volatile int astpending;
    101 
    102 #define curcpu()		(&cpu_info_store)
    103 #define cpu_number()		0
    104 
    105 #endif /* MULTIPROCESSOR */
    106 
    107 #define	CLKF_USERMODE(frame)	(((frame)->srr1 & PSL_PR) != 0)
    108 #define	CLKF_BASEPRI(frame)	((frame)->pri == 0)
    109 #define	CLKF_PC(frame)		((frame)->srr0)
    110 #define	CLKF_INTR(frame)	((frame)->depth > 0)
    111 
    112 #define	PROC_PC(p)		(trapframe(p)->srr0)
    113 
    114 #define	cpu_swapout(p)
    115 #define cpu_wait(p)
    116 
    117 extern void delay __P((unsigned));
    118 #define	DELAY(n)		delay(n)
    119 
    120 #define	need_resched(ci)	(want_resched = 1, astpending = 1)
    121 #define	need_proftick(p)	((p)->p_flag |= P_OWEUPC, astpending = 1)
    122 #define	signotify(p)		(astpending = 1)
    123 
    124 extern char bootpath[];
    125 
    126 #endif /* _KERNEL */
    127 
    128 #if defined(_KERNEL) || defined(_STANDALONE)
    129 #define	CACHELINESIZE	32
    130 #endif
    131 
    132 #include <powerpc/cpu.h>
    133 
    134 #endif	/* _MACHINE_CPU_H_ */
    135