Home | History | Annotate | Line # | Download | only in include
intr.h revision 1.11.40.2
      1  1.11.40.2     yamt /*	$NetBSD: intr.h,v 1.11.40.2 2007/02/26 09:06:09 yamt Exp $	*/
      2        1.1      leo 
      3        1.1      leo /*-
      4        1.1      leo  * Copyright (c) 1997 The NetBSD Foundation, Inc.
      5        1.1      leo  * All rights reserved.
      6        1.1      leo  *
      7        1.1      leo  * Redistribution and use in source and binary forms, with or without
      8        1.1      leo  * modification, are permitted provided that the following conditions
      9        1.1      leo  * are met:
     10        1.1      leo  * 1. Redistributions of source code must retain the above copyright
     11        1.1      leo  *    notice, this list of conditions and the following disclaimer.
     12        1.1      leo  * 2. Redistributions in binary form must reproduce the above copyright
     13        1.1      leo  *    notice, this list of conditions and the following disclaimer in the
     14        1.1      leo  *    documentation and/or other materials provided with the distribution.
     15        1.1      leo  * 3. All advertising materials mentioning features or use of this software
     16        1.1      leo  *    must display the following acknowledgement:
     17        1.1      leo  *        This product includes software developed by the NetBSD
     18        1.1      leo  *        Foundation, Inc. and its contributors.
     19        1.1      leo  * 4. Neither the name of The NetBSD Foundation nor the names of its
     20        1.1      leo  *    contributors may be used to endorse or promote products derived
     21        1.1      leo  *    from this software without specific prior written permission.
     22        1.1      leo  *
     23        1.1      leo  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     24        1.1      leo  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     25        1.1      leo  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     26        1.5      jtc  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     27        1.5      jtc  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     28        1.1      leo  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     29        1.1      leo  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     30        1.1      leo  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     31        1.1      leo  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     32        1.1      leo  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     33        1.1      leo  * POSSIBILITY OF SUCH DAMAGE.
     34        1.1      leo  */
     35        1.1      leo 
     36        1.1      leo #ifndef _ATARI_INTR_H_
     37        1.1      leo #define _ATARI_INTR_H_
     38        1.1      leo 
     39        1.6      leo #define	IPL_NONE	0		    /* disable no interrupts	    */
     40        1.6      leo #define	IPL_BIO		(PSL_S|PSL_IPL3)    /* disable block I/O interrupts */
     41        1.6      leo #define	IPL_NET		(PSL_S|PSL_IPL3)    /* disable network interrupts   */
     42        1.6      leo #define	IPL_TTY		(PSL_S|PSL_IPL4)    /* disable terminal interrupts  */
     43  1.11.40.1     yamt #define	IPL_LPT		IPL_TTY
     44  1.11.40.1     yamt #define	IPL_VM		(PSL_S|PSL_IPL4)
     45        1.6      leo #define	IPL_CLOCK	(PSL_S|PSL_IPL6)    /* disable clock interrupts	    */
     46  1.11.40.1     yamt #define	IPL_STATCLOCK	IPL_CLOCK
     47        1.6      leo #define	IPL_HIGH	(PSL_S|PSL_IPL7)    /* disable all interrupts	    */
     48  1.11.40.1     yamt #define	IPL_SCHED	IPL_HIGH
     49  1.11.40.1     yamt #define	IPL_LOCK	IPL_HIGH
     50        1.1      leo 
     51        1.1      leo #define	IST_UNUSABLE	-1	/* interrupt cannot be used	*/
     52        1.1      leo #define	IST_NONE	0	/* none (dummy)			*/
     53        1.1      leo #define	IST_PULSE	1	/* pulsed			*/
     54        1.1      leo #define	IST_EDGE	2	/* edge-triggered		*/
     55        1.1      leo #define	IST_LEVEL	3	/* level-triggered		*/
     56        1.1      leo 
     57        1.1      leo /*
     58        1.1      leo  * spl functions; all but spl0 are done in-line
     59        1.1      leo  */
     60        1.1      leo #include <machine/psl.h>
     61        1.1      leo 
     62        1.8  thorpej /* spl0 requires checking for software interrupts */
     63        1.8  thorpej 
     64        1.8  thorpej #define splnone()		spl0()
     65        1.1      leo 
     66        1.8  thorpej #define splsoftclock()		splraise1()
     67        1.8  thorpej #define splsoftnet()		splraise1()
     68        1.8  thorpej 
     69        1.8  thorpej #define splbio()		_splraise(PSL_S|PSL_IPL3)
     70        1.8  thorpej #define splnet()		_splraise(PSL_S|PSL_IPL3)
     71        1.8  thorpej #define spltty()		_splraise(PSL_S|PSL_IPL4)
     72       1.10  thorpej #define splvm()			_splraise(PSL_S|PSL_IPL4)
     73        1.8  thorpej 
     74        1.8  thorpej #define spllpt()		spltty()
     75        1.8  thorpej 
     76        1.8  thorpej #define splclock()		splraise6()
     77        1.8  thorpej #define splstatclock()		splraise6()
     78        1.8  thorpej #define splhigh()		spl7()
     79        1.8  thorpej #define splsched()		spl7()
     80        1.9  thorpej #define spllock()		spl7()
     81        1.1      leo 
     82        1.8  thorpej #define splx(s)			((s) & PSL_IPL ? _spl(s) : spl0())
     83        1.1      leo 
     84        1.1      leo #ifdef _KERNEL
     85        1.1      leo int spl0 __P((void));
     86  1.11.40.1     yamt 
     87  1.11.40.1     yamt typedef int ipl_t;
     88  1.11.40.1     yamt typedef struct {
     89  1.11.40.1     yamt 	int _ipl;
     90  1.11.40.1     yamt } ipl_cookie_t;
     91  1.11.40.1     yamt 
     92  1.11.40.1     yamt static inline ipl_cookie_t
     93  1.11.40.1     yamt makeiplcookie(ipl_t ipl)
     94  1.11.40.1     yamt {
     95  1.11.40.1     yamt 
     96  1.11.40.1     yamt 	return (ipl_cookie_t){._ipl = ipl};
     97  1.11.40.1     yamt }
     98  1.11.40.1     yamt 
     99  1.11.40.1     yamt static inline int
    100  1.11.40.1     yamt splraiseipl(ipl_cookie_t icookie)
    101  1.11.40.1     yamt {
    102  1.11.40.1     yamt 
    103  1.11.40.1     yamt 	return _splraise(icookie._ipl);
    104  1.11.40.1     yamt }
    105        1.1      leo #endif /* _KERNEL */
    106        1.1      leo 
    107        1.1      leo #endif /* _ATARI_INTR_H_ */
    108