Home | History | Annotate | Line # | Download | only in include
intr.h revision 1.5
      1 /*	$NetBSD: intr.h,v 1.5 1999/08/04 07:14:13 dbj Exp $	*/
      2 
      3 /*
      4  * Copyright (C) 1997 Scott Reynolds
      5  * Copyright (C) 1998 Darrin Jewell
      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. The name of the author may not be used to endorse or promote products
     17  *    derived from this software without specific prior written permission.
     18  *
     19  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     20  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     21  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     22  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     23  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     24  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     28  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     29  */
     30 
     31 #ifndef _NEXT68K_INTR_H_
     32 #define _NEXT68K_INTR_H_
     33 
     34 #include <machine/psl.h>
     35 
     36 /* Probably want to dealwith IPL's here @@@ */
     37 
     38 #ifdef _KERNEL
     39 /*
     40  * spl functions; all but spl0 are done in-line
     41  */
     42 
     43 #define _spl(s)								\
     44 ({									\
     45         register int _spl_r;						\
     46 									\
     47         __asm __volatile ("clrl %0; movew sr,%0; movew %1,sr" :		\
     48                 "&=d" (_spl_r) : "di" (s));				\
     49         _spl_r;								\
     50 })
     51 
     52 #define _splraise(s)							\
     53 ({									\
     54 	int _spl_r;							\
     55 									\
     56 	__asm __volatile ("						\
     57 		clrl	d0					;	\
     58 		movw	sr,d0					;	\
     59 		movl	d0,%0					;	\
     60 		andw	#0x700,d0				;	\
     61 		movw	%1,d1					;	\
     62 		andw	#0x700,d1				;	\
     63 		cmpw	d0,d1					;	\
     64 		jle	1f					;	\
     65 		movw	%1,sr					;	\
     66 	    1:"							:	\
     67 		    "&=d" (_spl_r)				:	\
     68 		    "di" (s)					:	\
     69 		    "d0", "d1");					\
     70 	_spl_r;								\
     71 })
     72 
     73 /* spl0 requires checking for software interrupts */
     74 #define spl1()  _spl(PSL_S|PSL_IPL1)
     75 #define spl2()  _spl(PSL_S|PSL_IPL2)
     76 #define spl3()  _spl(PSL_S|PSL_IPL3)
     77 #define spl4()  _spl(PSL_S|PSL_IPL4)
     78 #define spl5()  _spl(PSL_S|PSL_IPL5)
     79 #define spl6()  _spl(PSL_S|PSL_IPL6)
     80 #define spl7()  _spl(PSL_S|PSL_IPL7)
     81 
     82 /* watch out for side effects */
     83 #define splx(s)         ((s) & PSL_IPL ? _spl(s) : spl0())
     84 
     85 /****************************************************************/
     86 
     87 #define splhigh()       spl7()
     88 #define splserial()     _splraise(PSL_S|PSL_IPL5)
     89 #define splsched()      _splraise(PSL_S|PSL_IPL3)
     90 #define splclock()      _splraise(PSL_S|PSL_IPL6)
     91 #define splstatclock()  splclock()
     92 #define splimp()        _splraise(PSL_S|PSL_IPL6)
     93 #define spltty()        _splraise(PSL_S|PSL_IPL3)
     94 #define splbio()        _splraise(PSL_S|PSL_IPL3)
     95 #define splnet()        _splraise(PSL_S|PSL_IPL3)
     96 #define splsoftnet()    _splraise(PSL_S|PSL_IPL2)
     97 #define splsoftclock()  spl1()
     98 
     99 #define spldma()        _splraise(PSL_S|PSL_IPL6)
    100 
    101 /****************************************************************/
    102 
    103 /*
    104  * simulated software interrupt register
    105  */
    106 extern volatile u_int8_t ssir;
    107 
    108 #define	SIR_NET		0x01
    109 #define	SIR_CLOCK	0x02
    110 #define	SIR_SERIAL	0x04
    111 #define SIR_DTMGR	0x08
    112 #define SIR_ADB		0x10
    113 
    114 #define	siron(mask)	\
    115 	__asm __volatile ( "orb %1,%0" : "=m" (ssir) : "i" (mask))
    116 #define	siroff(mask)	\
    117 	__asm __volatile ( "andb %1,%0" : "=m" (ssir) : "ir" (~(mask)));
    118 
    119 #define	setsoftnet()	siron(SIR_NET)
    120 #define	setsoftclock()	siron(SIR_CLOCK)
    121 #define	setsoftserial()	siron(SIR_SERIAL)
    122 #define	setsoftdtmgr()	siron(SIR_DTMGR)
    123 #define	setsoftadb()	siron(SIR_ADB)
    124 
    125 extern u_long allocate_sir __P((void (*)(void *),void *));
    126 extern void init_sir __P((void));
    127 
    128 /* locore.s */
    129 int	spl0 __P((void));
    130 #endif /* _KERNEL */
    131 
    132 #define INTR_SETMASK(x)  ((*(volatile u_long *)IIOV(NEXT_P_INTRMASK))=(x))
    133 #define INTR_ENABLE(x)   ((*(volatile u_long *)IIOV(NEXT_P_INTRMASK))|=NEXT_I_BIT(x))
    134 #define INTR_DISABLE(x)  ((*(volatile u_long *)IIOV(NEXT_P_INTRMASK))&=(~NEXT_I_BIT(x)))
    135 #define INTR_OCCURRED(x)  ((*(volatile u_long *)IIOV(NEXT_P_INTRSTAT))& NEXT_I_BIT(x))
    136 
    137 #endif /* _NEXT68K_INTR_H_ */
    138