📄 intr.h
字号:
/* $OpenBSD: intr.h,v 1.3 1998/10/09 02:06:40 rahnds Exp $ *//* * Copyright (c) 1997, 1998, 1999, 2000 * Per Fogelstrom, Opsycon AB and RTMX Inc, USA. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed under OpenBSD by * Per Fogelstrom, Opsycon AB, Sweden for RTMX Inc, North Carolina USA. * 4. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * */#ifndef _MACHINE_INTR_H_#define _MACHINE_INTR_H_#include <psl.h>#define IPL_BIO 0#define IPL_NET 1#define IPL_TTY 2#define IPL_IMP 3#define IPL_CLOCK 4#define IPL_NONE 5#define IPL_HIGH 6#ifndef PMON#define IST_NONE 0#define IST_PULSE 1#define IST_EDGE 2#define IST_LEVEL 3#ifndef _LOCOREvoid setsoftclock __P((void));void clearsoftclock __P((void));int splsoftclock __P((void));void setsoftnet __P((void));void clearsoftnet __P((void));int splsoftnet __P((void));void do_pending_int __P((void));volatile int cpl, ipending, astpending, tickspending;int imask[7];/* * Reorder protection in the following inline functions is * achived with the "eieio" instruction which the assembler * seems to detect and then doen't move instructions past.... */static __inline intsplraise(newcpl) int newcpl;{ int oldcpl; __asm__ volatile("sync; eieio\n"); /* don't reorder.... */ oldcpl = cpl; cpl = oldcpl | newcpl; __asm__ volatile("sync; eieio\n"); /* reorder protect */ return(oldcpl);}static __inline voidsplx(newcpl) int newcpl;{ __asm__ volatile("sync; eieio\n"); /* reorder protect */ cpl = newcpl; if(ipending & ~newcpl) do_pending_int(); __asm__ volatile("sync; eieio\n"); /* reorder protect */}static __inline intspllower(newcpl) int newcpl;{ int oldcpl; __asm__ volatile("sync; eieio\n"); /* reorder protect */ oldcpl = cpl; cpl = newcpl; if(ipending & ~newcpl) do_pending_int(); __asm__ volatile("sync; eieio\n"); /* reorder protect */ return(oldcpl);}/* Following code should be implemented with lwarx/stwcx to avoid * the disable/enable. i need to read the manual once more.... */static __inline voidset_sint(pending) int pending;{ int msrsave; __asm__ ("mfmsr %0" : "=r"(msrsave)); __asm__ volatile ("mtmsr %0" :: "r"(msrsave & ~PSL_EE)); ipending |= pending; __asm__ volatile ("mtmsr %0" :: "r"(msrsave));}#endif /* _LOCORE */#define SINT_CLOCK 0x10000000#define SINT_NET 0x20000000#define SINT_TTY 0x40000000#define SPL_CLOCK 0x80000000#define SINT_MASK (SINT_CLOCK|SINT_NET|SINT_TTY)#define splbio() splraise(imask[IPL_BIO])#define splnet() splraise(imask[IPL_NET])#define spltty() splraise(imask[IPL_TTY])#define splclock() splraise(SPL_CLOCK|SINT_MASK)#define splimp() splraise(imask[IPL_IMP])#define splstatclock() splhigh()#define splsoftclock() spllower(SINT_CLOCK)#define splsoftnet() splraise(SINT_NET)#define splsofttty() splraise(SINT_TTY)#define setsoftclock() set_sint(SINT_CLOCK);#define setsoftnet() set_sint(SINT_NET);#define setsofttty() set_sint(SINT_TTY);#define splhigh() splraise(0xffffffff)#define spl0() spllower(0)#else /*PMON*/#ifndef _LOCOREint splbio __P((void));int splnet __P((void));int splclock __P((void));int spltty __P((void));int splimp __P((void));int splsoftclock __P((void));int splstatclock __P((void));int spl0 __P((void));void splx __P((int));int splhigh __P((void));void setsoftclock __P((void));void clearsoftclock __P((void));int splsoftclock __P((void));void setsoftnet __P((void));void clearsoftnet __P((void));int splsoftnet __P((void));#endif /* _LOCORE */#endif /* PMON *//* * Interrupt and trap vectors. */#define EX_BEGIN 0x0000 /* 0, First vector */#define EX_RESV0 0x0000 /* 0, reserved */#define EX_RESET 0x0100 /* 1, reset */#define EX_MCHEK 0x0200 /* 2, machine check */#define EX_DSI 0x0300 /* 3, data exception */#define EX_ISI 0x0400 /* 4, instruction exception */#define EX_EINT 0x0500 /* 5, external interrupt */#define EX_ALIGN 0x0600 /* 6, memory access alignment */#define EX_PRGM 0x0700 /* 7, program exception */#define EX_NOFP 0x0800 /* 8, FP unavailable */#define EX_DECR 0x0900 /* 9, Decrementer */#define EX_RESVA 0x0a00 /* a, reserved */#define EX_RESVB 0x0b00 /* b, reserved */#define EX_SC 0x0c00 /* c, System Call */#define EX_TRACE 0x0d00 /* d, Program trace */#define EX_FPA 0x0e00 /* e, FP Assist */#define EX_PERF 0x0f00 /* f, Performance monito */#define EX_RESV10 0x1000 /* 10, reserved */#define EX_RESV11 0x1100 /* 11, reserved */#define EX_RESV12 0x1200 /* 12, reserved */#define EX_IABP 0x1300 /* 13, Instruction BP */#define EX_SMI 0x1400 /* 14, System Management */#define EX_END 0x2f00 /* Last */#endif /* _MACHINE_INTR_H_ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -