psl.h revision 1.11
11.11Stoshii/*	$NetBSD: psl.h,v 1.11 2007/07/01 16:04:57 toshii Exp $	*/
21.1Sreinoud
31.1Sreinoud/*
41.1Sreinoud * Copyright (c) 1995 Mark Brinicombe.
51.1Sreinoud * All rights reserved.
61.1Sreinoud *
71.1Sreinoud * Redistribution and use in source and binary forms, with or without
81.1Sreinoud * modification, are permitted provided that the following conditions
91.1Sreinoud * are met:
101.1Sreinoud * 1. Redistributions of source code must retain the above copyright
111.1Sreinoud *    notice, this list of conditions and the following disclaimer.
121.1Sreinoud * 2. Redistributions in binary form must reproduce the above copyright
131.1Sreinoud *    notice, this list of conditions and the following disclaimer in the
141.1Sreinoud *    documentation and/or other materials provided with the distribution.
151.1Sreinoud * 3. All advertising materials mentioning features or use of this software
161.1Sreinoud *    must display the following acknowledgement:
171.1Sreinoud *	This product includes software developed by Mark Brinicombe
181.1Sreinoud *	for the NetBSD Project.
191.1Sreinoud * 4. The name of the company nor the name of the author may be used to
201.1Sreinoud *    endorse or promote products derived from this software without specific
211.1Sreinoud *    prior written permission.
221.1Sreinoud *
231.1Sreinoud * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
241.1Sreinoud * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
251.1Sreinoud * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
261.1Sreinoud * IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
271.1Sreinoud * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
281.1Sreinoud * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
291.1Sreinoud * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
301.1Sreinoud * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
311.1Sreinoud * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
321.1Sreinoud * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
331.1Sreinoud * SUCH DAMAGE.
341.1Sreinoud *
351.1Sreinoud * RiscBSD kernel project
361.1Sreinoud *
371.1Sreinoud * psl.h
381.1Sreinoud *
391.1Sreinoud * spl prototypes.
401.1Sreinoud * Eventually this will become a set of defines.
411.1Sreinoud *
421.1Sreinoud * Created      : 21/07/95
431.1Sreinoud */
441.1Sreinoud
451.4Sbjh21#ifndef _ARM_PSL_H_
461.4Sbjh21#define _ARM_PSL_H_
471.1Sreinoud#include <machine/intr.h>
481.11Stoshii#if (! defined(_LOCORE)) && (! defined(hpcarm))
491.8Smatt#include <arm/softintr.h>
501.8Smatt#endif
511.1Sreinoud
521.1Sreinoud/*
531.1Sreinoud * These are the different SPL states
541.1Sreinoud *
551.1Sreinoud * Each state has an interrupt mask associated with it which
561.1Sreinoud * indicate which interrupts are allowed.
571.1Sreinoud */
581.1Sreinoud
591.1Sreinoud#define _SPL_0		0
601.8Smatt#define _SPL_SOFT	1
611.1Sreinoud#define _SPL_SOFTCLOCK	1
621.1Sreinoud#define _SPL_SOFTNET	2
631.1Sreinoud#define _SPL_BIO	3
641.1Sreinoud#define _SPL_NET	4
651.1Sreinoud#define _SPL_SOFTSERIAL	5
661.1Sreinoud#define _SPL_TTY	6
671.6Sthorpej#define _SPL_VM		7
681.1Sreinoud#define _SPL_AUDIO	8
691.1Sreinoud#define _SPL_CLOCK	9
701.5Srearnsha#define _SPL_STATCLOCK	10
711.5Srearnsha#define _SPL_HIGH	11
721.5Srearnsha#define _SPL_SERIAL	12
731.5Srearnsha#define _SPL_LEVELS	13
741.1Sreinoud
751.1Sreinoud#define spl0()		splx(_SPL_0)
761.8Smatt#define splsoft()	raisespl(_SPL_SOFT)
771.1Sreinoud#define splsoftnet()	raisespl(_SPL_SOFTNET)
781.1Sreinoud#define spllowersoftclock() lowerspl(_SPL_SOFTCLOCK)
791.1Sreinoud#define splsoftclock()	raisespl(_SPL_SOFTCLOCK)
801.1Sreinoud#define splbio()	raisespl(_SPL_BIO)
811.1Sreinoud#define splnet()	raisespl(_SPL_NET)
821.1Sreinoud#define splsoftserial()	raisespl(_SPL_SOFTSERIAL)
831.1Sreinoud#define spltty()	raisespl(_SPL_TTY)
841.1Sreinoud#define spllpt()	spltty()
851.6Sthorpej#define splvm()		raisespl(_SPL_VM)
861.1Sreinoud#define splaudio()	raisespl(_SPL_AUDIO)
871.1Sreinoud#define splclock()	raisespl(_SPL_CLOCK)
881.5Srearnsha#define splstatclock()	raisespl(_SPL_STATCLOCK)
891.1Sreinoud#define splserial()	raisespl(_SPL_SERIAL)
901.1Sreinoud#define splhigh()	raisespl(_SPL_HIGH)
911.1Sreinoud
921.1Sreinoud#define	splsched()	splhigh()
931.1Sreinoud#define	spllock()	splhigh()
941.1Sreinoud
951.1Sreinoud#ifdef _KERNEL
961.1Sreinoud#ifndef _LOCORE
971.1Sreinoudint raisespl	__P((int));
981.1Sreinoudint lowerspl	__P((int));
991.1Sreinoudint splx	__P((int));
1001.1Sreinoud
1011.8Smattvoid _setsoftintr	(int si);
1021.1Sreinoud
1031.1Sreinoudextern int current_spl_level;
1041.1Sreinoud
1051.2Stoshiiextern u_int spl_masks[_SPL_LEVELS + 1];
1061.7Syamt
1071.10Sthorpejtypedef uint8_t ipl_t;
1081.7Syamttypedef struct {
1091.10Sthorpej	uint8_t _spl;
1101.7Syamt} ipl_cookie_t;
1111.7Syamt
1121.7Syamtint ipl_to_spl(ipl_t);
1131.7Syamt
1141.7Syamtstatic inline ipl_cookie_t
1151.7Syamtmakeiplcookie(ipl_t ipl)
1161.7Syamt{
1171.7Syamt
1181.10Sthorpej	return (ipl_cookie_t){._spl = (uint8_t)ipl_to_spl(ipl)};
1191.7Syamt}
1201.7Syamt
1211.7Syamtstatic inline int
1221.7Syamtsplraiseipl(ipl_cookie_t icookie)
1231.7Syamt{
1241.7Syamt
1251.7Syamt	return raisespl(icookie._spl);
1261.7Syamt}
1271.1Sreinoud#endif /* _LOCORE */
1281.1Sreinoud#endif /* _KERNEL */
1291.1Sreinoud
1301.4Sbjh21#endif /* _ARM_PSL_H_ */
1311.1Sreinoud/* End of psl.h */
132