summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@cvs.openbsd.org>2013-12-07 10:57:07 +0000
committerMark Kettenis <kettenis@cvs.openbsd.org>2013-12-07 10:57:07 +0000
commit1820c3df1270e72fb9d54df70cb4a413d824b890 (patch)
tree67f9b0ffb192a4f6a8a6b3e99d11f373ecbbcd6a /sys
parent06afa977e287dd60c70b0a8b46de85ed95041cb5 (diff)
Remove the agp-specific bus_dma code. It is no longer used now that
inteldrm(4) manages the GTT by itself. ok miod@
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/amd64/pci/agp_machdep.c105
-rw-r--r--sys/arch/i386/pci/agp_machdep.c105
-rw-r--r--sys/dev/pci/agpvar.h9
3 files changed, 3 insertions, 216 deletions
diff --git a/sys/arch/amd64/pci/agp_machdep.c b/sys/arch/amd64/pci/agp_machdep.c
index b59377e28f2..93dbaece57e 100644
--- a/sys/arch/amd64/pci/agp_machdep.c
+++ b/sys/arch/amd64/pci/agp_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: agp_machdep.c,v 1.7 2013/03/17 21:49:00 kettenis Exp $ */
+/* $OpenBSD: agp_machdep.c,v 1.8 2013/12/07 10:57:06 kettenis Exp $ */
/*
* Copyright (c) 2008 - 2009 Owain G. Ainsworth <oga@openbsd.org>
@@ -77,109 +77,6 @@ agp_flush_cache_range(vaddr_t va, vsize_t sz)
pmap_flush_cache(va, sz);
}
-/*
- * functions for bus_dma used by drm for GEM
- *
- * We use the sg_dma backend (also used by iommu) to provide the actual
- * implementation, so all we need provide is the magic to create the tag, and
- * the appropriate callbacks.
- *
- * We give the backend drivers a chance to honour the bus_dma flags, some of
- * these may be used, for example to provide snooped mappings (intagp).
- * For intagp at least, we honour the BUS_DMA_COHERENT flag, though it is not
- * used often, and is * technically to be used for dmamem_map, we use it for
- * dmamap_load since adding coherency involes flags to the gtt pagetables.
- * We only use it for very special circumstances since when a GTT mapping is
- * set to coherent, the cpu can't read or write through the gtt aperture.
- *
- * Currently, since the userland agp driver still needs to access the gart, we
- * only do bus_dma for a section that we've been told is ours, hence the need
- * for the init function at present.
- */
-
-int
-agp_bus_dma_init(struct agp_softc *sc, bus_addr_t start, bus_addr_t end,
- bus_dma_tag_t *dmat)
-{
- struct bus_dma_tag *tag;
- struct sg_cookie *cookie;
-
- /*
- * XXX add agp map into the main queue that takes up our chunk of
- * GTT space to prevent the userland api stealing any of it.
- */
- if ((tag = malloc(sizeof(*tag), M_DEVBUF,
- M_WAITOK | M_CANFAIL)) == NULL)
- return (ENOMEM);
-
- if ((cookie = sg_dmatag_init("agpgtt", sc->sc_chipc, start, end - start,
- sc->sc_methods->bind_page, sc->sc_methods->unbind_page,
- sc->sc_methods->flush_tlb)) == NULL) {
- free(tag, M_DEVBUF);
- return (ENOMEM);
- }
-
- tag->_cookie = cookie;
- tag->_dmamap_create = sg_dmamap_create;
- tag->_dmamap_destroy = sg_dmamap_destroy;
- tag->_dmamap_load = sg_dmamap_load;
- tag->_dmamap_load_mbuf = sg_dmamap_load_mbuf;
- tag->_dmamap_load_uio = sg_dmamap_load_uio;
- tag->_dmamap_load_raw = sg_dmamap_load_raw;
- tag->_dmamap_unload = sg_dmamap_unload;
- tag->_dmamem_alloc = sg_dmamem_alloc;
- tag->_dmamem_free = _bus_dmamem_free;
- tag->_dmamem_map = _bus_dmamem_map;
- tag->_dmamem_unmap = _bus_dmamem_unmap;
- tag->_dmamem_mmap = _bus_dmamem_mmap;
-
- /* Driver may need special sync handling */
- if (sc->sc_methods->dma_sync != NULL) {
- tag->_dmamap_sync = sc->sc_methods->dma_sync;
- } else {
- tag->_dmamap_sync = _bus_dmamap_sync;
- }
-
- *dmat = tag;
- return (0);
-}
-
-void
-agp_bus_dma_destroy(struct agp_softc *sc, bus_dma_tag_t dmat)
-{
- struct sg_cookie *cookie = dmat->_cookie;
- bus_addr_t offset;
-
-
- /*
- * XXX clear up blocker queue
- */
-
- /*
- * some backends use a dummy page to avoid errors on prefetching, etc.
- * make sure that all of them are clean.
- */
- for (offset = cookie->sg_ex->ex_start;
- offset < cookie->sg_ex->ex_end; offset += PAGE_SIZE)
- sc->sc_methods->unbind_page(sc->sc_chipc, offset);
-
- sg_dmatag_destroy(cookie);
- free(dmat, M_DEVBUF);
-}
-
-void
-agp_bus_dma_set_alignment(bus_dma_tag_t tag, bus_dmamap_t dmam,
- u_long alignment)
-{
- sg_dmamap_set_alignment(tag, dmam, alignment);
-}
-
-void
-agp_bus_dma_rebind(bus_dma_tag_t tag, bus_dmamap_t dmam, int flags)
-{
- sg_dmamap_reload(tag, dmam, flags);
-}
-
struct agp_map {
bus_space_tag_t bst;
bus_space_handle_t bsh;
diff --git a/sys/arch/i386/pci/agp_machdep.c b/sys/arch/i386/pci/agp_machdep.c
index c6634a99dc4..ff33f36ea88 100644
--- a/sys/arch/i386/pci/agp_machdep.c
+++ b/sys/arch/i386/pci/agp_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: agp_machdep.c,v 1.13 2013/03/17 21:49:00 kettenis Exp $ */
+/* $OpenBSD: agp_machdep.c,v 1.14 2013/12/07 10:57:06 kettenis Exp $ */
/*
* Copyright (c) 2008 - 2009 Owain G. Ainsworth <oga@openbsd.org>
@@ -77,109 +77,6 @@ agp_flush_cache_range(vaddr_t va, vsize_t sz)
pmap_flush_cache(va, sz);
}
-/*
- * functions for bus_dma used by drm for GEM
- *
- * We use the sg_dma backend (also used by iommu) to provide the actual
- * implementation, so all we need provide is the magic to create the tag, and
- * the appropriate callbacks.
- *
- * We give the backend drivers a chance to honour the bus_dma flags, some of
- * these may be used, for example to provide snooped mappings (intagp).
- * For intagp at least, we honour the BUS_DMA_COHERENT flag, though it is not
- * used often, and is * technically to be used for dmamem_map, we use it for
- * dmamap_load since adding coherency involes flags to the gtt pagetables.
- * We only use it for very special circumstances since when a GTT mapping is
- * set to coherent, the cpu can't read or write through the gtt aperture.
- *
- * Currently, since the userland agp driver still needs to access the gart, we
- * only do bus_dma for a section that we've been told is ours, hence the need
- * for the init function at present.
- */
-
-int
-agp_bus_dma_init(struct agp_softc *sc, bus_addr_t start, bus_addr_t end,
- bus_dma_tag_t *dmat)
-{
- struct bus_dma_tag *tag;
- struct sg_cookie *cookie;
-
- /*
- * XXX add agp map into the main queue that takes up our chunk of
- * GTT space to prevent the userland api stealing any of it.
- */
- if ((tag = malloc(sizeof(*tag), M_DEVBUF,
- M_WAITOK | M_CANFAIL)) == NULL)
- return (ENOMEM);
-
- if ((cookie = sg_dmatag_init("agpgtt", sc->sc_chipc, start, end - start,
- sc->sc_methods->bind_page, sc->sc_methods->unbind_page,
- sc->sc_methods->flush_tlb)) == NULL) {
- free(tag, M_DEVBUF);
- return (ENOMEM);
- }
-
- tag->_cookie = cookie;
- tag->_dmamap_create = sg_dmamap_create;
- tag->_dmamap_destroy = sg_dmamap_destroy;
- tag->_dmamap_load = sg_dmamap_load;
- tag->_dmamap_load_mbuf = sg_dmamap_load_mbuf;
- tag->_dmamap_load_uio = sg_dmamap_load_uio;
- tag->_dmamap_load_raw = sg_dmamap_load_raw;
- tag->_dmamap_unload = sg_dmamap_unload;
- tag->_dmamem_alloc = sg_dmamem_alloc;
- tag->_dmamem_free = _bus_dmamem_free;
- tag->_dmamem_map = _bus_dmamem_map;
- tag->_dmamem_unmap = _bus_dmamem_unmap;
- tag->_dmamem_mmap = _bus_dmamem_mmap;
-
- /* Driver may need special sync handling */
- if (sc->sc_methods->dma_sync != NULL) {
- tag->_dmamap_sync = sc->sc_methods->dma_sync;
- } else {
- tag->_dmamap_sync = NULL;
- }
-
- *dmat = tag;
- return (0);
-}
-
-void
-agp_bus_dma_destroy(struct agp_softc *sc, bus_dma_tag_t dmat)
-{
- struct sg_cookie *cookie = dmat->_cookie;
- bus_addr_t offset;
-
-
- /*
- * XXX clear up blocker queue
- */
-
- /*
- * some backends use a dummy page to avoid errors on prefetching, etc.
- * make sure that all of them are clean.
- */
- for (offset = cookie->sg_ex->ex_start;
- offset < cookie->sg_ex->ex_end; offset += PAGE_SIZE)
- sc->sc_methods->unbind_page(sc->sc_chipc, offset);
-
- sg_dmatag_destroy(cookie);
- free(dmat, M_DEVBUF);
-}
-
-void
-agp_bus_dma_set_alignment(bus_dma_tag_t tag, bus_dmamap_t dmam,
- u_long alignment)
-{
- sg_dmamap_set_alignment(tag, dmam, alignment);
-}
-
-void
-agp_bus_dma_rebind(bus_dma_tag_t tag, bus_dmamap_t dmam, int flags)
-{
- sg_dmamap_reload(tag, dmam, flags);
-}
-
struct agp_map {
bus_space_tag_t bst;
bus_addr_t addr;
diff --git a/sys/dev/pci/agpvar.h b/sys/dev/pci/agpvar.h
index 8e1eda3a271..36f9d2de7ee 100644
--- a/sys/dev/pci/agpvar.h
+++ b/sys/dev/pci/agpvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: agpvar.h,v 1.27 2013/04/14 19:04:37 kettenis Exp $ */
+/* $OpenBSD: agpvar.h,v 1.28 2013/12/07 10:57:06 kettenis Exp $ */
/* $NetBSD: agpvar.h,v 1.4 2001/10/01 21:54:48 fvdl Exp $ */
/*-
@@ -189,13 +189,6 @@ void agp_free_dmamem(bus_dma_tag_t, size_t, bus_dmamap_t,
int agpdev_print(void *, const char *);
int agpbus_probe(struct agp_attach_args *aa);
-int agp_bus_dma_init(struct agp_softc *, bus_addr_t, bus_addr_t,
- bus_dma_tag_t *);
-void agp_bus_dma_destroy(struct agp_softc *, bus_dma_tag_t);
-void agp_bus_dma_set_alignment(bus_dma_tag_t, bus_dmamap_t,
- u_long);
-void agp_bus_dma_rebind(bus_dma_tag_t, bus_dmamap_t, int);
-
void *agp_map(struct agp_softc *, bus_addr_t, bus_size_t,
bus_space_handle_t *);
void agp_unmap(struct agp_softc *, void *, size_t, bus_space_handle_t);