intr.h revision 1.12 1 1.12 yamt /* $NetBSD: intr.h,v 1.12 2006/12/21 15:55:22 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.12 yamt #define IPL_LPT IPL_TTY
44 1.12 yamt #define IPL_VM (PSL_S|PSL_IPL4)
45 1.6 leo #define IPL_CLOCK (PSL_S|PSL_IPL6) /* disable clock interrupts */
46 1.12 yamt #define IPL_STATCLOCK IPL_CLOCK
47 1.6 leo #define IPL_HIGH (PSL_S|PSL_IPL7) /* disable all interrupts */
48 1.12 yamt #define IPL_SCHED IPL_HIGH
49 1.12 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.8 thorpej #define spllowersoftclock() spl1()
66 1.1 leo
67 1.8 thorpej #define splsoftclock() splraise1()
68 1.8 thorpej #define splsoftnet() splraise1()
69 1.8 thorpej
70 1.8 thorpej #define splbio() _splraise(PSL_S|PSL_IPL3)
71 1.8 thorpej #define splnet() _splraise(PSL_S|PSL_IPL3)
72 1.8 thorpej #define spltty() _splraise(PSL_S|PSL_IPL4)
73 1.10 thorpej #define splvm() _splraise(PSL_S|PSL_IPL4)
74 1.8 thorpej
75 1.8 thorpej #define spllpt() spltty()
76 1.8 thorpej
77 1.8 thorpej #define splclock() splraise6()
78 1.8 thorpej #define splstatclock() splraise6()
79 1.8 thorpej #define splhigh() spl7()
80 1.8 thorpej #define splsched() spl7()
81 1.9 thorpej #define spllock() spl7()
82 1.1 leo
83 1.8 thorpej #define splx(s) ((s) & PSL_IPL ? _spl(s) : spl0())
84 1.1 leo
85 1.1 leo #ifdef _KERNEL
86 1.1 leo int spl0 __P((void));
87 1.12 yamt
88 1.12 yamt typedef int ipl_t;
89 1.12 yamt typedef struct {
90 1.12 yamt int _ipl;
91 1.12 yamt } ipl_cookie_t;
92 1.12 yamt
93 1.12 yamt static inline ipl_cookie_t
94 1.12 yamt makeiplcookie(ipl_t ipl)
95 1.12 yamt {
96 1.12 yamt
97 1.12 yamt return (ipl_cookie_t){._ipl = ipl};
98 1.12 yamt }
99 1.12 yamt
100 1.12 yamt static inline int
101 1.12 yamt splraiseipl(ipl_cookie_t icookie)
102 1.12 yamt {
103 1.12 yamt
104 1.12 yamt return _splraise(icookie._ipl);
105 1.12 yamt }
106 1.1 leo #endif /* _KERNEL */
107 1.1 leo
108 1.1 leo #endif /* _ATARI_INTR_H_ */
109