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:
parent
48a1466abf
commit
fac207b0b2
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=52548
@ -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);
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user