📄 mipsregs.h
字号:
/* * This file is subject to the terms and conditions of the GNU General Public * License. See the file "COPYING" in the main directory of this archive * for more details. * * Copyright (C) 1994, 1995, 1996, 1997, 2000, 2001 by Ralf Baechle * Copyright (C) 2000 Silicon Graphics, Inc. * Modified for further R[236]000 support by Paul M. Antoine, 1996. * Kevin D. Kissell, kevink@mips.com and Carsten Langgaard, carstenl@mips.com * Copyright (C) 2000 MIPS Technologies, Inc. All rights reserved. */#ifndef _ASM_MIPSREGS_H#define _ASM_MIPSREGS_H#if 0#include <linux/linkage.h>#endif/* * The following macros are especially useful for __asm__ * inline assembler. */#ifndef __STR#define __STR(x) #x#endif#ifndef STR#define STR(x) __STR(x)#endif/* * Coprocessor 0 register names */#define CP0_INDEX $0#define CP0_RANDOM $1#define CP0_ENTRYLO0 $2#define CP0_ENTRYLO1 $3#define CP0_CONF $3#define CP0_CONTEXT $4#define CP0_PAGEMASK $5#define CP0_WIRED $6#define CP0_INFO $7#define CP0_BADVADDR $8#define CP0_COUNT $9#define CP0_ENTRYHI $10#define CP0_COMPARE $11#define CP0_STATUS $12#define CP0_CAUSE $13#define CP0_EPC $14#define CP0_PRID $15#define CP0_CONFIG $16#define CP0_LLADDR $17#define CP0_WATCHLO $18#define CP0_WATCHHI $19#define CP0_XCONTEXT $20#define CP0_FRAMEMASK $21#define CP0_DIAGNOSTIC $22#define CP0_PERFORMANCE $25#define CP0_ECC $26#define CP0_CACHEERR $27#define CP0_TAGLO $28#define CP0_TAGHI $29#define CP0_ERROREPC $30/* * R4640/R4650 cp0 register names. These registers are listed * here only for completeness; without MMU these CPUs are not useable * by Linux. A future ELKS port might take make Linux run on them * though ... */#define CP0_IBASE $0#define CP0_IBOUND $1#define CP0_DBASE $2#define CP0_DBOUND $3#define CP0_CALG $17#define CP0_IWATCH $18#define CP0_DWATCH $19/* * Coprocessor 0 Set 1 register names */#define CP0_S1_DERRADDR0 $26#define CP0_S1_DERRADDR1 $27#define CP0_S1_INTCONTROL $20/* * Coprocessor 1 (FPU) register names */#define CP1_REVISION $0#define CP1_STATUS $31/* * FPU Status Register Values *//* * Status Register Values */#define FPU_CSR_FLUSH 0x01000000 /* flush denormalised results to 0 */#define FPU_CSR_COND 0x00800000 /* $fcc0 */#define FPU_CSR_COND0 0x00800000 /* $fcc0 */#define FPU_CSR_COND1 0x02000000 /* $fcc1 */#define FPU_CSR_COND2 0x04000000 /* $fcc2 */#define FPU_CSR_COND3 0x08000000 /* $fcc3 */#define FPU_CSR_COND4 0x10000000 /* $fcc4 */#define FPU_CSR_COND5 0x20000000 /* $fcc5 */#define FPU_CSR_COND6 0x40000000 /* $fcc6 */#define FPU_CSR_COND7 0x80000000 /* $fcc7 *//* * X the exception cause indicator * E the exception enable * S the sticky/flag bit*/#define FPU_CSR_ALL_X 0x0003f000#define FPU_CSR_UNI_X 0x00020000#define FPU_CSR_INV_X 0x00010000#define FPU_CSR_DIV_X 0x00008000#define FPU_CSR_OVF_X 0x00004000#define FPU_CSR_UDF_X 0x00002000#define FPU_CSR_INE_X 0x00001000#define FPU_CSR_ALL_E 0x00000f80#define FPU_CSR_INV_E 0x00000800#define FPU_CSR_DIV_E 0x00000400#define FPU_CSR_OVF_E 0x00000200#define FPU_CSR_UDF_E 0x00000100#define FPU_CSR_INE_E 0x00000080#define FPU_CSR_ALL_S 0x0000007c#define FPU_CSR_INV_S 0x00000040#define FPU_CSR_DIV_S 0x00000020#define FPU_CSR_OVF_S 0x00000010#define FPU_CSR_UDF_S 0x00000008#define FPU_CSR_INE_S 0x00000004/* rounding mode */#define FPU_CSR_RN 0x0 /* nearest */#define FPU_CSR_RZ 0x1 /* towards zero */#define FPU_CSR_RU 0x2 /* towards +Infinity */#define FPU_CSR_RD 0x3 /* towards -Infinity *//* * Values for PageMask register */#include <linux/config.h>#ifdef CONFIG_CPU_VR41XX#define PM_1K 0x00000000#define PM_4K 0x00001800#define PM_16K 0x00007800#define PM_64K 0x0001f800#define PM_256K 0x0007f800#else#define PM_4K 0x00000000#define PM_16K 0x00006000#define PM_64K 0x0001e000#define PM_256K 0x0007e000#define PM_1M 0x001fe000#define PM_4M 0x007fe000#define PM_16M 0x01ffe000#endif/* * Values used for computation of new tlb entries */#define PL_4K 12#define PL_16K 14#define PL_64K 16#define PL_256K 18#define PL_1M 20#define PL_4M 22#define PL_16M 24/* * Macros to access the system control coprocessor */#define read_32bit_cp0_register(source) \({ int __res; \ __asm__ __volatile__( \ ".set\tpush\n\t" \ ".set\treorder\n\t" \ "mfc0\t%0,"STR(source)"\n\t" \ ".set\tpop" \ : "=r" (__res)); \ __res;})#define read_32bit_cp0_set1_register(source) \({ int __res; \ __asm__ __volatile__( \ ".set\tpush\n\t" \ ".set\treorder\n\t" \ "cfc0\t%0,"STR(source)"\n\t" \ ".set\tpop" \ : "=r" (__res)); \ __res;})/* * For now use this only with interrupts disabled! */#define read_64bit_cp0_register(source) \({ int __res; \ __asm__ __volatile__( \ ".set\tmips3\n\t" \ "dmfc0\t%0,"STR(source)"\n\t" \ ".set\tmips0" \ : "=r" (__res)); \ __res;})#define write_32bit_cp0_register(register,value) \ __asm__ __volatile__( \ "mtc0\t%0,"STR(register)"\n\t" \ "nop" \ : : "r" (value));#define write_32bit_cp0_set1_register(register,value) \ __asm__ __volatile__( \ "ctc0\t%0,"STR(register)"\n\t" \ "nop" \ : : "r" (value));#define write_64bit_cp0_register(register,value) \ __asm__ __volatile__( \ ".set\tmips3\n\t" \ "dmtc0\t%0,"STR(register)"\n\t" \ ".set\tmips0" \ : : "r" (value))/* * This should be changed when we get a compiler that support the MIPS32 ISA. */#define read_mips32_cp0_config1() \({ int __res; \ __asm__ __volatile__( \ ".set\tnoreorder\n\t" \ ".set\tnoat\n\t" \ ".word\t0x40018001\n\t" \ "move\t%0,$1\n\t" \ ".set\tat\n\t" \ ".set\treorder" \ :"=r" (__res)); \ __res;})/* * R4x00 interrupt enable / cause bits */#define IE_SW0 (1<< 8)#define IE_SW1 (1<< 9)#define IE_IRQ0 (1<<10)#define IE_IRQ1 (1<<11)#define IE_IRQ2 (1<<12)#define IE_IRQ3 (1<<13)#define IE_IRQ4 (1<<14)#define IE_IRQ5 (1<<15)/* * R4x00 interrupt cause bits */#define C_SW0 (1<< 8)#define C_SW1 (1<< 9)#define C_IRQ0 (1<<10)#define C_IRQ1 (1<<11)#define C_IRQ2 (1<<12)#define C_IRQ3 (1<<13)#define C_IRQ4 (1<<14)#define C_IRQ5 (1<<15)#ifndef _LANGUAGE_ASSEMBLY/* * Manipulate the status register. * Mostly used to access the interrupt bits. */#define __BUILD_SET_CP0(name,register) \
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -