]> CyberLeo.Net >> Repos - FreeBSD/releng/7.2.git/blob - sys/powerpc/include/intr.h
Create releng/7.2 from stable/7 in preparation for 7.2-RELEASE.
[FreeBSD/releng/7.2.git] / sys / powerpc / include / intr.h
1 /*-
2  * Copyright (c) 1998 The NetBSD Foundation, Inc.
3  * All rights reserved.
4  *
5  * This code is derived from software contributed to The NetBSD Foundation
6  * by Charles M. Hannum.
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 the NetBSD
19  *        Foundation, Inc. and its contributors.
20  * 4. Neither the name of The NetBSD Foundation nor the names of its
21  *    contributors may be used to endorse or promote products derived
22  *    from this software without specific prior written permission.
23  *
24  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
25  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
26  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
27  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
28  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34  * POSSIBILITY OF SUCH DAMAGE.
35  *
36  *      $NetBSD: intr.h,v 1.6 2000/02/11 13:15:44 tsubai Exp $
37  * $FreeBSD$
38  */
39
40 #ifndef _MACPPC_INTR_H_
41 #define _MACPPC_INTR_H_
42
43 /* Interrupt priority `levels'. */
44 #define IPL_NONE        9       /* nothing */
45 #define IPL_SOFTCLOCK   8       /* timeouts */
46 #define IPL_SOFTNET     7       /* protocol stacks */
47 #define IPL_BIO         6       /* block I/O */
48 #define IPL_NET         5       /* network */
49 #define IPL_SOFTSERIAL  4       /* serial */
50 #define IPL_TTY         3       /* terminal */
51 #define IPL_IMP         3       /* memory allocation */
52 #define IPL_AUDIO       2       /* audio */
53 #define IPL_CLOCK       1       /* clock */
54 #define IPL_HIGH        1       /* everything */
55 #define IPL_SERIAL      0       /* serial */
56 #define NIPL            10
57
58 /* Interrupt sharing types. */
59 #define IST_NONE        0       /* none */
60 #define IST_PULSE       1       /* pulsed */
61 #define IST_EDGE        2       /* edge-triggered */
62 #define IST_LEVEL       3       /* level-triggered */
63
64 #ifndef LOCORE
65
66 #if 0
67 /*
68  * Interrupt handler chains.  intr_establish() inserts a handler into
69  * the list.  The handler is called with its (single) argument.
70  */
71 struct intrhand {
72         int     (*ih_fun)(void *);
73         void    *ih_arg;
74         u_long  ih_count;
75         struct  intrhand *ih_next;
76         int     ih_level;
77         int     ih_irq;
78 };
79 #endif
80
81 void    setsoftclock(void);
82 void    clearsoftclock(void);
83 void    setsoftnet(void);
84 void    clearsoftnet(void);
85
86 void    do_pending_int(void);
87
88 static __inline void softintr(int);
89
90 extern u_int cpl, ipending, tickspending;
91 extern int imask[];
92
93 /* Following code should be implemented with lwarx/stwcx to avoid
94  * the disable/enable. i need to read the manual once more.... */
95 static __inline void
96 softintr(int ipl)
97 {
98         unsigned int    msrsave;
99
100         msrsave = mfmsr();
101         mtmsr(msrsave & ~PSL_EE);
102
103         ipending |= 1 << ipl;
104
105         mtmsr(msrsave);
106 }
107
108 #define ICU_LEN         64
109
110 /* Soft interrupt masks. */
111 #define SIR_CLOCK       28
112 #define SIR_NET         29
113 #define SIR_SERIAL      30
114 #define SPL_CLOCK       31
115
116 #if 0
117
118 /*
119  * Hardware interrupt masks
120  */
121
122 #define splbio()        splraise(imask[IPL_BIO])
123 #define splnet()        splraise(imask[IPL_NET])
124 #define spltty()        splraise(imask[IPL_TTY])
125 #define splaudio()      splraise(imask[IPL_AUDIO])
126 #define splclock()      splraise(imask[IPL_CLOCK])
127 #define splstatclock()  splclock()
128 #define splserial()     splraise(imask[IPL_SERIAL])
129
130 #define spllpt()        spltty()
131
132 /*
133  * Software interrupt masks
134  *
135  * NOTE: splsoftclock() is used by hardclock() to lower the priority from
136  * clock to softclock before it calls softclock().
137  */
138 #define spllowersoftclock() spllower(imask[IPL_SOFTCLOCK])
139 #define splsoftclock()  splraise(imask[IPL_SOFTCLOCK])
140 #define splsoftnet()    splraise(imask[IPL_SOFTNET])
141 #define splsoftserial() splraise(imask[IPL_SOFTSERIAL])
142
143 /*
144  * Miscellaneous
145  */
146 #define splimp()        splraise(imask[IPL_IMP])
147 #define splhigh()       splraise(imask[IPL_HIGH])
148 #define spl0()          spllower(0)
149
150 #endif /* 0 */
151
152 #define setsoftclock()  softintr(SIR_CLOCK)
153 #define setsoftnet()    softintr(SIR_NET)
154 #define setsoftserial() softintr(SIR_SERIAL)
155
156 #define CNT_IRQ0        0
157 #define CNT_CLOCK       64
158 #define CNT_SOFTCLOCK   65
159 #define CNT_SOFTNET     66
160 #define CNT_SOFTSERIAL  67
161
162 #endif /* !LOCORE */
163
164 #endif /* !_MACPPC_INTR_H_ */