Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/arm Start CPUs more like aarch64 by using a cpu_mpi...



details:   https://anonhg.NetBSD.org/src/rev/4dd0e5536c10
branches:  trunk
changeset: 995719:4dd0e5536c10
user:      skrll <skrll%NetBSD.org@localhost>
date:      Thu Jan 03 10:26:41 2019 +0000

description:
Start CPUs more like aarch64 by using a cpu_mpidr array (if populated)
to map MPIDRs to an index for each CPU.

Towards big.LITTLE support.

diffstat:

 sys/arch/arm/arm/armv6_start.S       |  92 ++++++++++++++++++++++++-----------
 sys/arch/arm/arm32/arm32_boot.c      |  22 ++++----
 sys/arch/arm/arm32/arm32_machdep.c   |  17 ++++-
 sys/arch/arm/arm32/cpu.c             |  46 ++++++++++-------
 sys/arch/arm/broadcom/bcm2835_intr.c |  18 +++---
 sys/arch/arm/fdt/cpu_fdt.c           |  30 +----------
 sys/arch/arm/include/arm32/machdep.h |   4 +-
 sys/arch/arm/include/cpu.h           |  10 +++-
 8 files changed, 136 insertions(+), 103 deletions(-)

diffs (truncated from 591 to 300 lines):

diff -r 06ed0cc217de -r 4dd0e5536c10 sys/arch/arm/arm/armv6_start.S
--- a/sys/arch/arm/arm/armv6_start.S    Thu Jan 03 10:16:43 2019 +0000
+++ b/sys/arch/arm/arm/armv6_start.S    Thu Jan 03 10:26:41 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: armv6_start.S,v 1.4 2019/01/02 16:27:04 skrll Exp $    */
+/*     $NetBSD: armv6_start.S,v 1.5 2019/01/03 10:26:41 skrll Exp $    */
 
 /*-
  * Copyright (c) 2012, 2017, 2018 The NetBSD Foundation, Inc.
@@ -160,6 +160,12 @@
 #endif
 
 #ifdef VERBOSE_INIT_ARM
+       VPRINTF("\n\rmidr :")
+       mrc     p15, 0, r0, c0, c0, 0   // MIDR
+       VPRINTX(r0)
+       VPRINTF("\n\rmpidr:")
+       mrc     p15, 0, r0, c0, c0, 5   // MPIDR
+       VPRINTX(r0)
        VPRINTF("\n\rttb0 :")
        mrc     p15, 0, r0, c2, c0, 0   // TTBR0 read
        VPRINTX(r0)
@@ -516,8 +522,14 @@
        0)
 
 
-//
-// Perform the initialization of the an ARMv7 core required by NetBSD.
+/*
+ * Perform the initialization of the an ARMv7 core required by NetBSD.
+ *
+ * Uses the following callee saved registers:
+ *
+ * Callee saved:
+ *     r4, r5, r6, r7
+ */
 armv7_init:
 
        .arch           armv7a
@@ -618,6 +630,14 @@
 
        .ltorg
 
+/*
+ * Transititions the CPU to using the TTB passed in r0.
+ *
+ * Uses the following callee saved registers:
+ *
+ * Callee saved:
+ *     r4, r5
+ */
 
 armv7_mmuinit:
        // Because the MMU may already be on do a typical sequence to set
@@ -740,22 +760,45 @@
        ldr     R_TMP2, =start_stacks_top
        sub     sp, R_TMP2, R_VTOPDIFF
 
+#ifdef VERBOSE_INIT_ARM
+       VPRINTF("\n\rmidr :")
+       mrc     p15, 0, r0, c0, c0, 0           // MIDR
+       VPRINTX(r0)
+       VPRINTF("\n\rmpidr:")
+       mrc     p15, 0, r0, c0, c0, 5           // MPIDR
+       VPRINTX(r0)
+#endif
+
        mrc     p15, 0, r4, c0, c0, 5           // MPIDR get
-       and     r4, r4, #7                      // get our cpu numder
+       and     r4, #(MPIDR_AFF2|MPIDR_AFF1|MPIDR_AFF0)
+
+       mov     r0, #0
+       ldr     r1, =cpu_mpidr
+       sub     r1, R_VTOPDIFF
+1:
+       ldr     r2, [r1, r0, lsl #2]            // r2 = cpu_mpidr[r0]
+       cmp     r2, r4
+       beq     2f                              // found our mpidr
 
-       mov     r5, r4
+       add     r0, #1
+       cmp     r0, #MAXCPUS
+       bne     1b
+
+       // Not found our mpidr in the list - use Aff0 for cpuindex
+       and     r0, r4, #7
+2:
+       mov     R_TMP2, r0                      // save cpu_index for later
+
+       VPRINTF("index: ")
+       VPRINTX(R_TMP2)
+       XPUTC('\n')
+       XPUTC('\r')
+
+       mov     r5, R_TMP2
        lsl     r5, #INIT_ARM_STACK_SHIFT
        sub     sp, sp, r5
 
-       XPUTC('c')
-       mov     r0, r4
-       add     r0, #'0'
-       bl      uartputc
-       XPUTC(':')
-
-       mov     r0, sp
-       bl      generic_printx
-
+       VPRINTX(sp)
        XPUTC('\n')
        XPUTC('\r')
 
@@ -776,21 +819,12 @@
  * Now running with real kernel VA via bootstrap tables
  */
 armv7_mpcontinuation:
-       ldr     R_TMP2, =start_stacks_top
-
-       mrc     p15, 0, r4, c0, c0, 5           // MPIDR get
-       and     r4, r4, #7                      // get our cpu numder
-
-       mov     r5, r4
-       lsl     r5, #INIT_ARM_STACK_SHIFT
-       sub     sp, R_TMP2, r5
+       // Adjust stack back to KVA address
+       add     sp, sp, R_VTOPDIFF
 
        VPRINTF("go\n\r")
 
-       mrc     p15, 0, r4, c0, c0, 5           // MPIDR get
-       and     r4, r4, #7                      // get our cpu numder
-
-       mov     r0, r4
+       mov     r0, R_TMP2                      // index into cpu_mpidr[] or cpu_number if not found
        bl      cpu_init_secondary_processor
 
        /* Wait for cpu_boot_secondary_processors the when cpu_info is allocated, etc */
@@ -799,7 +833,7 @@
        movt    r6, #:upper16:arm_cpu_mbox
 
        mov     r5, #1                          // bitmask...
-       lsl     r5, r4                          // ... for our cpu
+       lsl     r5, R_TMP2                      // ... for our cpu
 
 1:     dmb                                     // data memory barrier
        ldr     r2, [r6]                        // load mbox
@@ -809,7 +843,7 @@
 
        movw    r0, #:lower16:cpu_info
        movt    r0, #:upper16:cpu_info          // get pointer to cpu_infos
-       ldr     r5, [r0, r4, lsl #2]            // load our cpu_info
+       ldr     r5, [r0, R_TMP2, lsl #2]        // load our cpu_info
        ldr     r6, [r5, #CI_IDLELWP]           // get the idlelwp
        ldr     r7, [r6, #L_PCB]                // now get its pcb
        ldr     sp, [r7, #PCB_KSP]              // finally, we can load our SP
@@ -823,7 +857,7 @@
        str     r6, [r5, #CI_CURLWP]            // and note we are running on it
 
        mov     r0, r5                          // pass cpu_info
-       mov     r1, r4                          // pass cpu_id
+       mov     r1, R_TMP2                      // pass cpu_index
        movw    r2, #:lower16:MD_CPU_HATCH      // pass md_cpu_hatch
        movt    r2, #:upper16:MD_CPU_HATCH      // pass md_cpu_hatch
        bl      _C_LABEL(cpu_hatch)
diff -r 06ed0cc217de -r 4dd0e5536c10 sys/arch/arm/arm32/arm32_boot.c
--- a/sys/arch/arm/arm32/arm32_boot.c   Thu Jan 03 10:16:43 2019 +0000
+++ b/sys/arch/arm/arm32/arm32_boot.c   Thu Jan 03 10:26:41 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: arm32_boot.c,v 1.27 2018/10/31 09:31:01 skrll Exp $    */
+/*     $NetBSD: arm32_boot.c,v 1.28 2019/01/03 10:26:41 skrll Exp $    */
 
 /*
  * Copyright (c) 2002, 2003, 2005  Genetec Corporation.  All rights reserved.
@@ -122,7 +122,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(1, "$NetBSD: arm32_boot.c,v 1.27 2018/10/31 09:31:01 skrll Exp $");
+__KERNEL_RCSID(1, "$NetBSD: arm32_boot.c,v 1.28 2019/01/03 10:26:41 skrll Exp $");
 
 #include "opt_arm_debug.h"
 #include "opt_cputypes.h"
@@ -338,25 +338,25 @@
  * of the idlelwp for this cpu.
  */
 void
-cpu_hatch(struct cpu_info *ci, cpuid_t cpuid, void (*md_cpu_init)(struct cpu_info *))
+cpu_hatch(struct cpu_info *ci, u_int cpuindex, void (*md_cpu_init)(struct cpu_info *))
 {
-       KASSERT(cpu_index(ci) == cpuid);
+       KASSERT(cpu_index(ci) == cpuindex);
 
        /*
         * Raise our IPL to the max
         */
        splhigh();
 
-       VPRINTF("%s(%s): ", __func__, ci->ci_data.cpu_name);
+       VPRINTF("%s(%s): ", __func__, cpu_name(ci));
        ci->ci_ctrl = armreg_sctlr_read();
        uint32_t mpidr = armreg_mpidr_read();
        if (mpidr & MPIDR_MT) {
-               ci->ci_data.cpu_smt_id = mpidr & MPIDR_AFF0;
-               ci->ci_data.cpu_core_id = mpidr & MPIDR_AFF1;
-               ci->ci_data.cpu_package_id = mpidr & MPIDR_AFF2;
+               ci->ci_smt_id = mpidr & MPIDR_AFF0;
+               ci->ci_core_id = mpidr & MPIDR_AFF1;
+               ci->ci_package_id = mpidr & MPIDR_AFF2;
        } else {
-               ci->ci_data.cpu_core_id = mpidr & MPIDR_AFF0;
-               ci->ci_data.cpu_package_id = mpidr & MPIDR_AFF1;
+               ci->ci_core_id = mpidr & MPIDR_AFF0;
+               ci->ci_package_id = mpidr & MPIDR_AFF1;
        }
 
        /*
@@ -423,7 +423,7 @@
        VPRINTF(" done!\n");
 
        /* Notify cpu_boot_secondary_processors that we're done */
-       atomic_and_32(&arm_cpu_mbox, ~__BIT(cpuid));
+       atomic_and_32(&arm_cpu_mbox, ~__BIT(cpuindex));
        membar_producer();
        __asm __volatile("sev; sev; sev");
 }
diff -r 06ed0cc217de -r 4dd0e5536c10 sys/arch/arm/arm32/arm32_machdep.c
--- a/sys/arch/arm/arm32/arm32_machdep.c        Thu Jan 03 10:16:43 2019 +0000
+++ b/sys/arch/arm/arm32/arm32_machdep.c        Thu Jan 03 10:26:41 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: arm32_machdep.c,v 1.124 2018/10/19 08:30:57 skrll Exp $        */
+/*     $NetBSD: arm32_machdep.c,v 1.125 2019/01/03 10:26:41 skrll Exp $        */
 
 /*
  * Copyright (c) 1994-1998 Mark Brinicombe.
@@ -42,7 +42,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: arm32_machdep.c,v 1.124 2018/10/19 08:30:57 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: arm32_machdep.c,v 1.125 2019/01/03 10:26:41 skrll Exp $");
 
 #include "opt_arm_debug.h"
 #include "opt_arm_start.h"
@@ -704,7 +704,7 @@
 vaddr_t
 cpu_uarea_alloc_idlelwp(struct cpu_info *ci)
 {
-       const vaddr_t va = idlestack.pv_va + ci->ci_cpuid * USPACE;
+       const vaddr_t va = idlestack.pv_va + cpu_index(ci) * USPACE;
        // printf("%s: %s: va=%lx\n", __func__, ci->ci_data.cpu_name, va);
        return va;
 }
@@ -723,13 +723,15 @@
  *
  */
 void
-cpu_init_secondary_processor(int cpuno)
+cpu_init_secondary_processor(int cpuindex)
 {
        // pmap_kernel has been sucessfully built and we can switch to it
 
        cpu_domains(DOMAIN_DEFAULT);
        cpu_idcache_wbinv_all();
 
+       VPRINTS("index: ");
+       VPRINTX(cpuindex);
        VPRINTS(" ttb");
 
        cpu_setup(boot_args);
@@ -763,9 +765,14 @@
        VPRINTS(")");
        VPRINTS(" (TTBCR=");
        VPRINTX(armreg_ttbcr_read());
+       VPRINTS(")");
 #endif
 
-       atomic_or_uint(&arm_cpu_hatched, __BIT(cpuno));
+       atomic_or_uint(&arm_cpu_hatched, __BIT(cpuindex));
+
+       VPRINTS(" hatched=");
+       VPRINTX(arm_cpu_hatched);
+       VPRINTS("\n\r");
 
        /* return to assembly to Wait for cpu_boot_secondary_processors */
 }
diff -r 06ed0cc217de -r 4dd0e5536c10 sys/arch/arm/arm32/cpu.c
--- a/sys/arch/arm/arm32/cpu.c  Thu Jan 03 10:16:43 2019 +0000
+++ b/sys/arch/arm/arm32/cpu.c  Thu Jan 03 10:26:41 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpu.c,v 1.124 2019/01/02 09:04:09 skrll Exp $  */
+/*     $NetBSD: cpu.c,v 1.125 2019/01/03 10:26:41 skrll Exp $  */
 
 /*
  * Copyright (c) 1995 Mark Brinicombe.
@@ -46,7 +46,7 @@
 #include "opt_multiprocessor.h"
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpu.c,v 1.124 2019/01/02 09:04:09 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpu.c,v 1.125 2019/01/03 10:26:41 skrll Exp $");
 



Home | Main Index | Thread Index | Old Index