summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornon <non@FreeBSD.org>2001-02-25 14:01:05 +0000
committernon <non@FreeBSD.org>2001-02-25 14:01:05 +0000
commit616fd772d1ff52f7be49c8c668a6095fa8cdf0cf (patch)
tree332cc2d84a65b699a0e79409eeebdbd2cfcc8478
parent69c64365e594d4895efab2beaf9a1c9d32081733 (diff)
downloadFreeBSD-src-616fd772d1ff52f7be49c8c668a6095fa8cdf0cf.zip
FreeBSD-src-616fd772d1ff52f7be49c8c668a6095fa8cdf0cf.tar.gz
o Check the size of I/O window handed by parent bus.
o Check if it is in PIO_MODE when memory window is not handed.
-rw-r--r--sys/dev/nsp/nsp_pccard.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/sys/dev/nsp/nsp_pccard.c b/sys/dev/nsp/nsp_pccard.c
index 2603ceb..afc3be2 100644
--- a/sys/dev/nsp/nsp_pccard.c
+++ b/sys/dev/nsp/nsp_pccard.c
@@ -134,12 +134,16 @@ static int
nsp_alloc_resource(DEVPORT_PDEVICE dev)
{
struct nsp_softc *sc = device_get_softc(dev);
- u_long maddr, msize;
+ u_long ioaddr, iosize, maddr, msize;
int error;
+ error = bus_get_resource(dev, SYS_RES_IOPORT, 0, &ioaddr, &iosize);
+ if (error || iosize < NSP_IOSIZE)
+ return(ENOMEM);
+
sc->port_rid = 0;
sc->port_res = bus_alloc_resource(dev, SYS_RES_IOPORT, &sc->port_rid,
- 0, ~0, NSP_IOSIZE,RF_ACTIVE);
+ 0, ~0, 0, RF_ACTIVE);
if (sc->port_res == NULL) {
nsp_release_resource(dev);
return(ENOMEM);
@@ -153,18 +157,19 @@ nsp_alloc_resource(DEVPORT_PDEVICE dev)
return(ENOMEM);
}
- /* no need to allocate memory if PIO mode */
- if ((DEVPORT_PDEVFLAGS(dev) & PIO_MODE) != 0) {
- return(0);
- }
-
error = bus_get_resource(dev, SYS_RES_MEMORY, 0, &maddr, &msize);
if (error) {
return(0); /* XXX */
}
- /* no need to allocate memory if not configured */
+ /* No need to allocate memory if not configured and it's in PIO mode */
if (maddr == 0 || msize == 0) {
+ if ((DEVPORT_PDEVFLAGS(dev) & PIO_MODE) == 0) {
+ printf("Memory window was not configured. Configure or use in PIO mode.");
+ nsp_release_resource(dev);
+ return(ENOMEM);
+ }
+ /* no need to allocate memory if PIO mode */
return(0);
}
OpenPOWER on IntegriCloud