psl.h revision 1.15
11.15Smatt/*	$NetBSD: psl.h,v 1.15 2008/01/06 01:37:54 matt 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.15Smatt#ifdef __HAVE_FAST_SOFTINTS
611.1Sreinoud#define _SPL_SOFTCLOCK	1
621.14Sad#define _SPL_SOFTBIO	2
631.14Sad#define _SPL_SOFTNET	3
641.14Sad#define _SPL_SOFTSERIAL	4
651.14Sad#define _SPL_VM		5
661.14Sad#define _SPL_SCHED	6
671.14Sad#define _SPL_HIGH	7
681.14Sad#define _SPL_LEVELS	8
691.15Smatt#else
701.15Smatt#define _SPL_SOFTCLOCK	_SPL_0
711.15Smatt#define _SPL_SOFTBIO	_SPL_0
721.15Smatt#define _SPL_SOFTNET	_SPL_0
731.15Smatt#define _SPL_SOFTSERIAL	_SPL_0
741.15Smatt#define _SPL_VM		1
751.15Smatt#define _SPL_SCHED	2
761.15Smatt#define _SPL_HIGH	3
771.15Smatt#define _SPL_LEVELS	4
781.15Smatt#endif
791.1Sreinoud
801.1Sreinoud#define spl0()		splx(_SPL_0)
811.15Smatt#ifdef __HAVE_FAST_SOFTINTS
821.14Sad#define splsoftclock()	raisespl(_SPL_SOFTCLOCK)
831.14Sad#define splsoftbio()	raisespl(_SPL_SOFTBIO)
841.1Sreinoud#define splsoftnet()	raisespl(_SPL_SOFTNET)
851.1Sreinoud#define splsoftserial()	raisespl(_SPL_SOFTSERIAL)
861.15Smatt#else
871.15Smatt#define splsoftclock()	spl0()
881.15Smatt#define splsoftbio()	spl0()
891.15Smatt#define splsoftnet()	spl0()
901.15Smatt#define splsoftserial()	spl0()
911.15Smatt#endif
921.6Sthorpej#define splvm()		raisespl(_SPL_VM)
931.14Sad#define splsched()	raisespl(_SPL_SCHED)
941.1Sreinoud#define splhigh()	raisespl(_SPL_HIGH)
951.1Sreinoud
961.1Sreinoud#ifdef _KERNEL
971.1Sreinoud#ifndef _LOCORE
981.15Smattint raisespl	(int);
991.15Smattint lowerspl	(int);
1001.15Smattint splx	(int);
1011.1Sreinoud
1021.15Smatt#ifdef __HAVE_FAST_SOFTINTS
1031.8Smattvoid _setsoftintr	(int si);
1041.15Smatt#endif
1051.1Sreinoud
1061.1Sreinoudextern int current_spl_level;
1071.1Sreinoud
1081.2Stoshiiextern u_int spl_masks[_SPL_LEVELS + 1];
1091.7Syamt
1101.10Sthorpejtypedef uint8_t ipl_t;
1111.7Syamttypedef struct {
1121.10Sthorpej	uint8_t _spl;
1131.7Syamt} ipl_cookie_t;
1141.7Syamt
1151.7Syamtint ipl_to_spl(ipl_t);
1161.7Syamt
1171.7Syamtstatic inline ipl_cookie_t
1181.7Syamtmakeiplcookie(ipl_t ipl)
1191.7Syamt{
1201.7Syamt
1211.10Sthorpej	return (ipl_cookie_t){._spl = (uint8_t)ipl_to_spl(ipl)};
1221.7Syamt}
1231.7Syamt
1241.7Syamtstatic inline int
1251.7Syamtsplraiseipl(ipl_cookie_t icookie)
1261.7Syamt{
1271.7Syamt
1281.7Syamt	return raisespl(icookie._spl);
1291.7Syamt}
1301.1Sreinoud#endif /* _LOCORE */
1311.1Sreinoud#endif /* _KERNEL */
1321.1Sreinoud
1331.4Sbjh21#endif /* _ARM_PSL_H_ */
1341.1Sreinoud/* End of psl.h */
135