psl.h revision 1.14
11.14Sad/*	$NetBSD: psl.h,v 1.14 2007/12/03 15:33:19 ad 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.1Sreinoud#define _SPL_SOFTCLOCK	1
611.14Sad#define _SPL_SOFTBIO	2
621.14Sad#define _SPL_SOFTNET	3
631.14Sad#define _SPL_SOFTSERIAL	4
641.14Sad#define _SPL_VM		5
651.14Sad#define _SPL_SCHED	6
661.14Sad#define _SPL_HIGH	7
671.14Sad#define _SPL_LEVELS	8
681.1Sreinoud
691.1Sreinoud#define spl0()		splx(_SPL_0)
701.14Sad#define splsoftclock()	raisespl(_SPL_SOFTCLOCK)
711.14Sad#define splsoftbio()	raisespl(_SPL_SOFTBIO)
721.1Sreinoud#define splsoftnet()	raisespl(_SPL_SOFTNET)
731.1Sreinoud#define splsoftserial()	raisespl(_SPL_SOFTSERIAL)
741.6Sthorpej#define splvm()		raisespl(_SPL_VM)
751.14Sad#define splsched()	raisespl(_SPL_SCHED)
761.1Sreinoud#define splhigh()	raisespl(_SPL_HIGH)
771.1Sreinoud
781.1Sreinoud#ifdef _KERNEL
791.1Sreinoud#ifndef _LOCORE
801.1Sreinoudint raisespl	__P((int));
811.1Sreinoudint lowerspl	__P((int));
821.1Sreinoudint splx	__P((int));
831.1Sreinoud
841.8Smattvoid _setsoftintr	(int si);
851.1Sreinoud
861.1Sreinoudextern int current_spl_level;
871.1Sreinoud
881.2Stoshiiextern u_int spl_masks[_SPL_LEVELS + 1];
891.7Syamt
901.10Sthorpejtypedef uint8_t ipl_t;
911.7Syamttypedef struct {
921.10Sthorpej	uint8_t _spl;
931.7Syamt} ipl_cookie_t;
941.7Syamt
951.7Syamtint ipl_to_spl(ipl_t);
961.7Syamt
971.7Syamtstatic inline ipl_cookie_t
981.7Syamtmakeiplcookie(ipl_t ipl)
991.7Syamt{
1001.7Syamt
1011.10Sthorpej	return (ipl_cookie_t){._spl = (uint8_t)ipl_to_spl(ipl)};
1021.7Syamt}
1031.7Syamt
1041.7Syamtstatic inline int
1051.7Syamtsplraiseipl(ipl_cookie_t icookie)
1061.7Syamt{
1071.7Syamt
1081.7Syamt	return raisespl(icookie._spl);
1091.7Syamt}
1101.1Sreinoud#endif /* _LOCORE */
1111.1Sreinoud#endif /* _KERNEL */
1121.1Sreinoud
1131.4Sbjh21#endif /* _ARM_PSL_H_ */
1141.1Sreinoud/* End of psl.h */
115