diff options
author | Niklas Hallqvist <niklas@cvs.openbsd.org> | 1999-01-07 02:28:16 +0000 |
---|---|---|
committer | Niklas Hallqvist <niklas@cvs.openbsd.org> | 1999-01-07 02:28:16 +0000 |
commit | 3c69591551bdd895632b3df688b934194da15b78 (patch) | |
tree | e9f7caabb849ba2ea488746be3fe111ee4649796 | |
parent | 003294c571f5404cf3bb2ab3cf33eba8643b932b (diff) |
Delayed irq allocation for pcic, gives pccard devices better chance of getting
working interrupts on laptops where some are not wired to the pccard controller
-rw-r--r-- | sys/dev/isa/i82365_isa.c | 39 |
1 files changed, 21 insertions, 18 deletions
diff --git a/sys/dev/isa/i82365_isa.c b/sys/dev/isa/i82365_isa.c index 9f89707b019..663ba04fcb4 100644 --- a/sys/dev/isa/i82365_isa.c +++ b/sys/dev/isa/i82365_isa.c @@ -1,4 +1,4 @@ -/* $OpenBSD: i82365_isa.c,v 1.5 1999/01/01 08:05:46 fgsch Exp $ */ +/* $OpenBSD: i82365_isa.c,v 1.6 1999/01/07 02:28:15 niklas Exp $ */ /* $NetBSD: i82365_isa.c,v 1.11 1998/06/09 07:25:00 thorpej Exp $ */ /* @@ -199,8 +199,18 @@ pcic_isa_attach(parent, self, aux) sc->memt = memt; sc->memh = memh; + printf("\n"); + + pcic_attach(sc); + pcic_isa_bus_width_probe (sc, iot, ioh, ia->ia_iobase, ia->ia_iosize); + pcic_attach_sockets(sc); + /* - * allocate an irq. it will be used by both controllers. I could + * We allocate the card event IRQ late because it is more important + * that the cards will get their interrupt than that we get a + * card event interrupt vector that works. + * + * Allocate an irq. It will be used by both controllers. I could * use two different interrupts, but interrupts are relatively * scarce, shareable, and for PCIC controllers, very infrequent. */ @@ -209,30 +219,23 @@ pcic_isa_attach(parent, self, aux) int ist = IST_EDGE; for (i = 0; i < npcic_isa_intr_list; i++) - if (isa_intr_check(ic, pcic_isa_intr_list[i], ist) == 2) + if (isa_intr_check(ic, pcic_isa_intr_list[i], ist) == + 2) goto found; for (i = 0; i < npcic_isa_intr_list; i++) - if (isa_intr_check(ic, pcic_isa_intr_list[i], ist) == 1) + if (isa_intr_check(ic, pcic_isa_intr_list[i], ist) == + 1) goto found; - printf("\n%s: can't allocate interrupt\n", sc->dev.dv_xname); + printf("%s: no irq\n", sc->dev.dv_xname); return; found: sc->irq = pcic_isa_intr_list[i]; - printf(" irq %d", sc->irq); } - printf("\n"); - - pcic_attach(sc); - - pcic_isa_bus_width_probe (sc, iot, ioh, ia->ia_iobase, ia->ia_iosize); - sc->ih = isa_intr_establish(ic, sc->irq, IST_EDGE, IPL_TTY, pcic_intr, sc, sc->dev.dv_xname); - if (sc->ih == NULL) { - printf("%s: can't establish interrupt\n", sc->dev.dv_xname); - return; - } - - pcic_attach_sockets(sc); + if (sc->ih) + printf("%s: irq %d\n", sc->dev.dv_xname, sc->irq); + else + printf("%s: no irq\n", sc->dev.dv_xname); } |