⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 intr.h

📁 国产CPU-龙芯(loongson)BIOS源代码
💻 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 + -