Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/arm Fix earmv6{,hf}eb start-up routines:
details: https://anonhg.NetBSD.org/src/rev/7a90266fffa5
branches: trunk
changeset: 1016772:7a90266fffa5
user: rin <rin%NetBSD.org@localhost>
date: Tue Dec 01 02:46:19 2020 +0000
description:
Fix earmv6{,hf}eb start-up routines:
- Turn on U-bit in SCTLR before E-bit is turned on by ``setend be'',
in order to avoid undefined condition. ARM1176JZF-S, at least, halts
if only E-bit is turned on.
- Turn on EE-bit in SCTLR instead of B-bit as we've switched to BE8.
diffstat:
sys/arch/arm/arm/armv6_start.S | 19 ++++++++++++++++---
sys/arch/arm/arm/cpufunc.c | 26 ++++++++++++++++----------
2 files changed, 32 insertions(+), 13 deletions(-)
diffs (124 lines):
diff -r 33f58b842d07 -r 7a90266fffa5 sys/arch/arm/arm/armv6_start.S
--- a/sys/arch/arm/arm/armv6_start.S Tue Dec 01 02:43:18 2020 +0000
+++ b/sys/arch/arm/arm/armv6_start.S Tue Dec 01 02:46:19 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: armv6_start.S,v 1.30 2020/10/13 21:06:18 skrll Exp $ */
+/* $NetBSD: armv6_start.S,v 1.31 2020/12/01 02:46:19 rin Exp $ */
/*-
* Copyright (c) 2012, 2017, 2018 The NetBSD Foundation, Inc.
@@ -95,9 +95,16 @@
ENTRY_NP(generic_start)
- // ARMv7 only?!?
#if defined(__ARMEB__)
+# if defined(_ARM_ARCH_7)
setend be /* force big endian */
+# else /* _ARM_ARCH_6 */
+ /* Make sure U bit is always set with E bit in SCTLR. */
+ mrc p15, 0, R_TMP1, c1, c0, 0
+ orr R_TMP1, R_TMP1, #CPU_CONTROL_UNAL_ENABLE
+ mcr p15, 0, R_TMP1, c1, c0, 0
+ setend be
+# endif
#endif
/* disable IRQs/FIQs. */
@@ -1086,6 +1093,11 @@
#else
#define CPU_CONTROL_EXTRA CPU_CONTROL_SYST_ENABLE
#endif
+#if defined(__ARMEL__)
+#define CPU_CONTROL_EX_BEND_SET 0
+#else
+#define CPU_CONTROL_EX_BEND_SET CPU_CONTROL_EX_BEND
+#endif
.word CPU_CONTROL_MMU_ENABLE | \
CPU_CONTROL_WBUF_ENABLE | /* not defined in 1176 (SBO) */ \
CPU_CONTROL_32BP_ENABLE | /* SBO */ \
@@ -1094,7 +1106,8 @@
(1 << 16) | /* SBO - Global enable for data tcm */ \
(1 << 18) | /* SBO - Global enable for insn tcm */ \
CPU_CONTROL_UNAL_ENABLE | \
- CPU_CONTROL_EXTRA
+ CPU_CONTROL_EXTRA | \
+ CPU_CONTROL_EX_BEND_SET
/* bits to clear in the Control Register */
Lcontrol_clr:
diff -r 33f58b842d07 -r 7a90266fffa5 sys/arch/arm/arm/cpufunc.c
--- a/sys/arch/arm/arm/cpufunc.c Tue Dec 01 02:43:18 2020 +0000
+++ b/sys/arch/arm/arm/cpufunc.c Tue Dec 01 02:46:19 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc.c,v 1.178 2020/10/30 18:54:36 skrll Exp $ */
+/* $NetBSD: cpufunc.c,v 1.179 2020/12/01 02:46:19 rin Exp $ */
/*
* arm7tdmi support code Copyright (c) 2001 John Fremlin
@@ -49,7 +49,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpufunc.c,v 1.178 2020/10/30 18:54:36 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpufunc.c,v 1.179 2020/12/01 02:46:19 rin Exp $");
#include "opt_arm_start.h"
#include "opt_compat_netbsd.h"
@@ -2769,6 +2769,11 @@
#endif
| CPU_CONTROL_IC_ENABLE | CPU_CONTROL_DC_ENABLE
/* | CPU_CONTROL_BPRD_ENABLE */;
+
+#ifdef __ARMEB__
+ cpuctrl |= CPU_CONTROL_EX_BEND;
+#endif
+
int cpuctrlmask = cpuctrl
| CPU_CONTROL_ROM_ENABLE | CPU_CONTROL_BPRD_ENABLE
| CPU_CONTROL_BEND_ENABLE | CPU_CONTROL_AFLT_ENABLE
@@ -2780,10 +2785,6 @@
cpuctrl = parse_cpu_options(args, arm11_options, cpuctrl);
-#ifdef __ARMEB__
- cpuctrl |= CPU_CONTROL_BEND_ENABLE;
-#endif
-
#ifndef ARM_HAS_VBAR
if (vector_page == ARM_VECTORS_HIGH)
cpuctrl |= CPU_CONTROL_VECRELOC;
@@ -2818,6 +2819,11 @@
| CPU_CONTROL_XP_ENABLE
#endif
| CPU_CONTROL_BPRD_ENABLE ;
+
+#ifdef __ARMEB__
+ cpuctrl |= CPU_CONTROL_EX_BEND;
+#endif
+
int cpuctrlmask = cpuctrl
| CPU_CONTROL_AFLT_ENABLE
| CPU_CONTROL_VECRELOC;
@@ -3057,6 +3063,10 @@
#endif
CPU_CONTROL_IC_ENABLE;
+#ifdef __ARMEB__
+ cpuctrl |= CPU_CONTROL_EX_BEND;
+#endif
+
/*
* "write as existing" bits
* inverse of this is mask
@@ -3075,10 +3085,6 @@
cpuctrl = parse_cpu_options(args, arm11_options, cpuctrl);
-#ifdef __ARMEB__
- cpuctrl |= CPU_CONTROL_BEND_ENABLE;
-#endif
-
#ifndef ARM_HAS_VBAR
if (vector_page == ARM_VECTORS_HIGH)
cpuctrl |= CPU_CONTROL_VECRELOC;
Home |
Main Index |
Thread Index |
Old Index