summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/isa/sb_isapnp.c37
1 files changed, 20 insertions, 17 deletions
diff --git a/sys/dev/isa/sb_isapnp.c b/sys/dev/isa/sb_isapnp.c
index c3b70a3a0e4..e291d94e89f 100644
--- a/sys/dev/isa/sb_isapnp.c
+++ b/sys/dev/isa/sb_isapnp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sb_isapnp.c,v 1.6 1999/01/02 00:02:47 niklas Exp $ */
+/* $OpenBSD: sb_isapnp.c,v 1.7 1999/01/02 17:48:31 niklas Exp $ */
/* $NetBSD: sb_isa.c,v 1.3 1997/03/20 11:03:11 mycroft Exp $ */
/*
@@ -87,26 +87,24 @@ sb_isapnp_attach(parent, self, aux)
struct device *parent, *self;
void *aux;
{
- register struct sbdsp_softc *sc = (struct sbdsp_softc *) self;
- register struct isa_attach_args *ia = aux;
+ struct sbdsp_softc *sc = (struct sbdsp_softc *) self;
+ struct isa_attach_args *ia = aux;
+ int i;
sc->sc_iot = ia->ia_iot;
- sc->sc_ioh = ia->ipa_io[0].h;
- sc->sc_ic = ia->ia_ic;
-
- sc->sc_iobase = ia->ipa_io[0].base;
sc->sc_irq = ia->ipa_irq[0].num;
+ sc->sc_ic = ia->ia_ic;
sc->sc_drq8 = ia->ipa_drq[0].num;
- if (ia->ipa_ndrq > 1 && ia->ipa_drq[0].num != ia->ipa_drq[1].num) {
- /* Some cards have the 16 bit drq first */
- if (sc->sc_drq8 >= 4) {
- sc->sc_drq16 = sc->sc_drq8;
- sc->sc_drq8 = ia->ipa_drq[1].num;
- } else
- sc->sc_drq16 = ia->ipa_drq[1].num;
- } else
- sc->sc_drq16 = DRQUNK;
+ if (ia->ipa_ndrq > 1 && ia->ipa_drq[0].num != ia->ipa_drq[1].num) {
+ /* Some cards have the 16 bit drq first */
+ if (sc->sc_drq8 >= 4) {
+ sc->sc_drq16 = sc->sc_drq8;
+ sc->sc_drq8 = ia->ipa_drq[1].num;
+ } else
+ sc->sc_drq16 = ia->ipa_drq[1].num;
+ } else
+ sc->sc_drq16 = DRQUNK;
#if NMIDI > 0
if (ia->ipa_nio > 1) {
@@ -116,6 +114,12 @@ sb_isapnp_attach(parent, self, aux)
sc->sc_mpu_sc.iobase = 0;
#endif
+ /*
+ * isapnp is a child if isa, and we need isa for the dma
+ * routines
+ */
+ sc->sc_isa = parent->dv_parent;
+
if (!sbmatch(sc)) {
printf("%s: sbmatch failed\n", sc->sc_dev.dv_xname);
return;
@@ -124,6 +128,5 @@ sb_isapnp_attach(parent, self, aux)
printf("%s: %s %s", sc->sc_dev.dv_xname, ia->ipa_devident,
ia->ipa_devclass);
- sc->sc_isa = parent;
sbattach(sc);
}