summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/macppc/pci/vgafb_pci.c36
-rw-r--r--sys/dev/pci/vga_pci.c41
2 files changed, 28 insertions, 49 deletions
diff --git a/sys/arch/macppc/pci/vgafb_pci.c b/sys/arch/macppc/pci/vgafb_pci.c
index ab7b6781a3c..9efc3ba93cf 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.16 2006/01/02 05:21:32 brad Exp $ */
+/* $OpenBSD: vgafb_pci.c,v 1.17 2006/03/15 20:46:15 matthieu Exp $ */
/* $NetBSD: vga_pci.c,v 1.4 1996/12/05 01:39:38 cgd Exp $ */
/*
@@ -230,12 +230,6 @@ vgafb_pci_match(parent, match, aux)
void *aux;
{
struct pci_attach_args *pa = aux;
-#ifdef SUPPORTS_NON_CONSOLE
- u_int32_t memaddr, memsize, cacheable;
- u_int32_t ioaddr, iosize;
- u_int32_t mmioaddr, mmiosize;
- int retval;
-#endif
int potential;
static int id = 0;
int myid;
@@ -278,34 +272,6 @@ vgafb_pci_match(parent, match, aux)
}
#endif
-#ifdef SUPPORTS_NON_CONSOLE
- /* ALL non-console vga support removed for now.
- * when the problems with it are resolved,
- * it can be reenabled.
- */
-
- memaddr=0xb8000; /* default to isa addresses? */
- ioaddr = 0; /* default to isa addresses? */
-
- retval = vgafb_pci_probe(pa, myid, &ioaddr, &iosize,
- &memaddr, &memsize, &cacheable, &mmioaddr, &mmiosize);
- if (retval == 0) {
- return 0;
- }
-#if 1
- printf("ioaddr %x, iosize %x, memaddr %x, memsize %x mmioaddr %x mmiosize %x\n",
- ioaddr, iosize, memaddr, memsize, mmioaddr, mmiosize);
-#endif
-
- if (!vgafb_common_probe(pa->pa_iot, pa->pa_memt, ioaddr, iosize, memaddr, memsize, mmioaddr, mmiosize))
- {
- printf("vgafb_pci_match: common_probe failed\n");
- return (0);
- }
- id++;
-
- return (1);
-#endif
return (0);
}
diff --git a/sys/dev/pci/vga_pci.c b/sys/dev/pci/vga_pci.c
index 0df6667c1da..a1d6b624109 100644
--- a/sys/dev/pci/vga_pci.c
+++ b/sys/dev/pci/vga_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vga_pci.c,v 1.20 2005/11/19 02:18:00 pedro Exp $ */
+/* $OpenBSD: vga_pci.c,v 1.21 2006/03/15 20:46:15 matthieu Exp $ */
/* $NetBSD: vga_pci.c,v 1.3 1998/06/08 06:55:58 thorpej Exp $ */
/*-
@@ -176,13 +176,8 @@ vga_pci_match(parent, match, aux)
/*
* If we might match, make sure that the card actually looks OK.
*/
-#ifdef MD_DISPLAY_ISA_IOT
- if (!vga_common_probe(MD_DISPLAY_ISA_IOT, MD_DISPLAY_ISA_MEMT))
- return (0);
-#else
if (!vga_common_probe(pa->pa_iot, pa->pa_memt))
return (0);
-#endif
return (1);
}
@@ -192,9 +187,7 @@ vga_pci_attach(parent, self, aux)
struct device *parent, *self;
void *aux;
{
-#ifndef MD_DISPLAY_ISA_IOT
struct pci_attach_args *pa = aux;
-#endif
#ifdef PCIAGP
struct vga_pci_softc *sc = (struct vga_pci_softc *)self;
const struct agp_product *ap;
@@ -259,13 +252,8 @@ vga_pci_attach(parent, self, aux)
}
#endif
printf("\n");
-#ifdef MD_DISPLAY_ISA_IOT
- vga_extended_attach(self, MD_DISPLAY_ISA_IOT, ppc_isa_membus_space,
- WSDISPLAY_TYPE_PCIVGA, vga_pci_mmap);
-#else
vga_common_attach(self, pa->pa_iot, pa->pa_memt,
WSDISPLAY_TYPE_PCIVGA);
-#endif
}
paddr_t
@@ -436,6 +424,31 @@ vga_pci_ioctl(v, cmd, addr, flag, p)
}
#ifdef PCIAGP
+void
+vga_pci_close(void *v)
+{
+ struct vga_config *vc = v;
+ struct vga_pci_softc *sc = (struct vga_pci_softc *)vc->vc_softc;
+ struct agp_memory *mem;
+
+ /*
+ * Clear out the aperture and free any
+ * outstanding memory blocks.
+ */
+ TAILQ_FOREACH(mem, &sc->sc_memory, am_link) {
+ if (mem->am_is_bound) {
+ AGP_UNBIND_MEMORY(sc, mem);
+ }
+ }
+
+ while (!TAILQ_EMPTY(&sc->sc_memory)) {
+ mem = TAILQ_FIRST(&sc->sc_memory);
+ AGP_FREE_MEMORY(sc, mem);
+ }
+
+ sc->sc_state = AGP_ACQUIRE_FREE;
+}
+
struct agp_memory *
agp_find_memory(struct vga_pci_softc *sc, int id)
{
@@ -889,4 +902,4 @@ agp_free_dmamem(bus_dma_tag_t tag, size_t size, bus_dmamap_t map,
bus_dmamem_unmap(tag, vaddr, size);
bus_dmamem_free(tag, seg, nseg);
}
-#endif
+#endif /* PCIAGP */