intr.h revision 1.6 1 1.6 uch /* $NetBSD: intr.h,v 1.6 2002/03/24 18:21:18 uch Exp $ */
2 1.6 uch
3 1.6 uch /*-
4 1.6 uch * Copyright (c) 2002 The NetBSD Foundation, Inc.
5 1.6 uch * All rights reserved.
6 1.6 uch *
7 1.6 uch * Redistribution and use in source and binary forms, with or without
8 1.6 uch * modification, are permitted provided that the following conditions
9 1.6 uch * are met:
10 1.6 uch * 1. Redistributions of source code must retain the above copyright
11 1.6 uch * notice, this list of conditions and the following disclaimer.
12 1.6 uch * 2. Redistributions in binary form must reproduce the above copyright
13 1.6 uch * notice, this list of conditions and the following disclaimer in the
14 1.6 uch * documentation and/or other materials provided with the distribution.
15 1.6 uch * 3. All advertising materials mentioning features or use of this software
16 1.6 uch * must display the following acknowledgement:
17 1.6 uch * This product includes software developed by the NetBSD
18 1.6 uch * Foundation, Inc. and its contributors.
19 1.6 uch * 4. Neither the name of The NetBSD Foundation nor the names of its
20 1.6 uch * contributors may be used to endorse or promote products derived
21 1.6 uch * from this software without specific prior written permission.
22 1.6 uch *
23 1.6 uch * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
24 1.6 uch * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
25 1.6 uch * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
26 1.6 uch * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
27 1.6 uch * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
28 1.6 uch * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
29 1.6 uch * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30 1.6 uch * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31 1.6 uch * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32 1.6 uch * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33 1.6 uch * POSSIBILITY OF SUCH DAMAGE.
34 1.6 uch */
35 1.6 uch
36 1.1 itojun #ifndef _EVBSH3_INTR_H_
37 1.1 itojun #define _EVBSH3_INTR_H_
38 1.3 msaitoh
39 1.6 uch #include <sh3/intr.h>
40 1.1 itojun
41 1.6 uch /* Number of interrupt source */
42 1.6 uch #define _INTR_N 7 /* TMU0, TMU1, TMU2, (SCIF or SCI) * 4 */
43 1.6 uch
44 1.6 uch /* Interrupt priority levels */
45 1.6 uch #define IPL_BIO 9 /* block I/O */
46 1.6 uch #define IPL_NET 11 /* network */
47 1.6 uch #define IPL_TTY 12 /* terminal */
48 1.6 uch #define IPL_SERIAL 12 /* serial */
49 1.6 uch #define IPL_CLOCK 14 /* clock */
50 1.6 uch #define IPL_HIGH 15 /* everything */
51 1.6 uch
52 1.6 uch #define splsoftclock() _cpu_intr_raise(IPL_SOFTCLOCK << 4)
53 1.6 uch #define splsoftnet() _cpu_intr_raise(IPL_SOFTNET << 4)
54 1.6 uch #define splsoftserial() _cpu_intr_raise(IPL_SOFTSERIAL << 4)
55 1.6 uch #define splbio() _cpu_intr_raise(IPL_BIO << 4)
56 1.6 uch #define splnet() _cpu_intr_raise(IPL_NET << 4)
57 1.6 uch #define spltty() _cpu_intr_raise(IPL_TTY << 4)
58 1.6 uch #define splvm() spltty()
59 1.6 uch #define splserial() _cpu_intr_raise(IPL_SERIAL << 4)
60 1.6 uch #define splclock() _cpu_intr_raise(IPL_CLOCK << 4)
61 1.6 uch #define splstatclock() splclock()
62 1.6 uch #define splsched() splclock()
63 1.6 uch #define splhigh() _cpu_intr_raise(IPL_HIGH << 4)
64 1.6 uch #define spllock() splhigh()
65 1.1 itojun
66 1.6 uch #define spl0() _cpu_intr_resume(0)
67 1.6 uch #define splx(x) _cpu_intr_resume(x)
68 1.2 msaitoh
69 1.6 uch #define spllowersoftclock() _cpu_intr_resume(IPL_SOFTCLOCK << 4)
70 1.1 itojun
71 1.6 uch #endif /* !_EVBSH3_INTR_H_ */
72