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

📄 mipsregs.h

📁 AT91RM9200的完整启动代码:包括loader, boot及U-boot三部分均已编译通过!欢迎下载使用!
💻 H
📖 第 1 页 / 共 2 页
字号:
/* * 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 + -