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