Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/mips/rmi Use EIMR/EIRR regs definitions from <mips/...



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

description:
Use EIMR/EIRR regs definitions from <mips/cpuregs.h>

diffstat:

 sys/arch/mips/rmi/rmixl_spl.S  |  52 ++++++++++++++++++++---------------------
 sys/arch/mips/rmi/rmixl_subr.S |  17 +++++--------
 2 files changed, 32 insertions(+), 37 deletions(-)

diffs (212 lines):

diff -r 91f28b0794e7 -r a1acbd8b1922 sys/arch/mips/rmi/rmixl_spl.S
--- a/sys/arch/mips/rmi/rmixl_spl.S     Sun Jul 26 07:47:27 2020 +0000
+++ b/sys/arch/mips/rmi/rmixl_spl.S     Sun Jul 26 07:48:07 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rmixl_spl.S,v 1.4 2015/06/19 06:32:08 matt Exp $       */
+/*     $NetBSD: rmixl_spl.S,v 1.5 2020/07/26 07:48:07 simonb Exp $     */
 
 /*-
  * Copyright (c) 2009, 2010 The NetBSD Foundation, Inc.
@@ -36,7 +36,7 @@
 #include <mips/asm.h>
 #include <mips/cpuregs.h>
 
-RCSID("$NetBSD: rmixl_spl.S,v 1.4 2015/06/19 06:32:08 matt Exp $");
+RCSID("$NetBSD: rmixl_spl.S,v 1.5 2020/07/26 07:48:07 simonb Exp $");
 
 #include "assym.h"
 
@@ -47,8 +47,6 @@
 #define RMIXL_EIRR_PRESERVE    (RMIXL_INT_MASK_5 | RMIXL_SOFT_INT_MASK)
 #define RMIXL_INT_MASK_1       (MIPS_INT_MASK_1 >> 8)
 #define RMIXL_INT_MASK_5       (MIPS_INT_MASK_5 >> 8)
-#define RMIXL_COP_0_EIRR       _(9), 6
-#define RMIXL_COP_0_EIMR       _(9), 7
 
        .set noreorder
 
@@ -89,9 +87,9 @@
        ori     t0, MIPS_SR_INT_IE              # set IE
        mtc0    zero, MIPS_COP_0_STATUS         ## disable all ints in STATUS
        COP0_SYNC
-       dmtc0   zero, RMIXL_COP_0_EIMR          ##  "       "   "   "  EIMR
+       dmtc0   zero, MIPS_COP_0_EIMR           ##  "       "   "   "  EIMR
        COP0_SYNC
-       dmtc0   zero, RMIXL_COP_0_EIRR          ## clear EIRR
+       dmtc0   zero, MIPS_COP_0_EIRR           ## clear EIRR
        COP0_SYNC
        mtc0    t0, MIPS_COP_0_STATUS           ## set STATUS | IE
        JR_HB_RA
@@ -110,8 +108,8 @@
         * Can only use a0-a3 and v0-v1
         * old IPL is returned in v0
         */
-       dmfc0   a2, RMIXL_COP_0_EIMR            # save EIMR
-       dmtc0   zero, RMIXL_COP_0_EIMR          ## disable all interrupts
+       dmfc0   a2, MIPS_COP_0_EIMR             # save EIMR
+       dmtc0   zero, MIPS_COP_0_EIMR           ## disable all interrupts
        COP0_SYNC
        PTR_L   a3, L_CPU(MIPS_CURLWP)          ##
        INT_L   v0, CPU_INFO_CPL(a3)            ## get current IPL from cpu_info
@@ -119,10 +117,10 @@
        bnez    v1, 1f                          ## yes, don't change.
         nop
        INT_S   a1, CPU_INFO_CPL(a3)            ## save IPL in cpu_info
-       dmtc0   a0, RMIXL_COP_0_EIMR            ## set new EIMR
+       dmtc0   a0, MIPS_COP_0_EIMR             ## set new EIMR
        JR_HB_RA
 1:
-       dmtc0   a2, RMIXL_COP_0_EIMR            ## restore saved EIMR
+       dmtc0   a2, MIPS_COP_0_EIMR             ## restore saved EIMR
        JR_HB_RA
 
 STATIC_LEAF(_splsw_splx)
@@ -132,17 +130,17 @@
        PTR_ADDU v1, a2                         # add to table addr
        REG_L   v1, (v1)                        # load EIMR bits for this IPL
 
-       dmtc0   zero, RMIXL_COP_0_EIMR          ## disable all interrupts
+       dmtc0   zero, MIPS_COP_0_EIMR           ## disable all interrupts
        COP0_SYNC
        PTR_L   a3, L_CPU(MIPS_CURLWP)          ## get cpu_info
        INT_S   a0, CPU_INFO_CPL(a3)            ## save IPL in cpu_info
-       dmtc0   v1, RMIXL_COP_0_EIMR            ## set new EIMR
+       dmtc0   v1, MIPS_COP_0_EIMR             ## set new EIMR
        JR_HB_RA
 END(_splsw_splx)
 
 STATIC_LEAF(_splsw_spl0)
        REG_L   v1, _C_LABEL(ipl_eimr_map) + 8*IPL_NONE
-       dmtc0   zero, RMIXL_COP_0_EIMR          ## disable all interrupts
+       dmtc0   zero, MIPS_COP_0_EIMR           ## disable all interrupts
        COP0_SYNC
        PTR_L   a3, L_CPU(MIPS_CURLWP)          ## get cpu_info
 #if IPL_NONE == 0
@@ -150,22 +148,22 @@
 #else
 #error IPL_NONE != 0
 #endif
-       dmtc0   v1, RMIXL_COP_0_EIMR            ## set new EIMR
+       dmtc0   v1, MIPS_COP_0_EIMR             ## set new EIMR
        JR_HB_RA
 END(_splsw_spl0)
 
 STATIC_LEAF(_splsw_setsoftintr)
        dsrl    a0, 8                           # convert CAUSE bit to EIRR bit
        and     a0, RMIXL_SOFT_INT_MASK         # restrict to softint bits
-       dmfc0   v1, RMIXL_COP_0_EIMR            # save EIMR register
-       dmtc0   zero, RMIXL_COP_0_EIMR          ## disable all interrupts
+       dmfc0   v1, MIPS_COP_0_EIMR             # save EIMR register
+       dmtc0   zero, MIPS_COP_0_EIMR           ## disable all interrupts
        COP0_SYNC
-       dmfc0   v0, RMIXL_COP_0_EIRR            ## load EIRR
+       dmfc0   v0, MIPS_COP_0_EIRR             ## load EIRR
        and     v0, RMIXL_EIRR_PRESERVE         ## preserve clock & softints
        or      v0, a0                          ## set new softint bit
-       dmtc0   v0, RMIXL_COP_0_EIRR            ## store EIRR
+       dmtc0   v0, MIPS_COP_0_EIRR             ## store EIRR
        COP0_SYNC
-       dmtc0   v1, RMIXL_COP_0_EIMR            ## restore EIMR
+       dmtc0   v1, MIPS_COP_0_EIMR             ## restore EIMR
        JR_HB_RA
 END(_splsw_setsoftintr)
 
@@ -173,14 +171,14 @@
        dsrl    a0, 8                           # convert CAUSE bit to EIRR bit
        and     a0, RMIXL_SOFT_INT_MASK         # restrict to softint bits
        xor     a0, RMIXL_EIRR_PRESERVE         # clear from preserve mask
-       dmfc0   v1, RMIXL_COP_0_EIMR            # save EIMR register
-       dmtc0   zero, RMIXL_COP_0_EIMR          ## disable all interrupts
+       dmfc0   v1, MIPS_COP_0_EIMR             # save EIMR register
+       dmtc0   zero, MIPS_COP_0_EIMR           ## disable all interrupts
        COP0_SYNC
-       dmfc0   v0, RMIXL_COP_0_EIRR            ## load EIRR
+       dmfc0   v0, MIPS_COP_0_EIRR             ## load EIRR
        and     v0, a0                          ## apply preserve mask
-       dmtc0   v0, RMIXL_COP_0_EIRR            ## store EIRR
+       dmtc0   v0, MIPS_COP_0_EIRR             ## store EIRR
        COP0_SYNC
-       dmtc0   v1, RMIXL_COP_0_EIMR            ## restore EIMR
+       dmtc0   v1, MIPS_COP_0_EIMR             ## restore EIMR
        JR_HB_RA
 END(_splsw_clrsoftintr)
 
@@ -196,7 +194,7 @@
 
 STATIC_LEAF(_splsw_splhigh)
 STATIC_XLEAF(_splsw_splhigh_noprof)
-       dmtc0   zero, RMIXL_COP_0_EIMR          ## disable all interrupts
+       dmtc0   zero, MIPS_COP_0_EIMR           ## disable all interrupts
        COP0_SYNC
        PTR_L   a3, L_CPU(MIPS_CURLWP)          ## get cpu_info from curlwp
        li      a1, IPL_HIGH                    ##
@@ -257,7 +255,7 @@
 END(_splsw_splsoftclock)
 
 STATIC_LEAF(_splsw_splintr)
-       dmfc0   ta1, RMIXL_COP_0_EIRR           # get active interrupts
+       dmfc0   ta1, MIPS_COP_0_EIRR            # get active interrupts
                                                # restrict to hard int bits:
        and     v1, ta1, RMIXL_SOFT_INT_MASK    #  v1 = ta1 & ~RMIXL_SOFT_INT_MASK
        xor     v1, ta1                         #   "       "
@@ -309,7 +307,7 @@
        PTR_L   t0, L_CPU(MIPS_CURLWP)
        INT_L   t1, CPU_INFO_CPL(t0)            # get current priority level
 
-       dmfc0   t0, RMIXL_COP_0_EIMR            # get current EIMR
+       dmfc0   t0, MIPS_COP_0_EIMR             # get current EIMR
 
        PTR_LA  t2, _C_LABEL(ipl_eimr_map)
        sll     t1, MAP_SCALESHIFT              # shift cpl to array index
diff -r 91f28b0794e7 -r a1acbd8b1922 sys/arch/mips/rmi/rmixl_subr.S
--- a/sys/arch/mips/rmi/rmixl_subr.S    Sun Jul 26 07:47:27 2020 +0000
+++ b/sys/arch/mips/rmi/rmixl_subr.S    Sun Jul 26 07:48:07 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rmixl_subr.S,v 1.6 2015/06/07 08:03:10 matt Exp $      */
+/*     $NetBSD: rmixl_subr.S,v 1.7 2020/07/26 07:48:07 simonb Exp $    */
 
 /*-
  * Copyright (c) 2010 The NetBSD Foundation, Inc.
@@ -37,13 +37,10 @@
 #include <mips/asm.h>
 #include <mips/cpuregs.h>
 
-RCSID("$NetBSD: rmixl_subr.S,v 1.6 2015/06/07 08:03:10 matt Exp $");
+RCSID("$NetBSD: rmixl_subr.S,v 1.7 2020/07/26 07:48:07 simonb Exp $");
 
 #include "assym.h"
 
-#define RMIXL_COP_0_EIRR       _(9), 6
-#define RMIXL_COP_0_EIMR       _(9), 7
-
        .set    noreorder
        .set    arch=xlr
        .text
@@ -83,14 +80,14 @@
  *     clobbered by the EIRR read-modify-write 
  */
 LEAF(rmixl_eirr_ack)
-       dmtc0   zero, RMIXL_COP_0_EIMR  /* EIMR = 0 */
+       dmtc0   zero, MIPS_COP_0_EIMR   /* EIMR = 0 */
        COP0_SYNC
-       dmfc0   a3, RMIXL_COP_0_EIRR    /* a3 = EIRR */
+       dmfc0   a3, MIPS_COP_0_EIRR     /* a3 = EIRR */
        and     a3, a2                  /* a3 &= preserve */
        or      a3, a1                  /* a3 |= vecbit */
-       dmtc0   a3, RMIXL_COP_0_EIRR    /* EIRR = a3 */
+       dmtc0   a3, MIPS_COP_0_EIRR     /* EIRR = a3 */
        COP0_SYNC
-       dmtc0   a0, RMIXL_COP_0_EIMR    /* EIMR = eimr */
+       dmtc0   a0, MIPS_COP_0_EIMR     /* EIMR = eimr */
        JR_HB_RA
 END(rmixl_eirr_ack)
 
@@ -144,7 +141,7 @@
        li              t0, 0
 #endif
 
-       mtc0            zero, RMIXL_COP_0_EIMR  /* disable all in MIPS_COP_0_EIMR */
+       mtc0            zero, MIPS_COP_0_EIMR   /* disable all in MIPS_COP_0_EIMR */
 
        mtc0            t0, MIPS_COP_0_STATUS
 



Home | Main Index | Thread Index | Old Index