- Use the definitions found in <i386/isa/isa.h> instead of rolling our

own definition of ISA_HOLE_START.  We shouldn't need to include
  bus/processor specific code in here, but it is required.  At least by
  doing it this way it becomes more obvious where the bogusness is.

Obtained from:	email with bde
This commit is contained in:
Nate Williams 1997-10-24 15:27:16 +00:00
parent 514b69b047
commit d50a3fb743

View File

@ -60,10 +60,10 @@
#include <machine/md_var.h>
/*
* XXX ISA_HOLE_START is defined in <machine/pmap.h>, but it
* carries too much baggage
* XXX We shouldn't be using processor-specific/bus-specific code in
* here, but we need the start of the ISA hole (IOM_BEGIN).
*/
#define ISA_HOLE_START 0xA0000
#include <i386/isa/isa.h>
SYSCTL_NODE(_machdep, OID_AUTO, pccard, CTLFLAG_RW, 0, "pccard");
@ -592,7 +592,7 @@ allocate_driver(struct slot *sp, struct drv_desc *drvp)
*/
if (drvp->mem)
devp->isahd.id_maddr =
(caddr_t)(drvp->mem + atdevbase - ISA_HOLE_START);
(caddr_t)(drvp->mem + atdevbase - IOM_BEGIN);
else
devp->isahd.id_maddr = 0;
devp->next = sp->devices;
@ -995,7 +995,7 @@ crdioctl(dev_t dev, int cmd, caddr_t data, int fflag, struct proc *p)
*/
pccard_mem = *(unsigned long *)data;
pccard_kmem = (unsigned char *)(pccard_mem
+ atdevbase - ISA_HOLE_START);
+ atdevbase - IOM_BEGIN);
break;
/*
* Set power values
@ -1061,7 +1061,8 @@ crdpoll(dev_t dev, int events, struct proc *p)
static int
invalid_io_memory(unsigned long adr, int size)
{
if (adr < 0xC0000 || (adr+size) > 0x100000)
/* XXX - What's magic about 0xC0000?? */
if (adr < 0xC0000 || (adr+size) > IOM_END)
return(1);
return(0);
}