summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorKenji Aoyama <aoyama@cvs.openbsd.org>2006-10-30 14:32:28 +0000
committerKenji Aoyama <aoyama@cvs.openbsd.org>2006-10-30 14:32:28 +0000
commite38be535be921aef060db439f5a8e1dec74e38e3 (patch)
treec787054a083952624012cd8316e04ff739a32ac0 /sys
parent477177823a959b0a35fbb475aeb6902bfa56318b (diff)
Changed CMMU probing method. On the luna88k, badaddr() returns 'good'
on unpopulated slots, so we check the CMMU type value for each CMMU register address. ok miod@
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/luna88k/luna88k/m8820x.c42
1 files changed, 12 insertions, 30 deletions
diff --git a/sys/arch/luna88k/luna88k/m8820x.c b/sys/arch/luna88k/luna88k/m8820x.c
index d1ee60e9c28..75974aceb43 100644
--- a/sys/arch/luna88k/luna88k/m8820x.c
+++ b/sys/arch/luna88k/luna88k/m8820x.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: m8820x.c,v 1.12 2006/05/15 21:40:04 miod Exp $ */
+/* $OpenBSD: m8820x.c,v 1.13 2006/10/30 14:32:27 aoyama Exp $ */
/*
* Copyright (c) 2004, Miodrag Vallat.
*
@@ -112,38 +112,24 @@ m8820x_setup_board_config()
/*
* Probe CMMU address to discover which CPU slots are populated.
- * Actually, we'll simply check how many upper slots we can ignore,
- * and keep using badaddr() to cope with unpopulated slots.
+ * On the luna88k, badaddr() returns 'good' on unpopulated slots,
+ * so we check the CMMU type value for each CMMU register address.
*/
- cmmu = m8820x_cmmu + 7;
- for (max_cmmus = 7; max_cmmus != 0; max_cmmus--, cmmu--) {
- if (badaddr((vaddr_t)cmmu->cmmu_regs, 4) != 0)
+ cmmu = m8820x_cmmu;
+
+ for (num = 0; num < 8; num++) {
+ volatile unsigned *cr = m8820x_cmmu[num].cmmu_regs;
+ int type;
+
+ type = CMMU_TYPE(cr[CMMU_IDR]);
+ if (type != M88200_ID && type != M88204_ID)
break;
}
- max_cpus = 1 + (max_cmmus >> 1);
+ max_cpus = num >> 1;
max_cmmus = max_cpus << 1;
cmmu_shift = 1; /* fixed 2:1 configuration */
-#ifdef DEBUG
- /*
- * Check CMMU type
- */
- for (num = 0; num < max_cmmus; num++) {
- volatile unsigned *cr = m8820x_cmmu[num].cmmu_regs;
- if (badaddr((vaddr_t)cr, 4) == 0) {
- int type;
-
- type = CMMU_TYPE(cr[CMMU_IDR]);
- if (type != M88200_ID && type != M88204_ID) {
- printf("WARNING: non M8820x circuit found "
- "at CMMU address %p\n", cr);
- continue; /* will probably die quickly */
- }
- }
- }
-#endif
-
/*
* Now that we know which CMMUs are there, report every association
*/
@@ -152,12 +138,8 @@ m8820x_setup_board_config()
int type;
cr = m8820x_cmmu[num << cmmu_shift].cmmu_regs;
- if (badaddr((vaddr_t)cr, 4) != 0)
- continue;
-#ifdef MULTIPROCESSOR
m88k_cpus[num].ci_alive = 1; /* This cpu installed... */
-#endif
type = CMMU_TYPE(cr[CMMU_IDR]);
printf("CPU%d is associated to %d MC8820%c CMMUs\n",