1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-14 14:55:41 +00:00

Make these compile. Next step is to connect newbus plumbing.

This commit is contained in:
Warner Losh 1999-10-27 05:24:09 +00:00
parent 48a1466abf
commit fac207b0b2
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=52548
5 changed files with 88 additions and 70 deletions

View File

@ -1,8 +1,6 @@
/* $NetBSD: i82365.c,v 1.23 1999/02/19 03:14:00 mycroft Exp $ */ /* $NetBSD: i82365.c,v 1.23 1999/02/19 03:14:00 mycroft Exp $ */
/* $FreeBSD$ */ /* $FreeBSD$ */
#define PCICDEBUG
/* /*
* Copyright (c) 1997 Marc Horowitz. All rights reserved. * Copyright (c) 1997 Marc Horowitz. All rights reserved.
* *
@ -45,6 +43,8 @@
#include <sys/rman.h> #include <sys/rman.h>
#include <machine/resource.h> #include <machine/resource.h>
#include <machine/clock.h>
#include <sys/proc.h> #include <sys/proc.h>
#include <sys/wait.h> #include <sys/wait.h>
#include <sys/kthread.h> #include <sys/kthread.h>
@ -67,6 +67,9 @@ int pcic_debug = 0;
#define DPRINTF(arg) #define DPRINTF(arg)
#endif #endif
#define DETACH_FORCE 0x1
#define PCIC_VENDOR_UNKNOWN 0 #define PCIC_VENDOR_UNKNOWN 0
#define PCIC_VENDOR_I82365SLR0 1 #define PCIC_VENDOR_I82365SLR0 1
#define PCIC_VENDOR_I82365SLR1 2 #define PCIC_VENDOR_I82365SLR1 2
@ -83,8 +86,10 @@ int pcic_debug = 0;
void pcic_attach_socket __P((struct pcic_handle *)); void pcic_attach_socket __P((struct pcic_handle *));
void pcic_init_socket __P((struct pcic_handle *)); void pcic_init_socket __P((struct pcic_handle *));
#if XXX
int pcic_submatch __P((struct device *, struct cfdata *, void *)); int pcic_submatch __P((struct device *, struct cfdata *, void *));
int pcic_print __P((void *arg, const char *pnp)); int pcic_print __P((void *arg, const char *pnp));
#endif
int pcic_intr_socket __P((struct pcic_handle *)); int pcic_intr_socket __P((struct pcic_handle *));
void pcic_attach_card __P((struct pcic_handle *)); void pcic_attach_card __P((struct pcic_handle *));
@ -174,9 +179,10 @@ pcic_vendor_to_string(vendor)
} }
void void
pcic_attach(sc) pcic_attach(device_t dev)
struct pcic_softc *sc;
{ {
struct pcic_softc *sc = (struct pcic_softc *)
device_get_softc(dev);
int vendor, count, i, reg; int vendor, count, i, reg;
/* now check for each controller/socket */ /* now check for each controller/socket */
@ -265,7 +271,7 @@ pcic_attach(sc)
*/ */
if (sc->handle[i].flags & PCIC_FLAG_SOCKETP) if (sc->handle[i].flags & PCIC_FLAG_SOCKETP)
{ {
SIMPLEQ_INIT(&sc->handle[i].events); STAILQ_INIT(&sc->handle[i].events);
pcic_write(&sc->handle[i], PCIC_CSC_INTR, 0); pcic_write(&sc->handle[i], PCIC_CSC_INTR, 0);
pcic_read(&sc->handle[i], PCIC_CSC); pcic_read(&sc->handle[i], PCIC_CSC);
} }
@ -275,7 +281,7 @@ pcic_attach(sc)
(sc->handle[1].flags & PCIC_FLAG_SOCKETP)) { (sc->handle[1].flags & PCIC_FLAG_SOCKETP)) {
vendor = pcic_vendor(&sc->handle[0]); vendor = pcic_vendor(&sc->handle[0]);
printf("%s: controller 0 (%s) has ", sc->dev.dv_xname, device_printf(dev, "controller 0 (%s) has ",
pcic_vendor_to_string(vendor)); pcic_vendor_to_string(vendor));
if ((sc->handle[0].flags & PCIC_FLAG_SOCKETP) && if ((sc->handle[0].flags & PCIC_FLAG_SOCKETP) &&
@ -295,7 +301,7 @@ pcic_attach(sc)
(sc->handle[3].flags & PCIC_FLAG_SOCKETP)) { (sc->handle[3].flags & PCIC_FLAG_SOCKETP)) {
vendor = pcic_vendor(&sc->handle[2]); vendor = pcic_vendor(&sc->handle[2]);
printf("%s: controller 1 (%s) has ", sc->dev.dv_xname, device_printf(dev, "controller 1 (%s) has ",
pcic_vendor_to_string(vendor)); pcic_vendor_to_string(vendor));
if ((sc->handle[2].flags & PCIC_FLAG_SOCKETP) && if ((sc->handle[2].flags & PCIC_FLAG_SOCKETP) &&
@ -344,8 +350,10 @@ pcic_attach_socket(h)
paa.iobase = h->sc->iobase; paa.iobase = h->sc->iobase;
paa.iosize = h->sc->iosize; paa.iosize = h->sc->iosize;
#if XXX
h->pccard = config_found_sm(&h->sc->dev, &paa, pcic_print, h->pccard = config_found_sm(&h->sc->dev, &paa, pcic_print,
pcic_submatch); pcic_submatch);
#endif
/* if there's actually a pccard device attached, initialize the slot */ /* if there's actually a pccard device attached, initialize the slot */
@ -377,14 +385,14 @@ pcic_create_event_thread(arg)
panic("pcic_create_event_thread: unknown pcic socket"); panic("pcic_create_event_thread: unknown pcic socket");
} }
if (kthread_create1(pcic_event_thread, h, &h->event_thread, if (kthread_create(pcic_event_thread, h, &h->event_thread,
"%s,%s", h->sc->dev.dv_xname, cs)) { "%s,%s", device_get_name(h->sc->dev), cs)) {
printf("%s: unable to create event thread for sock 0x%02x\n", device_printf(h->sc->dev,
h->sc->dev.dv_xname, h->sock); "cannot create event thread for sock 0x%02x\n", h->sock);
panic("pcic_create_event_thread"); panic("pcic_create_event_thread");
} else } else
printf("%s: create event thread for sock 0x%02x\n", device_printf(h->sc->dev,
h->sc->dev.dv_xname, h->sock); "create event thread for sock 0x%02x\n", h->sock);
} }
@ -398,7 +406,7 @@ pcic_event_thread(arg)
while (h->shutdown == 0) { while (h->shutdown == 0) {
s = splhigh(); s = splhigh();
if ((pe = SIMPLEQ_FIRST(&h->events)) == NULL) { if ((pe = STAILQ_FIRST(&h->events)) == NULL) {
splx(s); splx(s);
(void) tsleep(&h->events, PWAIT, "pcicev", 0); (void) tsleep(&h->events, PWAIT, "pcicev", 0);
continue; continue;
@ -408,7 +416,7 @@ pcic_event_thread(arg)
(void) tsleep((caddr_t)pcic_event_thread, PWAIT, "pcicss", hz/4); (void) tsleep((caddr_t)pcic_event_thread, PWAIT, "pcicss", hz/4);
} }
s = splhigh(); s = splhigh();
SIMPLEQ_REMOVE_HEAD(&h->events, pe, pe_q); STAILQ_REMOVE_HEAD_UNTIL(&h->events, pe, pe_q);
splx(s); splx(s);
switch (pe->pe_type) { switch (pe->pe_type) {
@ -417,16 +425,16 @@ pcic_event_thread(arg)
while (1) { while (1) {
struct pcic_event *pe1, *pe2; struct pcic_event *pe1, *pe2;
if ((pe1 = SIMPLEQ_FIRST(&h->events)) == NULL) if ((pe1 = STAILQ_FIRST(&h->events)) == NULL)
break; break;
if (pe1->pe_type != PCIC_EVENT_REMOVAL) if (pe1->pe_type != PCIC_EVENT_REMOVAL)
break; break;
if ((pe2 = SIMPLEQ_NEXT(pe1, pe_q)) == NULL) if ((pe2 = STAILQ_NEXT(pe1, pe_q)) == NULL)
break; break;
if (pe2->pe_type == PCIC_EVENT_INSERTION) { if (pe2->pe_type == PCIC_EVENT_INSERTION) {
SIMPLEQ_REMOVE_HEAD(&h->events, pe1, pe_q); STAILQ_REMOVE_HEAD_UNTIL(&h->events, pe1, pe_q);
free(pe1, M_TEMP); free(pe1, M_TEMP);
SIMPLEQ_REMOVE_HEAD(&h->events, pe2, pe_q); STAILQ_REMOVE_HEAD_UNTIL(&h->events, pe2, pe_q);
free(pe2, M_TEMP); free(pe2, M_TEMP);
} }
} }
@ -441,16 +449,16 @@ pcic_event_thread(arg)
while (1) { while (1) {
struct pcic_event *pe1, *pe2; struct pcic_event *pe1, *pe2;
if ((pe1 = SIMPLEQ_FIRST(&h->events)) == NULL) if ((pe1 = STAILQ_FIRST(&h->events)) == NULL)
break; break;
if (pe1->pe_type != PCIC_EVENT_INSERTION) if (pe1->pe_type != PCIC_EVENT_INSERTION)
break; break;
if ((pe2 = SIMPLEQ_NEXT(pe1, pe_q)) == NULL) if ((pe2 = STAILQ_NEXT(pe1, pe_q)) == NULL)
break; break;
if (pe2->pe_type == PCIC_EVENT_REMOVAL) { if (pe2->pe_type == PCIC_EVENT_REMOVAL) {
SIMPLEQ_REMOVE_HEAD(&h->events, pe1, pe_q); STAILQ_REMOVE_HEAD_UNTIL(&h->events, pe1, pe_q);
free(pe1, M_TEMP); free(pe1, M_TEMP);
SIMPLEQ_REMOVE_HEAD(&h->events, pe2, pe_q); STAILQ_REMOVE_HEAD_UNTIL(&h->events, pe2, pe_q);
free(pe2, M_TEMP); free(pe2, M_TEMP);
} }
} }
@ -488,7 +496,7 @@ pcic_init_socket(h)
if (h->event_thread != NULL) if (h->event_thread != NULL)
panic("pcic_attach_socket: event thread"); panic("pcic_attach_socket: event thread");
#endif #endif
kthread_create(pcic_create_event_thread, h); pcic_create_event_thread(h);
/* set up the card to interrupt on card detect */ /* set up the card to interrupt on card detect */
@ -522,6 +530,7 @@ pcic_init_socket(h)
} }
} }
#if XXX
int int
pcic_submatch(parent, cf, aux) pcic_submatch(parent, cf, aux)
struct device *parent; struct device *parent;
@ -583,7 +592,9 @@ pcic_submatch(parent, cf, aux)
return ((*cf->cf_attach->ca_match)(parent, cf, aux)); return ((*cf->cf_attach->ca_match)(parent, cf, aux));
} }
#endif
#if XXX
int int
pcic_print(arg, pnp) pcic_print(arg, pnp)
void *arg; void *arg;
@ -615,6 +626,7 @@ pcic_print(arg, pnp)
return (UNCONF); return (UNCONF);
} }
#endif
int int
pcic_intr(arg) pcic_intr(arg)
@ -707,7 +719,7 @@ pcic_queue_event(h, event)
pe->pe_type = event; pe->pe_type = event;
s = splhigh(); s = splhigh();
SIMPLEQ_INSERT_TAIL(&h->events, pe, pe_q); STAILQ_INSERT_TAIL(&h->events, pe, pe_q);
splx(s); splx(s);
wakeup(&h->events); wakeup(&h->events);
} }
@ -718,8 +730,10 @@ pcic_attach_card(h)
{ {
struct pccard_softc *psc = (void*)h->pccard; struct pccard_softc *psc = (void*)h->pccard;
if (!(h->flags & PCIC_FLAG_CARDP)) { if (!(h->flags & PCIC_FLAG_CARDP)) {
#if XXX
/* call the MI attach function */ /* call the MI attach function */
psc->sc_if.if_card_attach (psc); psc->sc_if.if_card_attach (psc);
#endif
h->flags |= PCIC_FLAG_CARDP; h->flags |= PCIC_FLAG_CARDP;
} else { } else {
@ -737,7 +751,9 @@ pcic_detach_card(h, flags)
h->flags &= ~PCIC_FLAG_CARDP; h->flags &= ~PCIC_FLAG_CARDP;
/* call the MI detach function */ /* call the MI detach function */
#if XXX
psc->sc_if.if_card_detach (psc, flags); psc->sc_if.if_card_detach (psc, flags);
#endif
} else { } else {
DPRINTF(("pcic_detach_card: already detached")); DPRINTF(("pcic_detach_card: already detached"));
} }
@ -749,7 +765,9 @@ pcic_deactivate_card(h)
{ {
struct pccard_softc *psc = (void*)h->pccard; struct pccard_softc *psc = (void*)h->pccard;
/* call the MI deactivate function */ /* call the MI deactivate function */
#if XXX
psc->sc_if.if_card_deactivate (psc); psc->sc_if.if_card_deactivate (psc);
#endif
/* power down the socket */ /* power down the socket */
pcic_write(h, PCIC_PWRCTL, 0); pcic_write(h, PCIC_PWRCTL, 0);
@ -784,10 +802,12 @@ pcic_chip_mem_alloc(pch, size, pcmhp)
for (i = 0; i <= PCIC_MAX_MEM_PAGES - sizepg; i++) { for (i = 0; i <= PCIC_MAX_MEM_PAGES - sizepg; i++) {
if ((h->sc->subregionmask & (mask << i)) == (mask << i)) { if ((h->sc->subregionmask & (mask << i)) == (mask << i)) {
#if XXX
if (bus_space_subregion(h->sc->memt, h->sc->memh, if (bus_space_subregion(h->sc->memt, h->sc->memh,
i * PCIC_MEM_PAGESIZE, i * PCIC_MEM_PAGESIZE,
sizepg * PCIC_MEM_PAGESIZE, &memh)) sizepg * PCIC_MEM_PAGESIZE, &memh))
return (1); return (1);
#endif
mhandle = mask << i; mhandle = mask << i;
addr = h->sc->membase + (i * PCIC_MEM_PAGESIZE); addr = h->sc->membase + (i * PCIC_MEM_PAGESIZE);
h->sc->subregionmask &= ~(mhandle); h->sc->subregionmask &= ~(mhandle);
@ -1037,16 +1057,20 @@ pcic_chip_io_alloc(pch, start, size, align, pcihp)
if (start) { if (start) {
ioaddr = start; ioaddr = start;
#if XXX
if (bus_space_map(iot, start, size, 0, &ioh)) if (bus_space_map(iot, start, size, 0, &ioh))
return (1); return (1);
#endif
DPRINTF(("pcic_chip_io_alloc map port %lx+%lx\n", DPRINTF(("pcic_chip_io_alloc map port %lx+%lx\n",
(u_long) ioaddr, (u_long) size)); (u_long) ioaddr, (u_long) size));
} else { } else {
flags |= PCCARD_IO_ALLOCATED; flags |= PCCARD_IO_ALLOCATED;
#if XXX
if (bus_space_alloc(iot, h->sc->iobase, if (bus_space_alloc(iot, h->sc->iobase,
h->sc->iobase + h->sc->iosize, size, align, 0, 0, h->sc->iobase + h->sc->iosize, size, align, 0, 0,
&ioaddr, &ioh)) &ioaddr, &ioh))
return (1); return (1);
#endif
DPRINTF(("pcic_chip_io_alloc alloc port %lx+%lx\n", DPRINTF(("pcic_chip_io_alloc alloc port %lx+%lx\n",
(u_long) ioaddr, (u_long) size)); (u_long) ioaddr, (u_long) size));
} }
@ -1069,10 +1093,12 @@ pcic_chip_io_free(pch, pcihp)
bus_space_handle_t ioh = pcihp->ioh; bus_space_handle_t ioh = pcihp->ioh;
bus_size_t size = pcihp->size; bus_size_t size = pcihp->size;
#if XXX
if (pcihp->flags & PCCARD_IO_ALLOCATED) if (pcihp->flags & PCCARD_IO_ALLOCATED)
bus_space_free(iot, ioh, size); bus_space_free(iot, ioh, size);
else else
bus_space_unmap(iot, ioh, size); bus_space_unmap(iot, ioh, size);
#endif
} }
@ -1314,7 +1340,9 @@ pcic_chip_socket_enable(pch)
/* set the card type */ /* set the card type */
#if XXX
cardtype = psc->sc_if.if_card_gettype (psc); cardtype = psc->sc_if.if_card_gettype (psc);
#endif
reg = pcic_read(h, PCIC_INTR); reg = pcic_read(h, PCIC_INTR);
reg &= ~(PCIC_INTR_CARDTYPE_MASK | PCIC_INTR_IRQ_MASK | PCIC_INTR_ENABLE); reg &= ~(PCIC_INTR_CARDTYPE_MASK | PCIC_INTR_IRQ_MASK | PCIC_INTR_ENABLE);

View File

@ -1,8 +1,6 @@
/* $NetBSD: i82365_isa.c,v 1.11 1998/06/09 07:25:00 thorpej Exp $ */ /* $NetBSD: i82365_isa.c,v 1.11 1998/06/09 07:25:00 thorpej Exp $ */
/* $FreeBSD$ */ /* $FreeBSD$ */
#define PCICISADEBUG
/* /*
* Copyright (c) 1997 Marc Horowitz. All rights reserved. * Copyright (c) 1997 Marc Horowitz. All rights reserved.
* *
@ -70,22 +68,9 @@ int pcicisa_debug = 0 /* XXX */ ;
#define DPRINTF(arg) #define DPRINTF(arg)
#endif #endif
int pcic_isa_probe __P((struct device *, struct cfdata *, void *)); int pcic_isa_probe(device_t dev);
void pcic_isa_attach __P((struct device *, struct device *, void *)); int pcic_isa_attach(device_t dev);
void *pcic_isa_chip_intr_establish __P((pccard_chipset_handle_t,
struct pccard_function *, int, int (*) (void *), void *));
void pcic_isa_chip_intr_disestablish __P((pccard_chipset_handle_t, void *));
#ifdef __FreeBSD__
struct cfattach pcic_isa_ca = {
sizeof(struct pcic_softc), pcic_isa_probe, pcic_isa_attach
};
#else
struct cfattach pcic_isa_ca = {
sizeof(struct pcic_softc), pcic_isa_probe, pcic_isa_attach
};
#endif
static struct pccard_chip_functions pcic_isa_functions = { static struct pccard_chip_functions pcic_isa_functions = {
pcic_chip_mem_alloc, pcic_chip_mem_alloc,
pcic_chip_mem_free, pcic_chip_mem_free,
@ -105,11 +90,9 @@ static struct pccard_chip_functions pcic_isa_functions = {
}; };
int int
pcic_isa_probe(parent, match, aux) pcic_isa_probe(device_t dev)
struct device *parent;
struct cfdata *match;
void *aux;
{ {
#if XXX
struct isa_attach_args *ia = aux; struct isa_attach_args *ia = aux;
bus_space_tag_t iot = ia->ia_iot; bus_space_tag_t iot = ia->ia_iot;
bus_space_handle_t ioh, memh; bus_space_handle_t ioh, memh;
@ -182,15 +165,14 @@ pcic_isa_probe(parent, match, aux)
return (0); return (0);
ia->ia_iosize = PCIC_IOSIZE; ia->ia_iosize = PCIC_IOSIZE;
#endif
return (1); return (1);
} }
void int
pcic_isa_attach(parent, self, aux) pcic_isa_attach(device_t dev)
struct device *parent, *self;
void *aux;
{ {
#if 0
struct pcic_softc *sc = (void *) self; struct pcic_softc *sc = (void *) self;
struct isa_attach_args *ia = aux; struct isa_attach_args *ia = aux;
isa_chipset_tag_t ic = ia->ia_ic; isa_chipset_tag_t ic = ia->ia_ic;
@ -259,4 +241,6 @@ pcic_isa_attach(parent, self, aux)
} }
pcic_attach_sockets(sc); pcic_attach_sockets(sc);
#endif
return 0;
} }

View File

@ -1,8 +1,6 @@
/* $NetBSD: i82365_isasubr.c,v 1.1 1998/06/07 18:28:31 sommerfe Exp $ */ /* $NetBSD: i82365_isasubr.c,v 1.1 1998/06/07 18:28:31 sommerfe Exp $ */
/* $FreeBSD$ */ /* $FreeBSD$ */
#define PCICISADEBUG
/* /*
* Copyright (c) 1998 Bill Sommerfeld. All rights reserved. * Copyright (c) 1998 Bill Sommerfeld. All rights reserved.
* Copyright (c) 1997 Marc Horowitz. All rights reserved. * Copyright (c) 1997 Marc Horowitz. All rights reserved.
@ -121,13 +119,15 @@ int pcicsubr_debug = 0 /* XXX */ ;
#define DPRINTF(arg) #define DPRINTF(arg)
#endif #endif
void pcic_isa_bus_width_probe (sc, iot, ioh, base, length) void pcic_isa_bus_width_probe (dev, iot, ioh, base, length)
struct pcic_softc *sc; device_t dev;
bus_space_tag_t iot; bus_space_tag_t iot;
bus_space_handle_t ioh; bus_space_handle_t ioh;
bus_addr_t base; bus_addr_t base;
u_int32_t length; u_int32_t length;
{ {
struct pcic_softc *sc = (struct pcic_softc *)
device_get_softc(dev);
bus_space_handle_t ioh_high; bus_space_handle_t ioh_high;
int i, iobuswidth, tmp1, tmp2; int i, iobuswidth, tmp1, tmp2;
@ -138,12 +138,13 @@ void pcic_isa_bus_width_probe (sc, iot, ioh, base, length)
iobuswidth = 12; iobuswidth = 12;
#if XXX
/* Map i/o space. */ /* Map i/o space. */
if (bus_space_map(iot, base + 0x400, length, 0, &ioh_high)) { if (bus_space_map(iot, base + 0x400, length, 0, &ioh_high)) {
printf("%s: can't map high i/o space\n", sc->dev.dv_xname); printf("%s: can't map high i/o space\n", sc->dev.dv_xname);
return; return;
} }
#endif
for (i = 0; i < PCIC_NSLOTS; i++) { for (i = 0; i < PCIC_NSLOTS; i++) {
if (sc->handle[i].flags & PCIC_FLAG_SOCKETP) { if (sc->handle[i].flags & PCIC_FLAG_SOCKETP) {
/* /*
@ -164,7 +165,9 @@ void pcic_isa_bus_width_probe (sc, iot, ioh, base, length)
} }
} }
#if XXX
bus_space_free(iot, ioh_high, length); bus_space_free(iot, ioh_high, length);
#endif
/* /*
* XXX mycroft recommends I/O space range 0x400-0xfff . I should put * XXX mycroft recommends I/O space range 0x400-0xfff . I should put
@ -227,6 +230,8 @@ pcic_isa_chip_intr_establish(pch, pf, ipl, fct, arg)
int (*fct) __P((void *)); int (*fct) __P((void *));
void *arg; void *arg;
{ {
#define IST_LEVEL 1
#define IST_PULSE 2
struct pcic_handle *h = (struct pcic_handle *) pch; struct pcic_handle *h = (struct pcic_handle *) pch;
isa_chipset_tag_t ic = h->sc->intr_est; isa_chipset_tag_t ic = h->sc->intr_est;
int irq, ist; int irq, ist;
@ -240,12 +245,14 @@ pcic_isa_chip_intr_establish(pch, pf, ipl, fct, arg)
else else
ist = IST_LEVEL; ist = IST_LEVEL;
#if XXX
if (isa_intr_alloc(ic, if (isa_intr_alloc(ic,
PCIC_INTR_IRQ_VALIDMASK & pcic_isa_intr_alloc_mask, ist, &irq)) PCIC_INTR_IRQ_VALIDMASK & pcic_isa_intr_alloc_mask, ist, &irq))
return (NULL); return (NULL);
if ((ih = isa_intr_establish(ic, irq, ist, ipl, if ((ih = isa_intr_establish(ic, irq, ist, ipl,
fct, arg)) == NULL) fct, arg)) == NULL)
return (NULL); return (NULL);
#endif
reg = pcic_read(h, PCIC_INTR); reg = pcic_read(h, PCIC_INTR);
reg &= ~PCIC_INTR_IRQ_MASK; reg &= ~PCIC_INTR_IRQ_MASK;
@ -254,7 +261,7 @@ pcic_isa_chip_intr_establish(pch, pf, ipl, fct, arg)
h->ih_irq = irq; h->ih_irq = irq;
printf("%s: card irq %d\n", h->pccard->dv_xname, irq); printf("card irq %d\n",irq);
return (ih); return (ih);
} }
@ -274,5 +281,7 @@ pcic_isa_chip_intr_disestablish(pch, ih)
reg &= ~(PCIC_INTR_IRQ_MASK | PCIC_INTR_ENABLE); reg &= ~(PCIC_INTR_IRQ_MASK | PCIC_INTR_ENABLE);
pcic_write(h, PCIC_INTR, reg); pcic_write(h, PCIC_INTR, reg);
#if XXX
isa_intr_disestablish(ic, ih); isa_intr_disestablish(ic, ih);
#endif
} }

View File

@ -34,17 +34,17 @@
extern int pcic_isa_intr_alloc_mask; extern int pcic_isa_intr_alloc_mask;
/* /*
* Establish/disestablish interrupts for PCMCIA functions. * Establish/disestablish interrupts for PCCARD functions.
*/ */
void *pcic_isa_chip_intr_establish __P((pcmcia_chipset_handle_t, void *pcic_isa_chip_intr_establish __P((pccard_chipset_handle_t,
struct pcmcia_function *, int, int (*) (void *), void *)); struct pccard_function *, int, int (*) (void *), void *));
void pcic_isa_chip_intr_disestablish __P((pcmcia_chipset_handle_t, void *)); void pcic_isa_chip_intr_disestablish __P((pccard_chipset_handle_t, void *));
/* /*
* Figure out how wide the ISA bus is... * Figure out how wide the ISA bus is...
*/ */
void pcic_isa_bus_width_probe __P((struct pcic_softc *, bus_space_tag_t, void pcic_isa_bus_width_probe (device_t, bus_space_tag_t, bus_space_handle_t,
bus_space_handle_t, bus_addr_t, u_int32_t)); bus_addr_t, u_int32_t);

View File

@ -38,7 +38,7 @@
struct proc; struct proc;
struct pcic_event { struct pcic_event {
SIMPLEQ_ENTRY(pcic_event) pe_q; STAILQ_ENTRY(pcic_event) pe_q;
int pe_type; int pe_type;
}; };
@ -70,7 +70,7 @@ struct pcic_handle {
int shutdown; int shutdown;
struct proc *event_thread; struct proc *event_thread;
SIMPLEQ_HEAD(, pcic_event) events; STAILQ_HEAD(, pcic_event) events;
}; };
#define PCIC_FLAG_SOCKETP 0x0001 #define PCIC_FLAG_SOCKETP 0x0001
@ -96,7 +96,7 @@ struct pcic_handle {
#define PCIC_NSLOTS 4 #define PCIC_NSLOTS 4
struct pcic_softc { struct pcic_softc {
struct device dev; device_t dev;
bus_space_tag_t memt; bus_space_tag_t memt;
bus_space_handle_t memh; bus_space_handle_t memh;
@ -136,13 +136,10 @@ int pcic_ident_ok __P((int));
int pcic_vendor __P((struct pcic_handle *)); int pcic_vendor __P((struct pcic_handle *));
char *pcic_vendor_to_string __P((int)); char *pcic_vendor_to_string __P((int));
void pcic_attach __P((struct pcic_softc *)); void pcic_attach(device_t dev);
void pcic_attach_sockets __P((struct pcic_softc *)); void pcic_attach_sockets __P((struct pcic_softc *));
int pcic_intr __P((void *arg)); int pcic_intr __P((void *arg));
static __inline int pcic_read __P((struct pcic_handle *, int));
static __inline void pcic_write __P((struct pcic_handle *, int, int));
int pcic_chip_mem_alloc __P((pccard_chipset_handle_t, bus_size_t, int pcic_chip_mem_alloc __P((pccard_chipset_handle_t, bus_size_t,
struct pccard_mem_handle *)); struct pccard_mem_handle *));
void pcic_chip_mem_free __P((pccard_chipset_handle_t, void pcic_chip_mem_free __P((pccard_chipset_handle_t,