Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/arm move register accessor macros for MPIDR and AUX...



details:   https://anonhg.NetBSD.org/src/rev/30f8df46162d
branches:  trunk
changeset: 338360:30f8df46162d
user:      hsuenaga <hsuenaga%NetBSD.org@localhost>
date:      Wed May 20 02:59:57 2015 +0000

description:
move register accessor macros for MPIDR and AUXFMC0 to armreg.h

diffstat:

 sys/arch/arm/arm/cpufunc_asm_pj4b.S |  14 +++++-----
 sys/arch/arm/include/armreg.h       |  44 +++++++++++++++++++++++++++---------
 2 files changed, 40 insertions(+), 18 deletions(-)

diffs (101 lines):

diff -r d26aa126be60 -r 30f8df46162d sys/arch/arm/arm/cpufunc_asm_pj4b.S
--- a/sys/arch/arm/arm/cpufunc_asm_pj4b.S       Wed May 20 02:45:20 2015 +0000
+++ b/sys/arch/arm/arm/cpufunc_asm_pj4b.S       Wed May 20 02:59:57 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc_asm_pj4b.S,v 1.10 2015/05/19 09:20:19 hsuenaga Exp $ */
+/*     $NetBSD: cpufunc_asm_pj4b.S,v 1.11 2015/05/20 02:59:57 hsuenaga Exp $ */
 
 /*******************************************************************************
 Copyright (C) Marvell International Ltd. and its affiliates
@@ -88,15 +88,15 @@
        /* Set Marvell Auxiliary Function Modes Control 0 register */
        mrc     p15, 1, r0, c15, c2, 0          @ get FMC0
        mrc     p15, 0, ip, c0, c0, 5           @ get MPIDR
-       tst     ip, #MPIDR_MPCORE
+       tst     ip, #PJ4B_MPIDR_MP
        beq     1f                              @ if not set, not a MPCORE
-       tst     ip, #MPIDR_UNI_PROCESSOR
+       tst     ip, #PJ4B_MPIDR_U
        bne     1f                              @ if set, uni-processor system 
-       orr     r0, r0, #(MV_FMC0_SMP)          @ enable SMP/nAMP
-       orr     r0, r0, #(MV_FMC0_FW)           @ enable maintenance bcast
+       orr     r0, r0, #(PJ4B_AUXFMC0_SMPNAMP) @ enable SMP/nAMP
+       orr     r0, r0, #(PJ4B_AUXFMC0_FW)      @ enable maintenance bcast
 1:
-       bic     r0, r0, #(MV_FMC0_LFDIS)        @ enable speculative linefill
-       orr     r0, r0, #(MV_FMC0_PARITY)       @ enable L1 parity
+       bic     r0, r0, #(PJ4B_AUXFMC0_DCSLFD)  @ enable speculative linefill
+       orr     r0, r0, #(PJ4B_AUXFMC0_L1PARITY)        @ enable L1 parity
        mcr     p15, 1, r0, c15, c2, 0
 
        RET
diff -r d26aa126be60 -r 30f8df46162d sys/arch/arm/include/armreg.h
--- a/sys/arch/arm/include/armreg.h     Wed May 20 02:45:20 2015 +0000
+++ b/sys/arch/arm/include/armreg.h     Wed May 20 02:59:57 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: armreg.h,v 1.104 2015/04/27 06:56:53 skrll Exp $       */
+/*     $NetBSD: armreg.h,v 1.105 2015/05/20 02:59:57 hsuenaga Exp $    */
 
 /*
  * Copyright (c) 1998, 2001 Ben Harris
@@ -434,8 +434,17 @@
 #define        MPCORE_AUXCTL_EX        0x00000010 /* exclusive L1/L2 cache */
 #define        MPCORE_AUXCTL_SA        0x00000020 /* SMP/AMP */
 
-/* Marvell PJ4B Auxillary Control Register */
-#define PJ4B_AUXCTL_SMPNAMP    0x00000040 /* SMP/AMP */
+/* Marvell PJ4B Auxillary Control Register (CP15.0.R1.c0.1) */
+#define PJ4B_AUXCTL_FW         __BIT(0)   /* Cache and TLB updates broadcast */
+#define PJ4B_AUXCTL_SMPNAMP    __BIT(6)   /* 0 = AMP, 1 = SMP */
+#define PJ4B_AUXCTL_L1PARITY   __BIT(9)   /* L1 parity checking */
+
+/* Marvell PJ4B Auxialiary Function Modes Control 0 (CP15.1.R15.c2.0) */
+#define PJ4B_AUXFMC0_L2EN      __BIT(0)  /* Tightly-Coupled L2 cache enable */
+#define PJ4B_AUXFMC0_SMPNAMP   __BIT(1)  /* 0 = AMP, 1 = SMP */
+#define PJ4B_AUXFMC0_L1PARITY  __BIT(2)  /* alias of PJ4B_AUXCTL_L1PARITY */
+#define PJ4B_AUXFMC0_DCSLFD    __BIT(2)  /* Disable DC Speculative linefill */
+#define PJ4B_AUXFMC0_FW                __BIT(8)  /* alias of PJ4B_AUXCTL_FW*/
 
 /* Cortex-A9 Auxiliary Control Register (CP15 register 1, opcode 1) */
 #define        CORTEXA9_AUXCTL_FW      0x00000001 /* Cache and TLB updates broadcast */
@@ -671,6 +680,27 @@
 #define PRRR_TR_DEVICE 1               // Device
 #define PRRR_TR_NORMAL 2               // Normal Memory
 
+/* ARMv7 MPIDR, Multiprocessor Affinity Register generic format  */
+#define MPIDR_MP               __BIT(31)       /* 1 = Have MP Extention */
+#define MPIDR_U                        __BIT(30)       /* 1 = Uni-Processor System */
+#define MPIDR_MT               __BIT(24)       /* 1 = SMT(AFF0 is logical) */
+#define MPIDR_AFF2             __BITS(23,16)   /* Affinity Level 2 */
+#define MPIDR_AFF1             __BITS(15,8)    /* Affinity Level 1 */
+#define MPIDR_AFF0             __BITS(7,0)     /* Affinity Level 0 */
+
+/* MPIDR implementation of ARM Cortex A9: SMT and AFF2 is not used */
+#define CORTEXA9_MPIDR_MP      MPIDR_MP
+#define CORTEXA9_MPIDR_U       MPIDR_U
+#define        CORTEXA9_MPIDR_CLID     __BITS(11,8)    /* AFF1 = cluster id */
+#define CORTEXA9_MPIDR_CPUID   __BITS(0,1)     /* AFF0 = phisycal core id */
+
+/* MPIDR implementation of Marvell PJ4B-MP: AFF2 is not used */
+#define PJ4B_MPIDR_MP          MPIDR_MP
+#define PJ4B_MPIDR_U           MPIDR_U
+#define PJ4B_MPIDR_MT          MPIDR_MT        /* 1 = SMT(AFF0 is logical) */
+#define PJ4B_MPIDR_CLID                __BITS(11,8)    /* AFF1 = cluster id */
+#define PJ4B_MPIDR_CPUID       __BITS(0,3)     /* AFF0 = core id */
+
 /* Defines for ARM Generic Timer */
 #define ARM_CNTCTL_ENABLE              __BIT(0) // Timer Enabled
 #define ARM_CNTCTL_IMASK               __BIT(1) // Mask Interrupt
@@ -1018,12 +1048,4 @@
 
 #endif /* !__ASSEMBLER__ */
 
-
-#define        MPIDR_31                0x80000000
-#define        MPIDR_U                 0x40000000      // 1 = Uniprocessor
-#define        MPIDR_MT                0x01000000      // AFF0 for SMT
-#define        MPIDR_AFF2              0x00ff0000
-#define        MPIDR_AFF1              0x0000ff00
-#define        MPIDR_AFF0              0x000000ff
-
 #endif /* _ARM_ARMREG_H */



Home | Main Index | Thread Index | Old Index