Home | History | Annotate | Line # | Download | only in include
cpu.h revision 1.12
      1 /*	$NetBSD: cpu.h,v 1.12 2000/07/06 22:56:22 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 
     62 #ifdef MULTIPROCESSOR
     63 static __inline int
     64 cpu_number()
     65 {
     66 	int pir;
     67 
     68 	asm ("mfspr %0,1023" : "=r"(pir));
     69 	return pir;
     70 }
     71 
     72 extern struct cpu_info cpu_info[];
     73 
     74 #define CPU_IS_PRIMARY(ci)	((ci)->ci_cpuid == 0)
     75 #define curcpu()		(&cpu_info[cpu_number()])
     76 #define curproc			curcpu()->ci_curproc
     77 #define fpuproc			curcpu()->ci_fpuproc
     78 #define curpcb			curcpu()->ci_curpcb
     79 #define curpm			curcpu()->ci_curpm
     80 
     81 #else
     82 extern struct cpu_info cpu_info_store;
     83 
     84 #define curcpu()		(&cpu_info_store)
     85 #define cpu_number()		0
     86 
     87 #endif /* MULTIPROCESSOR */
     88 
     89 #define	CLKF_USERMODE(frame)	(((frame)->srr1 & PSL_PR) != 0)
     90 #define	CLKF_BASEPRI(frame)	((frame)->pri == 0)
     91 #define	CLKF_PC(frame)		((frame)->srr0)
     92 #define	CLKF_INTR(frame)	((frame)->depth > 0)
     93 
     94 #define	cpu_swapout(p)
     95 #define cpu_wait(p)
     96 
     97 extern void delay __P((unsigned));
     98 #define	DELAY(n)		delay(n)
     99 
    100 extern __volatile int want_resched;
    101 extern __volatile int astpending;
    102 
    103 #define	need_resched()		(want_resched = 1, astpending = 1)
    104 #define	need_proftick(p)	((p)->p_flag |= P_OWEUPC, astpending = 1)
    105 #define	signotify(p)		(astpending = 1)
    106 
    107 extern char bootpath[];
    108 
    109 #endif /* _KERNEL */
    110 
    111 #if defined(_KERNEL) || defined(_STANDALONE)
    112 #define	CACHELINESIZE	32
    113 #endif
    114 
    115 #include <powerpc/cpu.h>
    116 
    117 #endif	/* _MACHINE_CPU_H_ */
    118