Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/mips/include Bit definitions Config4 and Config5 re...



details:   https://anonhg.NetBSD.org/src/rev/efae7aba9922
branches:  trunk
changeset: 974391:efae7aba9922
user:      simonb <simonb%NetBSD.org@localhost>
date:      Fri Jul 31 02:34:38 2020 +0000

description:
Bit definitions Config4 and Config5 registers.

diffstat:

 sys/arch/mips/include/mipsNN.h |  179 ++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 177 insertions(+), 2 deletions(-)

diffs (207 lines):

diff -r e3bc83ea9971 -r efae7aba9922 sys/arch/mips/include/mipsNN.h
--- a/sys/arch/mips/include/mipsNN.h    Thu Jul 30 21:29:20 2020 +0000
+++ b/sys/arch/mips/include/mipsNN.h    Fri Jul 31 02:34:38 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mipsNN.h,v 1.9 2020/07/26 08:08:41 simonb Exp $        */
+/*     $NetBSD: mipsNN.h,v 1.10 2020/07/31 02:34:38 simonb Exp $       */
 
 /*
  * Copyright 2000, 2001
@@ -256,7 +256,7 @@
 /* "MCU" (R): MCU ASE extension present. */
 #define        MIPSNN_CFG3_MCU         0x00020000
 
-/* "ISAOnExc" (R): ISA used on exception. */
+/* "ISAOnExc" (R/RW): ISA used on exception. */
 #define        MIPSNN_CFG3_ISAOnExc    0x00010000      /* microMIPS used on entrance to exception vector */
 
 /* "ISA" (R): Instruction Set Availability. */
@@ -299,6 +299,180 @@
 #define        MIPSNN_CFG3_TL          0x00000001
 
 /*
+ * Values in Configuration Register 4 (CP0 Register 16, Select 4)
+ */
+
+/* "M" (R): Configuration Register 5 present. */
+#define        MIPSNN_CFG4_M                                   __BIT(31)
+
+/* "IE" (R): TLB invalidate instruction support/configuration. */
+#define        MIPSNN_CFG4_IE                                  __BITS(30,29)
+
+/* "AE" (R): Extend EntryHi[ASID] to 10 bits. */
+#define        MIPSNN_CFG4_AE                                  __BIT(28)
+
+/* "VTLBSizeExt" (R): TLB invalidate instruction support/configuration. */
+#define        MIPSNN_CFG4_VTLB_SE                             __BITS(27,24)
+
+/* "KScrExist" (R): Number of kernel mode scratch registers available. */
+#define        MIPSNN_CFG4_KSCR_EXIST                          __BITS(23,16)
+
+/* "MMUExtDef" (R): MMU extension definition. */
+#define        MIPSNN_CFG4_MMU_EXT_DEF                         __BITS(15,14)
+#define          MIPSNN_CFG4_MMU_EXT_DEF_MMU                     1
+#define          MIPSNN_CFG4_MMU_EXT_DEF_FLTB                    2
+#define          MIPSNN_CFG4_MMU_EXT_DEF_VTLB                    3
+
+/* "MMUSizeExt" (R): Extension of Config1[MMUSize-1] field. */
+#define        MIPSNN_CFG4_MMU_EXT_DEF_MMU_SIZE_EXT            __BITS(7,0)
+
+/* "FTLBPageSize" (R/RW): Indicates the Page Size of the FTLB Array Entries. */
+#define        MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE         __BITS(10,8)
+#define          MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE_1K      0
+#define          MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE_4K      1
+#define          MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE_16K     2
+#define          MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE_64K     3
+#define          MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE_256K    4
+#define          MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE_1G      5
+#define          MIPSNN_CFG4_FTLB_FTLB_PAGE_SIZE_4G      6
+/* "FTLBWays" (R): Indicates the Set Associativity of the FTLB Array. */
+#define        MIPSNN_CFG4_FTLB_FTLB_WAYS              __BITS(7,4)
+#define          MIPSNN_CFG4_FTLB_FTLB_WAYS_2            0
+#define          MIPSNN_CFG4_FTLB_FTLB_WAYS_3            1
+#define          MIPSNN_CFG4_FTLB_FTLB_WAYS_4            2
+#define          MIPSNN_CFG4_FTLB_FTLB_WAYS_5            3
+#define          MIPSNN_CFG4_FTLB_FTLB_WAYS_6            4
+#define          MIPSNN_CFG4_FTLB_FTLB_WAYS_7            5
+#define          MIPSNN_CFG4_FTLB_FTLB_WAYS_8            6
+/* "FTLBSets" (R): Indicates the number of Set per Way within the FTLB Array. */
+#define        MIPSNN_CFG4_FTLB_FTLB_SETS              __BITS(3,0)
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_1            0
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_2            1
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_4            2
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_8            3
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_16           4
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_32           5
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_64           6
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_128          7
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_256          8
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_512          9
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_1024         10
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_2048         11
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_4096         12
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_8192         13
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_16384        14
+#define          MIPSNN_CFG4_FTLB_FTLB_SETS_32768        15
+
+/* "MMUSizeExt" (R): Extension of Config1[MMUSize-1] field. */
+#define        MIPSNN_CFG4_FVTLB_VTLB_SIZE_EXT         __BITS(27,24)
+/* "FTLBPageSize" (R/RW): Indicates the Page Size of the FTLB Array Entries. */
+#define        MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE        __BITS(12,8)
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_1K     0
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_4K     1
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_16K    2
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_64K    3
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_256K   4
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_1M     5
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_4M     6
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_16M    7
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_64M    8
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_256M   9
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_1G     10
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_4G     11
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_16G    12
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_64G    13
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_256G   14
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_1T     15
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_4T     16
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_16T    17
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_64T    18
+#define          MIPSNN_CFG4_FVTLB_FTLB_PAGE_SIZE_256T   19
+/* "FTLBWays" (R): Indicates the Set Associativity of the FTLB Array. */
+#define        MIPSNN_CFG4_FVTLB_FTLB_WAYS             __BITS(7,4)
+#define          MIPSNN_CFG4_FVTLB_FTLB_WAYS_2           0
+#define          MIPSNN_CFG4_FVTLB_FTLB_WAYS_3           1
+#define          MIPSNN_CFG4_FVTLB_FTLB_WAYS_4           2
+#define          MIPSNN_CFG4_FVTLB_FTLB_WAYS_5           3
+#define          MIPSNN_CFG4_FVTLB_FTLB_WAYS_6           4
+#define          MIPSNN_CFG4_FVTLB_FTLB_WAYS_7           5
+#define          MIPSNN_CFG4_FVTLB_FTLB_WAYS_8           6
+/* "FTLBSets" (R): Indicates the number of Set per Way within the FTLB Array. */
+#define        MIPSNN_CFG4_FVTLB_FTLB_SETS             __BITS(3,0)
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_1           0
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_2           1
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_4           2
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_8           3
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_16          4
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_32          5
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_64          6
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_128         7
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_256         8
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_512         9
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_1024        10
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_2048        11
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_4096        12
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_8192        13
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_16384       14
+#define          MIPSNN_CFG4_FVTLB_FTLB_SETS_32768       15
+
+
+/*
+ * Values in Configuration Register 5 (CP0 Register 16, Select 5)
+ */
+
+/* "M" (R): Reserved for undefined configuration present. */
+#define        MIPSNN_CFG5_M                                   __BIT(31)
+
+/* "K" (RW): Enable/disable Config K0/Ku/K23 if segmentation is implemented. */
+#define        MIPSNN_CFG5_K                                   __BIT(30)
+
+/* "CV" (RW): Cache Error Exception Vector control disable. */
+#define        MIPSNN_CFG5_CV                                  __BIT(29)
+
+/* "EVA" (R): Enhanced Virtual Addressing instructions implemented. */
+#define        MIPSNN_CFG5_EVA                                 __BIT(28)
+
+/* "MSAEn" (RW): MIPS SIMD Architecture (MSA) enable. */
+#define        MIPSNN_CFG5_MSAEn                               __BIT(27)
+
+/* "XNP" (R): Extended LL/SC instructions non present. */
+#define        MIPSNN_CFG5_XNP                                 __BIT(13)
+
+/* "DEC" (R): Dual Endian Capability. */
+#define        MIPSNN_CFG5_DEC                                 __BIT(11)
+
+/* "L2C" (R): Indicates presense of COP0 Config2. */
+#define        MIPSNN_CFG5_L2C                                 __BIT(10)
+
+/* "UFE" (RW): Enable for user mode access to Config5[FRE]. */
+#define        MIPSNN_CFG5_UFE                                 __BIT(9)
+
+/* "FRE" (RW): Enable for user mode to emulate Status[FR]=0 handling. */
+#define        MIPSNN_CFG5_FRE                                 __BIT(8)
+
+/* "VP" (R): Virtual Processor - multi-threading features supported. */
+#define        MIPSNN_CFG5_VP                                  __BIT(7)
+
+/* "SBRI" (RW): SDBBP instruction Reserved Instruction control. */
+#define        MIPSNN_CFG5_SBRI                                __BIT(6)
+
+/* "MVH" (R): Move To/From High COP0 (MTHCO/MFHCO) instructions implemented. */
+#define        MIPSNN_CFG5_MVH                                 __BIT(5)
+
+/* "LLB" (R): Load-Linked Bit (LLB) is present in COP0 LLAddr. */
+#define        MIPSNN_CFG5_LLB                                 __BIT(4)
+
+/* "MRP" (R): COP0 Memory Accessibility Attributes Regisers are present. */
+#define        MIPSNN_CFG5_MRP                                 __BIT(3)
+
+/* "UFR" (R): Allows user-mode access to Status[FR] using CTC1/CFC1. */
+#define        MIPSNN_CFG5_UFR                                 __BIT(2)
+
+/* "NFExists" (R): Nested Fault feature exists. */
+#define        MIPSNN_CFG5_NF_EXISTS                           __BIT(0)
+
+
+/*
  * Values in Configuration Register 6 (CP0 Register 16, Select 6)
  * for RMI XLP processors
  */
@@ -362,6 +536,7 @@
 #define        MIPSNN_RMIXLP_CFG7_MASKSM_64MB  (0xff >> 1)
 #define        MIPSNN_RMIXLP_CFG7_MASKSM_256MB (0xff >> 0)
 
+
 /*
  * Values in Configuration Register 6 (CP0 Register 16, Select 6)
  * for the MTI 74K and 1074K cores.



Home | Main Index | Thread Index | Old Index