Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/mips/mips Rework "machine cp0" command and support ...



details:   https://anonhg.NetBSD.org/src/rev/ca0e6c0cb4e4
branches:  trunk
changeset: 974191:ca0e6c0cb4e4
user:      simonb <simonb%NetBSD.org@localhost>
date:      Sun Jul 26 07:57:06 2020 +0000

description:
Rework "machine cp0" command and support macros to use CP0 reg defines
instead of magic numbers for CP0 regs with a select number.

diffstat:

 sys/arch/mips/mips/db_interface.c |  44 +++++++++++++++++++++-----------------
 1 files changed, 24 insertions(+), 20 deletions(-)

diffs (107 lines):

diff -r 19449d05a392 -r ca0e6c0cb4e4 sys/arch/mips/mips/db_interface.c
--- a/sys/arch/mips/mips/db_interface.c Sun Jul 26 07:52:07 2020 +0000
+++ b/sys/arch/mips/mips/db_interface.c Sun Jul 26 07:57:06 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: db_interface.c,v 1.85 2020/07/13 12:56:58 simonb Exp $ */
+/*     $NetBSD: db_interface.c,v 1.86 2020/07/26 07:57:06 simonb Exp $ */
 
 /*
  * Mach Operating System
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.85 2020/07/13 12:56:58 simonb Exp $");
+__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.86 2020/07/26 07:57:06 simonb Exp $");
 
 #include "opt_multiprocessor.h"
 #include "opt_cputype.h"       /* which mips CPUs do we support? */
@@ -301,10 +301,12 @@
 
 #define        FLDWIDTH        10
 
-#define SHOW32(reg, name)      SHOW32SEL(reg, 0, name)
-#define SHOW64(reg, name)      SHOW64SEL(reg, 0, name)
+#define SHOW32(reg, name)      SHOW32SELECT(reg, 0, name)
+#define SHOW64(reg, name)      SHOW64SELECT(reg, 0, name)
+#define SHOW32SEL(reg, name)   SHOW32SELECT(reg, name)
+#define SHOW64SEL(reg, name)   SHOW64SELECT(reg, name)
 
-#define        SHOW32SEL(num, sel, name)                                       \
+#define        SHOW32SELECT(num, sel, name)                                    \
 do {                                                                   \
        uint32_t __val;                                                 \
                                                                        \
@@ -319,7 +321,7 @@
 } while (0)
 
 /* XXX not 64-bit ABI safe! */
-#define        SHOW64SEL(num, sel, name)                                       \
+#define        SHOW64SELECT(num, sel, name)                                    \
 do {                                                                   \
        uint64_t __val;                                                 \
                                                                        \
@@ -421,9 +423,9 @@
 
        if ((cp0flags & MIPS_CP0FL_USE) != 0) {
                if ((cp0flags & MIPS_CP0FL_EIRR) != 0)
-                       SHOW64SEL(9, 6, "eirr");
+                       SHOW64SEL(MIPS_COP_0_EIRR, "eirr");
                if ((cp0flags & MIPS_CP0FL_EIMR) != 0)
-                       SHOW64SEL(9, 7, "eimr");
+                       SHOW64SEL(MIPS_COP_0_EIMR, "eimr");
        }
 
        if (CPUIS64BITS) {
@@ -449,27 +451,27 @@
 
        if ((cp0flags & MIPS_CP0FL_USE) != 0) {
                if ((cp0flags & MIPS_CP0FL_EBASE) != 0)
-                       SHOW32SEL(15, 1, "ebase");
+                       SHOW32SEL(MIPS_COP_0_EBASE, "ebase");
                if ((cp0flags & MIPS_CP0FL_CONFIG) != 0)
                        SHOW32(MIPS_COP_0_CONFIG, "config");
                if ((cp0flags & MIPS_CP0FL_CONFIG1) != 0)
-                       SHOW32SEL(16, 1, "config1");
+                       SHOW32SEL(MIPS_COP_0_CONFIG1, "config1");
                if ((cp0flags & MIPS_CP0FL_CONFIG2) != 0)
-                       SHOW32SEL(16, 2, "config2");
+                       SHOW32SEL(MIPS_COP_0_CONFIG2, "config2");
                if ((cp0flags & MIPS_CP0FL_CONFIG3) != 0)
-                       SHOW32SEL(16, 3, "config3");
+                       SHOW32SEL(MIPS_COP_0_CONFIG3, "config3");
                if ((cp0flags & MIPS_CP0FL_CONFIG4) != 0)
-                       SHOW32SEL(16, 4, "config4");
+                       SHOW32SEL(MIPS_COP_0_CONFIG4, "config4");
                if ((cp0flags & MIPS_CP0FL_CONFIG5) != 0)
-                       SHOW32SEL(16, 5, "config5");
+                       SHOW32SEL(MIPS_COP_0_CONFIG5, "config5");
                if ((cp0flags & MIPS_CP0FL_CONFIG6) != 0)
-                       SHOW32SEL(16, 6, "config6");
+                       SHOW32SEL(MIPS_COP_0_CONFIG6, "config6");
                if ((cp0flags & MIPS_CP0FL_CONFIG7) != 0)
-                       SHOW32SEL(16, 7, "config7");
+                       SHOW32SEL(MIPS_COP_0_CONFIG7, "config7");
                if (CPUISMIPSNNR2)
-                       SHOW32(7, "hwrena");
+                       SHOW32(MIPS_COP_0_HWRENA, "hwrena");
                if (MIPS_HAS_USERLOCAL)
-                       SHOW32SEL(4, 2, "userlocal");
+                       SHOW32SEL(MIPS_COP_0_USERLOCAL, "userlocal");
        } else {
                SHOW32(MIPS_COP_0_CONFIG, "config");
 #if (MIPS32 + MIPS32R2 + MIPS64 + MIPS64R2) > 0
@@ -508,9 +510,11 @@
 
        if (CPUISMIPSNN) {
                if (CPUIS64BITS) {
-                       SHOW64(MIPS_COP_0_PERFCNT, "perfcnt");
+                       SHOW64(MIPS_COP_0_PERFCNT0_CTL, "perfcnt0ctl");
+                       SHOW64SEL(MIPS_COP_0_PERFCNT0_CNT, "perfcnt0cnt");
                } else {
-                       SHOW32(MIPS_COP_0_PERFCNT, "perfcnt");
+                       SHOW32(MIPS_COP_0_PERFCNT0_CTL, "perfcnt0ctl");
+                       SHOW32SEL(MIPS_COP_0_PERFCNT0_CNT, "perfcnt0cnt");
                }
        }
 



Home | Main Index | Thread Index | Old Index