diff options
author | Dale Rahn <drahn@cvs.openbsd.org> | 2002-03-26 16:51:44 +0000 |
---|---|---|
committer | Dale Rahn <drahn@cvs.openbsd.org> | 2002-03-26 16:51:44 +0000 |
commit | f6989103fe456a7384cf113d99a620ac97bad79c (patch) | |
tree | 28460d8ebab1c6b6de320ead010cc55eb02b54d7 /sys/arch/macppc/pci | |
parent | 98f6aab0a210e093d82725405a0106e5f2fb129c (diff) |
Only allow valid device PAs to be mmapped.
Diffstat (limited to 'sys/arch/macppc/pci')
-rw-r--r-- | sys/arch/macppc/pci/vgafb.c | 22 | ||||
-rw-r--r-- | sys/arch/macppc/pci/vgafb_pci.c | 17 | ||||
-rw-r--r-- | sys/arch/macppc/pci/vgafbvar.h | 11 |
3 files changed, 34 insertions, 16 deletions
diff --git a/sys/arch/macppc/pci/vgafb.c b/sys/arch/macppc/pci/vgafb.c index e97cddf3385..7878c680121 100644 --- a/sys/arch/macppc/pci/vgafb.c +++ b/sys/arch/macppc/pci/vgafb.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vgafb.c,v 1.6 2002/03/14 01:26:37 millert Exp $ */ +/* $OpenBSD: vgafb.c,v 1.7 2002/03/26 16:51:43 drahn Exp $ */ /* $NetBSD: vga.c,v 1.3 1996/12/02 22:24:54 cgd Exp $ */ /* @@ -381,7 +381,7 @@ vgafb_mmap(v, offset, prot) bus_space_handle_t h; /* memsize... */ - if (offset >= 0x00000 && offset < 0x800000) /* 8MB of mem??? */ + if (offset >= 0x00000 && offset < vc->memsize) h = vc->vc_paddr + offset; /* XXX the following are probably wrong. we want physical addresses here, not virtual ones */ @@ -394,18 +394,18 @@ vgafb_mmap(v, offset, prot) else if (offset >= 0x18880000 && offset < 0x100c0000) /* 256KB of iohd */ h = vc->vc_ioh_d; - else if (offset >= 0x20000000 && offset < 0x30000000) + else if (offset >= 0x20000000 && offset < 0x20000000+vc->mmiosize) /* mmiosize... */ h = vc->vc_mmioh + (offset - 0x20000000); - else { - /* XXX - allow mapping of the actual physical - * device address, if the address is read from - * pci bus config space - */ - - /* NEEDS TO BE RESTRICTED to valid addresses for this device */ - + else if (offset >= vc->membase && (offset < vc->membase+vc->memsize)) { + /* allow mmapping of memory */ h = offset; + } else if (offset >= vc->mmiobase && + (offset < vc->mmiobase+vc->mmiosize)) { + /* allow mmapping of mmio space */ + h = offset; + } else { + h = -1; } #ifdef alpha diff --git a/sys/arch/macppc/pci/vgafb_pci.c b/sys/arch/macppc/pci/vgafb_pci.c index 0b98fe61c56..352e8332fab 100644 --- a/sys/arch/macppc/pci/vgafb_pci.c +++ b/sys/arch/macppc/pci/vgafb_pci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vgafb_pci.c,v 1.3 2002/03/14 01:26:37 millert Exp $ */ +/* $OpenBSD: vgafb_pci.c,v 1.4 2002/03/26 16:51:43 drahn Exp $ */ /* $NetBSD: vga_pci.c,v 1.4 1996/12/05 01:39:38 cgd Exp $ */ /* @@ -104,7 +104,7 @@ vgafb_pci_probe(pa, id, ioaddr, iosize, memaddr, memsize, cacheable, mmioaddr, m *iosize = 0x0; *memsize = 0x0; *mmiosize = 0x0; - for (i = 0x10; i < 0x18; i += 4) { + for (i = 0x10; i <= 0x18; i += 4) { #ifdef DEBUG_VGAFB printf("vgafb confread %x %x\n", i, pci_conf_read(pc, pa->pa_tag, i)); @@ -135,7 +135,7 @@ vgafb_pci_probe(pa, id, ioaddr, iosize, memaddr, memsize, cacheable, mmioaddr, m } if (size == 0) { /* ignore this entry */ - }else if (size <= (64 * 1024)) { + }else if (size <= (1024 * 1024)) { #ifdef DEBUG_VGAFB printf("vgafb_pci_probe: mem %x addr %x size %x iosize %x\n", i, addr, size, *iosize); @@ -143,6 +143,10 @@ vgafb_pci_probe(pa, id, ioaddr, iosize, memaddr, memsize, cacheable, mmioaddr, m if (*mmiosize == 0) { /* this is mmio, not memory */ *mmioaddr = addr; + if (size < 0x80000) { + /* ATI driver maps 0x80000, grr */ + size = 0x80000; + } *mmiosize = size; /* need skew in here for io memspace */ } @@ -305,6 +309,7 @@ vgafb_pci_attach(parent, self, aux) vgafb_pci_probe(pa, myid, &ioaddr, &iosize, &memaddr, &memsize, &cacheable, &mmioaddr, &mmiosize); + console = (!bcmp(&pa->pa_tag, &vgafb_pci_console_tag, sizeof(pa->pa_tag))); if (console) vc = sc->sc_vc = &vgafb_pci_console_vc; @@ -318,6 +323,12 @@ vgafb_pci_attach(parent, self, aux) } vc->vc_mmap = vgafbpcimmap; vc->vc_ioctl = vgafbpciioctl; + vc->iobase = ioaddr; + vc->iosize = iosize; + vc->membase = memaddr; + vc->memsize = memsize; + vc->mmiobase = mmioaddr; + vc->mmiosize = mmiosize; sc->sc_pcitag = pa->pa_tag; diff --git a/sys/arch/macppc/pci/vgafbvar.h b/sys/arch/macppc/pci/vgafbvar.h index 79e5042655f..58ca2de2305 100644 --- a/sys/arch/macppc/pci/vgafbvar.h +++ b/sys/arch/macppc/pci/vgafbvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: vgafbvar.h,v 1.4 2002/03/14 03:15:56 millert Exp $ */ +/* $OpenBSD: vgafbvar.h,v 1.5 2002/03/26 16:51:43 drahn Exp $ */ /* $NetBSD: vgavar.h,v 1.2 1996/11/23 06:06:43 cgd Exp $ */ /* @@ -59,7 +59,14 @@ struct vgafb_config { #endif struct rcons dc_rcons; /* raster blitter control info */ - + bus_addr_t iobase; + bus_size_t iosize; + + bus_addr_t membase; + bus_size_t memsize; + + bus_addr_t mmiobase; + bus_size_t mmiosize; }; int vgafb_common_probe(bus_space_tag_t, bus_space_tag_t, |