Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/powerpc/oea Split cpu_model_init() into cpu_feature...
details: https://anonhg.NetBSD.org/src/rev/fce558c1613e
branches: trunk
changeset: 1019099:fce558c1613e
user: thorpej <thorpej%NetBSD.org@localhost>
date: Fri Feb 26 21:15:20 2021 +0000
description:
Split cpu_model_init() into cpu_features_probe() and cpu_features_enable()
so that early bootstrap can do those two steps independently, if needed.
Continue to provide a cpu_model_init() wrapper for now.
diffstat:
sys/arch/powerpc/include/oea/cpufeat.h | 9 ++-
sys/arch/powerpc/oea/cpu_subr.c | 79 ++++++++++++++++++++++++++-------
2 files changed, 68 insertions(+), 20 deletions(-)
diffs (163 lines):
diff -r 6d95d4ac94fa -r fce558c1613e sys/arch/powerpc/include/oea/cpufeat.h
--- a/sys/arch/powerpc/include/oea/cpufeat.h Fri Feb 26 19:25:12 2021 +0000
+++ b/sys/arch/powerpc/include/oea/cpufeat.h Fri Feb 26 21:15:20 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufeat.h,v 1.5 2018/03/22 21:26:27 macallan Exp $ */
+/* $NetBSD: cpufeat.h,v 1.6 2021/02/26 21:15:20 thorpej Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
* All rights reserved.
@@ -30,7 +30,8 @@
#ifndef _POWERPC_OEA_OEAFEAT_H_
-/* Cpu features for OEA Cpus.
+/*
+ * Cpu features for OEA Cpus.
* These are only features that affect early bootstrap, and decisions
* that need to be made very early on, like what pmap to use, if bats are
* available, etc etc. More can be added later. Some are not yet utilized.
@@ -48,7 +49,9 @@
#define OEACPU_XBSEN (1 << 7) /* BATS > 256MB */
#ifdef _KERNEL
-void cpu_model_init(void);
+void cpu_features_probe(void);
+void cpu_features_enable(void);
+void cpu_model_init(void);
extern unsigned long oeacpufeat;
#define oea_mapiodev(addr, size) ((oeacpufeat & OEACPU_NOBAT) ? \
diff -r 6d95d4ac94fa -r fce558c1613e sys/arch/powerpc/oea/cpu_subr.c
--- a/sys/arch/powerpc/oea/cpu_subr.c Fri Feb 26 19:25:12 2021 +0000
+++ b/sys/arch/powerpc/oea/cpu_subr.c Fri Feb 26 21:15:20 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu_subr.c,v 1.106 2021/02/26 02:18:57 thorpej Exp $ */
+/* $NetBSD: cpu_subr.c,v 1.107 2021/02/26 21:15:20 thorpej Exp $ */
/*-
* Copyright (c) 2001 Matt Thomas.
@@ -34,7 +34,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpu_subr.c,v 1.106 2021/02/26 02:18:57 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpu_subr.c,v 1.107 2021/02/26 21:15:20 thorpej Exp $");
#include "sysmon_envsys.h"
@@ -267,20 +267,22 @@
unsigned long oeacpufeat;
-/* This is to be called from locore.S, and nowhere else. */
+void
+cpu_features_probe(void)
+{
+ static bool feature_probe_done;
-void
-cpu_model_init(void)
-{
u_int pvr, vers;
+ if (feature_probe_done) {
+ return;
+ }
+
pvr = mfpvr();
vers = pvr >> 16;
- oeacpufeat = 0;
-
if ((vers >= IBMRS64II && vers <= IBM970GX) || vers == MPC620 ||
- vers == IBMCELL || vers == IBMPOWER6P5) {
+ vers == IBMCELL || vers == IBMPOWER6P5) {
oeacpufeat |= OEACPU_64;
oeacpufeat |= OEACPU_64_BRIDGE;
oeacpufeat |= OEACPU_NOBAT;
@@ -289,22 +291,53 @@
oeacpufeat |= OEACPU_601;
} else if (MPC745X_P(vers)) {
- register_t hid1 = mfspr(SPR_HID1);
-
if (vers != MPC7450) {
- register_t hid0 = mfspr(SPR_HID0);
-
/* Enable more SPRG registers */
oeacpufeat |= OEACPU_HIGHSPRG;
/* Enable more BAT registers */
oeacpufeat |= OEACPU_HIGHBAT;
- hid0 |= HID0_HIGH_BAT_EN;
/* Enable larger BAT registers */
oeacpufeat |= OEACPU_XBSEN;
+ }
+
+ } else if (vers == IBM750FX || vers == IBM750GX) {
+ oeacpufeat |= OEACPU_HIGHBAT;
+ }
+
+ feature_probe_done = true;
+}
+
+void
+cpu_features_enable(void)
+{
+ static bool feature_enable_done;
+
+ if (feature_enable_done) {
+ return;
+ }
+
+ u_int pvr, vers;
+
+ pvr = mfpvr();
+ vers = pvr >> 16;
+
+ if (MPC745X_P(vers)) {
+ register_t hid0 = mfspr(SPR_HID0);
+ register_t hid1 = mfspr(SPR_HID1);
+
+ const register_t ohid0 = hid0;
+
+ if (oeacpufeat & OEACPU_HIGHBAT) {
+ hid0 |= HID0_HIGH_BAT_EN;
+ }
+
+ if (oeacpufeat & OEACPU_XBSEN) {
hid0 |= HID0_XBSEN;
+ }
+ if (hid0 != ohid0) {
mtspr(SPR_HID0, hid0);
__asm volatile("sync;isync");
}
@@ -314,10 +347,22 @@
mtspr(SPR_HID1, hid1);
__asm volatile("sync;isync");
+ }
- } else if (vers == IBM750FX || vers == IBM750GX) {
- oeacpufeat |= OEACPU_HIGHBAT;
- }
+ feature_enable_done = true;
+}
+
+/* This is to be called from locore.S, and nowhere else. */
+
+void
+cpu_model_init(void)
+{
+ /*
+ * This is just a wrapper for backwards-compatibility, and will
+ * probably be garbage-collected in the near future.
+ */
+ cpu_features_probe();
+ cpu_features_enable();
}
void
Home |
Main Index |
Thread Index |
Old Index