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 Rather than putting it on the caller, j...
details: https://anonhg.NetBSD.org/src/rev/e9c615f8a8b2
branches: trunk
changeset: 1019100:e9c615f8a8b2
user: thorpej <thorpej%NetBSD.org@localhost>
date: Sat Feb 27 01:16:52 2021 +0000
description:
Rather than putting it on the caller, just let oea_iobat_add() decide
whether to call mpc601_ioseg_add().
diffstat:
sys/arch/powerpc/include/oea/sr_601.h | 6 +----
sys/arch/powerpc/oea/oea_machdep.c | 38 ++++++++++++++--------------------
2 files changed, 17 insertions(+), 27 deletions(-)
diffs (95 lines):
diff -r fce558c1613e -r e9c615f8a8b2 sys/arch/powerpc/include/oea/sr_601.h
--- a/sys/arch/powerpc/include/oea/sr_601.h Fri Feb 26 21:15:20 2021 +0000
+++ b/sys/arch/powerpc/include/oea/sr_601.h Sat Feb 27 01:16:52 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sr_601.h,v 1.5 2008/04/28 20:23:32 martin Exp $ */
+/* $NetBSD: sr_601.h,v 1.6 2021/02/27 01:16:52 thorpej Exp $ */
/*-
* Copyright (c) 2002, 2004 The NetBSD Foundation, Inc.
@@ -64,8 +64,4 @@
#define SR601_PA_MATCH_P(sr, pa) \
(((sr) & SR601_PACKET1) == ((pa) >> ADDR_SR_SHFT))
-#ifdef _KERNEL
-void mpc601_ioseg_add(paddr_t, register_t);
-#endif
-
#endif /* !_POWERPC_OEA_SR_601_H_ */
diff -r fce558c1613e -r e9c615f8a8b2 sys/arch/powerpc/oea/oea_machdep.c
--- a/sys/arch/powerpc/oea/oea_machdep.c Fri Feb 26 21:15:20 2021 +0000
+++ b/sys/arch/powerpc/oea/oea_machdep.c Sat Feb 27 01:16:52 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: oea_machdep.c,v 1.81 2020/07/06 10:34:23 rin Exp $ */
+/* $NetBSD: oea_machdep.c,v 1.82 2021/02/27 01:16:52 thorpej Exp $ */
/*
* Copyright (C) 2002 Matt Thomas
@@ -33,7 +33,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: oea_machdep.c,v 1.81 2020/07/06 10:34:23 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: oea_machdep.c,v 1.82 2021/02/27 01:16:52 thorpej Exp $");
#ifdef _KERNEL_OPT
#include "opt_altivec.h"
@@ -480,7 +480,7 @@
}
#ifdef PPC_OEA601
-void
+static void
mpc601_ioseg_add(paddr_t pa, register_t len)
{
const u_int i = pa >> ADDR_SR_SHFT;
@@ -531,6 +531,14 @@
KASSERT(len >= BAT_BL_8M);
+#ifdef PPC_OEA601
+ if (mfpvr() >> 16 == MPC601) {
+ /* Use I/O segments on the BAT-starved 601. */
+ mpc601_ioseg_add(pa, len);
+ return;
+ }
+#endif /* PPC_OEA601 */
+
/*
* If the caller wanted a bigger BAT than the hardware supports,
* split it into smaller BATs.
@@ -778,29 +786,15 @@
* registers were cleared above.
*/
- va_start(ap, pa);
-
/*
* Add any I/O BATs specificed;
- * use I/O segments on the BAT-starved 601.
*/
-#ifdef PPC_OEA601
- if (cpuvers == MPC601) {
- while (pa != 0) {
- register_t len = va_arg(ap, register_t);
- mpc601_ioseg_add(pa, len);
- pa = va_arg(ap, paddr_t);
- }
- } else
-#endif
- {
- while (pa != 0) {
- register_t len = va_arg(ap, register_t);
- oea_iobat_add(pa, len);
- pa = va_arg(ap, paddr_t);
- }
+ va_start(ap, pa);
+ while (pa != 0) {
+ register_t len = va_arg(ap, register_t);
+ oea_iobat_add(pa, len);
+ pa = va_arg(ap, paddr_t);
}
-
va_end(ap);
/*
Home |
Main Index |
Thread Index |
Old Index