intr.h revision 1.11
11.11Syamt/*	$NetBSD: intr.h,v 1.11 2006/12/21 15:55:25 yamt Exp $	*/
21.1Sminoura
31.5Sminoura/*-
41.5Sminoura * Copyright (c) 1998 The NetBSD Foundation, Inc.
51.1Sminoura * All rights reserved.
61.1Sminoura *
71.1Sminoura * This code is derived from software contributed to The NetBSD Foundation
81.1Sminoura * by Minoura Makoto and Jason R. Thorpe.
91.1Sminoura *
101.1Sminoura * Redistribution and use in source and binary forms, with or without
111.1Sminoura * modification, are permitted provided that the following conditions
121.1Sminoura * are met:
131.1Sminoura * 1. Redistributions of source code must retain the above copyright
141.1Sminoura *    notice, this list of conditions and the following disclaimer.
151.1Sminoura * 2. Redistributions in binary form must reproduce the above copyright
161.1Sminoura *    notice, this list of conditions and the following disclaimer in the
171.1Sminoura *    documentation and/or other materials provided with the distribution.
181.1Sminoura * 3. All advertising materials mentioning features or use of this software
191.1Sminoura *    must display the following acknowledgement:
201.5Sminoura *        This product includes software developed by the NetBSD
211.5Sminoura *        Foundation, Inc. and its contributors.
221.5Sminoura * 4. Neither the name of The NetBSD Foundation nor the names of its
231.5Sminoura *    contributors may be used to endorse or promote products derived
241.5Sminoura *    from this software without specific prior written permission.
251.1Sminoura *
261.5Sminoura * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
271.5Sminoura * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
281.5Sminoura * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
291.5Sminoura * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
301.5Sminoura * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
311.5Sminoura * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
321.5Sminoura * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
331.5Sminoura * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
341.5Sminoura * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
351.5Sminoura * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
361.5Sminoura * POSSIBILITY OF SUCH DAMAGE.
371.1Sminoura */
381.1Sminoura
391.1Sminoura#ifndef _X68K_INTR_H_
401.1Sminoura#define	_X68K_INTR_H_
411.1Sminoura
421.1Sminoura#include <machine/psl.h>
431.1Sminoura
441.4Sminoura#if defined(_KERNEL) && !defined(_LOCORE)
451.4Sminoura
461.1Sminoura/* spl0 requires checking for software interrupts */
471.9Schsvoid	spl0(void);
481.1Sminoura
491.10Syamt#define	splnone()	spl0()
501.10Syamt#define	spllowersoftclock() spl1()	/* disallow softclock */
511.10Syamt#define	splzs()		splraise5()	/* disallow serial interrupts */
521.1Sminoura
531.1Sminoura/* watch out for side effects */
541.1Sminoura#define splx(s)         ((s) & PSL_IPL ? _spl(s) : spl0())
551.1Sminoura
561.10Syamt#define	IPL_NONE	0
571.10Syamt#define	IPL_SOFTCLOCK	(PSL_S|PSL_IPL1)
581.10Syamt#define	IPL_SOFTNET	(PSL_S|PSL_IPL1)
591.10Syamt#define	IPL_BIO		(PSL_S|PSL_IPL3)
601.10Syamt#define	IPL_NET		(PSL_S|PSL_IPL4)
611.10Syamt#define	IPL_TTY		(PSL_S|PSL_IPL4)
621.10Syamt#define	IPL_VM		(PSL_S|PSL_IPL4)
631.10Syamt#define	IPL_CLOCK	(PSL_S|PSL_IPL6)
641.10Syamt#define	IPL_STATCLOCK	(PSL_S|PSL_IPL6)
651.10Syamt#define	IPL_SCHED	(PSL_S|PSL_IPL7)
661.10Syamt#define	IPL_HIGH	(PSL_S|PSL_IPL7)
671.10Syamt#define	IPL_LOCK	(PSL_S|PSL_IPL7)
681.10Syamt
691.11Syamttypedef int ipl_t;
701.11Syamttypedef struct {
711.11Syamt	ipl_t _ipl;
721.11Syamt} ipl_cookie_t;
731.11Syamt
741.11Syamtstatic inline ipl_cookie_t
751.11Syamtmakeiplcookie(ipl_t ipl)
761.11Syamt{
771.11Syamt
781.11Syamt	return (ipl_cookie_t){._ipl = ipl};
791.11Syamt}
801.11Syamt
811.11Syamtstatic inline int
821.11Syamtsplraiseipl(ipl_cookie_t icookie)
831.11Syamt{
841.11Syamt
851.11Syamt	return _splraise(icookie._ipl);
861.11Syamt}
871.10Syamt
881.10Syamt#include <sys/spl.h>
891.10Syamt
901.1Sminoura/*
911.1Sminoura * simulated software interrupt register
921.1Sminoura */
931.1Sminouraextern unsigned char ssir;
941.1Sminoura
951.1Sminoura#define SIR_NET		0x1
961.1Sminoura#define SIR_CLOCK	0x2
971.1Sminoura#define SIR_SERIAL	0x4
981.1Sminoura#define SIR_KBD		0x8
991.1Sminoura
1001.1Sminoura#define siroff(x)	ssir &= ~(x)
1011.1Sminoura#define setsoftnet()	ssir |= SIR_NET
1021.1Sminoura#define setsoftclock()	ssir |= SIR_CLOCK
1031.1Sminoura#define setsoftserial() ssir |= SIR_SERIAL
1041.1Sminoura#define setsoftkbd()    ssir |= SIR_KBD
1051.1Sminoura
1061.4Sminoura#endif /* _KERNEL && ! _LOCORE */
1071.1Sminoura#endif
108