summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2006-01-05 20:27:15 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2006-01-05 20:27:15 +0000
commite38173f0bc09f61be5eb08367a9897ec4f9a787a (patch)
treef29c98d8afb33d42700fc5a25f236d36e548208e /sys
parent28da10f6c403fbc1c2d67f8c96c7e06d19d44f99 (diff)
A match() function should never, never, ever return UNSUPP for unsupported
hardware - if only because UNSUPP is 2, not 0. So you'll match, and later have to do ``oops, twas not my fault, honest'' in attach.
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/mac68k/dev/if_ae_nubus.c47
1 files changed, 6 insertions, 41 deletions
diff --git a/sys/arch/mac68k/dev/if_ae_nubus.c b/sys/arch/mac68k/dev/if_ae_nubus.c
index 4621bafb93c..27555e43521 100644
--- a/sys/arch/mac68k/dev/if_ae_nubus.c
+++ b/sys/arch/mac68k/dev/if_ae_nubus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ae_nubus.c,v 1.14 2005/04/26 21:09:35 martin Exp $ */
+/* $OpenBSD: if_ae_nubus.c,v 1.15 2006/01/05 20:27:14 miod Exp $ */
/* $NetBSD: if_ae_nubus.c,v 1.17 1997/05/01 18:17:16 briggs Exp $ */
/*
@@ -97,8 +97,6 @@ ae_nubus_match(parent, vcf, aux)
0, &bsh))
return (0);
- rv = 0;
-
if (na->category == NUBUS_CATEGORY_NETWORK &&
na->type == NUBUS_TYPE_ETHERNET) {
switch (ae_nb_card_vendor(na->na_tag, bsh, na)) {
@@ -112,16 +110,17 @@ ae_nubus_match(parent, vcf, aux)
break;
case AE_VENDOR_DAYNA:
case AE_VENDOR_FOCUS:
- rv = UNSUPP;
- break;
+ /* not supported yet */
+ /* FALLTHROUGH */
default:
+ rv = 0;
break;
}
}
bus_space_unmap(na->na_tag, bsh, NBMEMSIZE);
- return rv;
+ return (rv);
}
/*
@@ -196,37 +195,6 @@ ae_nubus_attach(parent, self, aux)
success = 1;
break;
- case AE_VENDOR_DAYNA:
- /* Map register offsets */
- for (i = 0; i < 16; i++) /* normal order, longword aligned */
- sc->sc_reg_map[i] = i << 2;
-
- if (bus_space_subregion(bst, bsh,
- DP_REG_OFFSET, AE_REG_SIZE, &sc->sc_regh)) {
- printf(": failed to map register space\n");
- break;
- }
- sc->mem_size = 8192;
- if (bus_space_subregion(bst, bsh,
- DP_DATA_OFFSET, sc->mem_size, &sc->sc_bufh)) {
- printf(": failed to map register space\n");
- break;
- }
-#ifdef AE_OLD_GET_ENADDR
- /* Get station address from on-board ROM */
- for (i = 0; i < ETHER_ADDR_LEN; ++i)
- sc->sc_arpcom.ac_enaddr[i] =
- bus_space_read_1(bst, bsh, (DP_ROM_OFFSET + i * 2));
-#else
- if (ae_nb_get_enaddr(bst, bsh, na, sc->sc_arpcom.ac_enaddr)) {
- printf(": can't find MAC address\n");
- break;
- }
-#endif
-
- printf(": unsupported Dayna hardware\n");
- break;
-
case AE_VENDOR_FARALLON:
/* Map register offsets */
for (i = 0; i < 16; i++) /* reverse order, longword aligned */
@@ -257,10 +225,6 @@ ae_nubus_attach(parent, self, aux)
success = 1;
break;
- case AE_VENDOR_FOCUS:
- printf(": unsupported Focus hardware\n");
- break;
-
case AE_VENDOR_INTERLAN:
/* Map register offsets */
for (i = 0; i < 16; i++) /* normal order, longword aligned */
@@ -326,6 +290,7 @@ ae_nubus_attach(parent, self, aux)
break;
default:
+ /* shouldn't happen */
break;
}