Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch Convert remaining armv7 kernels to generic start an...
details: https://anonhg.NetBSD.org/src/rev/a1dbd0b9c5d6
branches: trunk
changeset: 456605:a1dbd0b9c5d6
user: skrll <skrll%NetBSD.org@localhost>
date: Sat May 18 08:49:23 2019 +0000
description:
Convert remaining armv7 kernels to generic start and remove a bunch of
code including a9_mpsubr.S.
Thanks to Lwazi Dube for testing PANDABOARD and BEAGLEBONE.
diffstat:
sys/arch/arm/broadcom/bcm53xx_reg.h | 6 +-
sys/arch/arm/cortex/a9_mpsubr.S | 856 ----------------------------
sys/arch/arm/omap/omap2_reg.h | 7 +-
sys/arch/evbarm/bcm53xx/bcm53xx_machdep.c | 88 ++-
sys/arch/evbarm/bcm53xx/bcm53xx_start.S | 201 ------
sys/arch/evbarm/bcm53xx/platform.h | 5 +-
sys/arch/evbarm/beagle/beagle_machdep.c | 192 ++++-
sys/arch/evbarm/beagle/beagle_start.S | 307 ----------
sys/arch/evbarm/beagle/genassym.cf | 38 -
sys/arch/evbarm/conf/ARMADILLO-IOT-G3 | 3 +-
sys/arch/evbarm/conf/BEAGLEBONE | 5 +-
sys/arch/evbarm/conf/IGEPV2 | 8 +-
sys/arch/evbarm/conf/N900 | 10 +-
sys/arch/evbarm/conf/OMAP5EVM | 8 +-
sys/arch/evbarm/conf/PANDABOARD | 10 +-
sys/arch/evbarm/conf/VTC100 | 9 +-
sys/arch/evbarm/conf/mk.beagle | 10 +-
sys/arch/evbarm/conf/mk.gumstix | 24 +-
sys/arch/evbarm/conf/mk.imx7 | 10 +-
sys/arch/evbarm/conf/mk.kobo | 8 +-
sys/arch/evbarm/conf/mk.nitrogen6 | 22 +-
sys/arch/evbarm/conf/std.bcm53xx | 3 +-
sys/arch/evbarm/conf/std.beagle | 4 +-
sys/arch/evbarm/conf/std.gumstix | 13 +-
sys/arch/evbarm/conf/std.imx7 | 26 +-
sys/arch/evbarm/conf/std.kobo | 22 +-
sys/arch/evbarm/conf/std.nitrogen6 | 9 +-
sys/arch/evbarm/conf/std.overo | 11 +-
sys/arch/evbarm/gumstix/gumstix_machdep.c | 231 ++++++-
sys/arch/evbarm/gumstix/gumstix_start.S | 181 +-----
sys/arch/evbarm/gumstix/gumstixreg.h | 4 +-
sys/arch/evbarm/imx7/genassym.cf | 59 -
sys/arch/evbarm/imx7/imx7_machdep.c | 133 +++-
sys/arch/evbarm/imx7/imx7_start.S | 329 ----------
sys/arch/evbarm/kobo/kobo_machdep.c | 14 +-
sys/arch/evbarm/kobo/kobo_start.S | 332 ----------
sys/arch/evbarm/netwalker/netwalker_start.S | 419 +++++++++++++-
37 files changed, 1092 insertions(+), 2525 deletions(-)
diffs (truncated from 4575 to 300 lines):
diff -r 61dcb6c43d10 -r a1dbd0b9c5d6 sys/arch/arm/broadcom/bcm53xx_reg.h
--- a/sys/arch/arm/broadcom/bcm53xx_reg.h Sat May 18 08:38:00 2019 +0000
+++ b/sys/arch/arm/broadcom/bcm53xx_reg.h Sat May 18 08:49:23 2019 +0000
@@ -69,11 +69,15 @@
#define BCM53XX_PCIE2_OWIN_SIZE 0x04000000
#define BCM53XX_PCIE2_OWIN_MAX 0x08000000
+#define BCM53XX_ROM_REGION_PBASE 0xfff00000
+#define BCM53XX_ROM_REGION_SIZE 0x00100000
+
#define BCM53XX_IO_SIZE (BCM53XX_IOREG_SIZE \
+ BCM53XX_ARMCORE_SIZE \
+ BCM53XX_PCIE0_OWIN_SIZE \
+ BCM53XX_PCIE1_OWIN_SIZE \
- + BCM53XX_PCIE2_OWIN_SIZE)
+ + BCM53XX_PCIE2_OWIN_SIZE \
+ + BCM53XX_ROM_REGION_SIZE)
#define BCM53XX_REF_CLK (25*1000*1000)
diff -r 61dcb6c43d10 -r a1dbd0b9c5d6 sys/arch/arm/cortex/a9_mpsubr.S
--- a/sys/arch/arm/cortex/a9_mpsubr.S Sat May 18 08:38:00 2019 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,856 +0,0 @@
-/* $NetBSD: a9_mpsubr.S,v 1.58 2018/09/21 12:04:06 skrll Exp $ */
-/*-
- * Copyright (c) 2012 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Matt Thomas of 3am Software Foundry.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
- * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
- * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- * POSSIBILITY OF SUCH DAMAGE.
- */
-
-#include "opt_console.h"
-#include "opt_cpuoptions.h"
-#include "opt_cputypes.h"
-#include "opt_multiprocessor.h"
-
-#include <arm/asm.h>
-#include <arm/armreg.h>
-#include <arm/cortex/scu_reg.h>
-#include "assym.h"
-
-//#define MPDEBUG
-
-// Macro to call routines in .text
-#if defined(KERNEL_BASES_EQUAL)
-#define CALL(f) bl _C_LABEL(f)
-#else
-#define CALL(f) \
- movw fp, #:lower16:_C_LABEL(f); \
- movt fp, #:upper16:_C_LABEL(f); \
- sub fp, fp, #KERNEL_BASE_VOFFSET; \
- blx fp
-#endif
-
-#if defined(CPU_CORTEXA7) || defined(CPU_CORTEXA15) || defined(CPU_CORTEXA17) \
- || defined(CPU_CORTEXA35)
- .arch armv7a
- .arch_extension virt
-#define CPU_CORTEXVIRT
-#endif
-
-// We'll modify va and pa at run time so we can use relocatable addresses.
-#define MMU_INIT(va,pa,n_sec,attr) \
- .word ((va) & 0xffffffff)|(n_sec) ; \
- .word ((pa) & 0xffffffff)|(attr) ; \
-
-// Set up a preliminary mapping in the MMU to allow us to run at KERNEL_BASE
-// with caches on. If we are MULTIPROCESSOR, save the TTB address.
-//
-arm_boot_l1pt_init:
-#if defined(MULTIPROCESSOR)
- movw r3, #:lower16:cortex_mmuinfo
- movt r3, #:upper16:cortex_mmuinfo
-#if !defined(KERNEL_BASES_EQUAL)
- sub r3, r3, #KERNEL_BASE_VOFFSET
-#endif
- str r0, [r3]
-
- // Make sure the info makes into memory
- mcr p15, 0, r3, c7, c10, 1 // writeback the cache line
- dsb
-#endif
-
- mov ip, r1 // save mmu table addr
- // Build page table from scratch
- mov r1, r0 // Start address to clear memory.
- // Zero the entire table so all virtual addresses are invalid.
- add r2, r1, #L1_TABLE_SIZE // Ending address
- mov r4, #0
- mov r5, #0
- mov r6, #0
- mov r7, #0
-1: stmia r1!, {r4-r7} // 16 bytes at a time
- cmp r1, r2
- blt 1b
-
- // Now create our entries per the mmu_init_table.
- l1table .req r0
- va .req r1
- pa .req r2
- n_sec .req r3
- attr .req r4
- itable .req r5
-
- mov attr, #0
- mrc p15, 0, r3, c0, c0, 5 // MPIDR read
- cmp r3, #0 // not zero?
- movne attr, #L1_S_V6_S // yes, shareable attribute
- mov itable, ip // reclaim table address
- b 3f
-
-2: str pa, [l1table, va, lsl #2]
- add va, va, #1
- add pa, pa, #(L1_S_SIZE)
- subs n_sec, n_sec, #1
- bhi 2b
-
-3: ldmia itable!, {va, pa}
- // Convert va to l1 offset: va = 4 * (va >> L1_S_SHIFT)
- ubfx n_sec, va, #0, #L1_S_SHIFT
- lsr va, va, #L1_S_SHIFT
-
- // Do we need add sharing for this?
- tst pa, #(L1_S_C|L1_S_B) // is this entry cacheable?
- orrne pa, pa, attr // add sharing
-
-4: cmp n_sec, #0
- bne 2b
- bx lr // return
-
- .unreq va
- .unreq pa
- .unreq n_sec
- .unreq attr
- .unreq itable
- .unreq l1table
-
-//
-// Coprocessor register initialization values
-//
-#if defined(CPU_CORTEXA8)
-#undef CPU_CONTROL_SWP_ENABLE // not present on A8
-#define CPU_CONTROL_SWP_ENABLE 0
-#endif
-#ifdef __ARMEL__
-#define CPU_CONTROL_EX_BEND_SET 0
-#else
-#define CPU_CONTROL_EX_BEND_SET CPU_CONTROL_EX_BEND
-#endif
-#ifdef ARM32_DISABLE_ALIGNMENT_FAULTS
-#define CPU_CONTROL_AFLT_ENABLE_CLR CPU_CONTROL_AFLT_ENABLE
-#define CPU_CONTROL_AFLT_ENABLE_SET 0
-#else
-#define CPU_CONTROL_AFLT_ENABLE_CLR 0
-#define CPU_CONTROL_AFLT_ENABLE_SET CPU_CONTROL_AFLT_ENABLE
-#endif
-
-// bits to set in the Control Register
-//
-#define CPU_CONTROL_SET \
- (CPU_CONTROL_MMU_ENABLE | \
- CPU_CONTROL_AFLT_ENABLE_SET | \
- CPU_CONTROL_DC_ENABLE | \
- CPU_CONTROL_SWP_ENABLE | \
- CPU_CONTROL_BPRD_ENABLE | \
- CPU_CONTROL_IC_ENABLE | \
- CPU_CONTROL_EX_BEND_SET | \
- CPU_CONTROL_UNAL_ENABLE)
-
-// bits to clear in the Control Register
-//
-#define CPU_CONTROL_CLR \
- (CPU_CONTROL_AFLT_ENABLE_CLR | \
- CPU_CONTROL_TR_ENABLE)
-
-arm_cpuinit:
- // Because the MMU may already be on do a typical sequence to set
- // the Translation Table Base(s).
- mov ip, lr
- mov r10, r0 // save TTBR
- mov r1, #0
-
- mcr p15, 0, r1, c7, c5, 0 // invalidate I cache
-
- mrc p15, 0, r2, c1, c0, 0 // SCTLR read
- movw r1, #(CPU_CONTROL_DC_ENABLE|CPU_CONTROL_IC_ENABLE)
- bic r2, r2, r1 // clear I+D cache enable
-
-#ifdef __ARMEB__
- // SCTLR.EE determines the endianness of translation table lookups.
- // So we need to make sure it's set before starting to use the new
- // translation tables (which are big endian).
- //
- orr r2, r2, #CPU_CONTROL_EX_BEND
- bic r2, r2, #CPU_CONTROL_MMU_ENABLE
- pli [pc, #32] // preload the next few cachelines
- pli [pc, #64]
- pli [pc, #96]
- pli [pc, #128]
-#endif
-
- mcr p15, 0, r2, c1, c0, 0 // SCTLR write
-
- XPUTC(#'F')
- dsb // Drain the write buffers.
-
- XPUTC(#'G')
- mrc p15, 0, r1, c0, c0, 5 // MPIDR read
- cmp r1, #0
- orrlt r10, r10, #TTBR_MPATTR // MP, cachable (Normal WB)
- orrge r10, r10, #TTBR_UPATTR // Non-MP, cacheable, normal WB
- XPUTC(#'0')
- mcr p15, 0, r10, c2, c0, 0 // TTBR0 write
-#if defined(ARM_MMU_EXTENDED)
- // When using split TTBRs, we need to set both since the physical
- // addresses we were/are using might be in either.
- XPUTC(#'1')
- mcr p15, 0, r10, c2, c0, 1 // TTBR1 write
-#endif
-
- XPUTC(#'H')
-#if defined(ARM_MMU_EXTENDED)
- XPUTC(#'1')
- mov r1, #TTBCR_S_N_1 // make sure TTBCR_S_N is 1
-#else
- XPUTC(#'0')
- mov r1, #0 // make sure TTBCR is 0
-#endif
- mcr p15, 0, r1, c2, c0, 2 // TTBCR write
-
- isb
-
-#if !defined(CPU_CORTEXA5)
- XPUTC(#'I')
- mov r1, #0
- mcr p15, 0, r1, c8, c7, 0 // TLBIALL (just this core)
- dsb
- isb
-#endif
-
- XPUTC(#'J')
- mov r1, #0 // get KERNEL_PID
- mcr p15, 0, r1, c13, c0, 1 // CONTEXTIDR write
-
- // Set the Domain Access register. Very important!
- XPUTC(#'K')
- mov r1, #((DOMAIN_CLIENT << (PMAP_DOMAIN_KERNEL*2)) | DOMAIN_CLIENT)
- mcr p15, 0, r1, c3, c0, 0 // DACR write
-
- //
- // Enable the MMU, etc.
- //
- XPUTC(#'L')
- mrc p15, 0, r1, c1, c0, 0 // SCTLR read
-
- movw r3, #:lower16:CPU_CONTROL_SET
-#if (CPU_CONTROL_SET & 0xffff0000)
- movt r3, #:upper16:CPU_CONTROL_SET
-#endif
- orr r0, r1, r3
- bic r0, r0, #CPU_CONTROL_CLR
- //cmp r0, r1 // any changes to SCTLR?
- //bxeq ip // no, then return.
-
- pli 1f
- dsb
-
- // turn mmu on!
- //
- mov r0, r0 // fetch instruction cacheline
-1: mcr p15, 0, r0, c1, c0, 0 // SCTLR write
-
- // Ensure that the coprocessor has finished turning on the MMU.
- //
- mrc p15, 0, r0, c0, c0, 0 // Read an arbitrary value.
- mov r0, r0 // Stall until read completes.
- XPUTC(#'M')
Home |
Main Index |
Thread Index |
Old Index