summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/amd64/pci/agp_machdep.c130
-rw-r--r--sys/arch/i386/pci/agp_machdep.c130
2 files changed, 2 insertions, 258 deletions
diff --git a/sys/arch/amd64/pci/agp_machdep.c b/sys/arch/amd64/pci/agp_machdep.c
index 93dbaece57e..6d3abfa49e6 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.8 2013/12/07 10:57:06 kettenis Exp $ */
+/* $OpenBSD: agp_machdep.c,v 1.9 2013/12/09 19:52:11 kettenis Exp $ */
/*
* Copyright (c) 2008 - 2009 Owain G. Ainsworth <oga@openbsd.org>
@@ -56,15 +56,6 @@
#include <uvm/uvm.h>
-#include "intagp.h"
-
-/* bus_dma functions */
-
-#if NINTAGP > 0
-void intagp_dma_sync(bus_dma_tag_t, bus_dmamap_t, bus_addr_t,
- bus_size_t, int);
-#endif
-
void
agp_flush_cache(void)
{
@@ -129,122 +120,3 @@ agp_unmap_subregion(struct agp_map *map, bus_space_handle_t bsh,
{
/* subregion doesn't need unmapping, do nothing */
}
-
-/*
- * ick ick ick. However, the rest of this driver is supposedly MI (though
- * they only exist on x86), so this can't be in dev/pci.
- */
-
-#if NINTAGP > 0
-
-/*
- * bus_dmamap_sync routine for intagp.
- *
- * This is tailored to the usage that drm with the GEM memory manager
- * will be using, since intagp is for intel IGD, and thus shouldn't be
- * used for anything other than gpu-based work. Essentially for the intel GEM
- * driver we use bus_dma as an abstraction to convert our memory into a gtt
- * address and deal with any cache incoherencies that we create.
- *
- * We use the cflush instruction to deal with clearing the caches, since our
- * cache is physically indexed, we can even map then clear the page and it'll
- * work. on i386 we need to check for the presence of cflush() in cpuid,
- * however, all cpus that have a new enough intel GMCH should be suitable.
- */
-void
-intagp_dma_sync(bus_dma_tag_t tag, bus_dmamap_t dmam,
- bus_addr_t offset, bus_size_t size, int ops)
-{
- bus_dma_segment_t *segp;
- struct sg_page_map *spm;
- void *addr;
- paddr_t pa;
- bus_addr_t poff, endoff, soff;
-
-#ifdef DIAGNOSTIC
- if ((ops & (BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE)) != 0 &&
- (ops & (BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE)) != 0)
- panic("agp_dmamap_sync: mix PRE and POST");
- if (offset >= dmam->dm_mapsize)
- panic("_intagp_dma_sync: bad offset %lu (size = %lu)",
- offset, dmam->dm_mapsize);
- if (size == 0 || (offset + size) > dmam->dm_mapsize)
- panic("intagp_dma_sync: bad length");
-#endif /* DIAGNOSTIC */
-
- /* Coherent mappings need no sync. */
- if (dmam->_dm_flags & BUS_DMA_COHERENT)
- return;
-
- /*
- * We need to clflush the object cache in all cases but postwrite.
- *
- * - Due to gpu incoherency, postread we need to flush speculative
- * reads (which are not written back on intel cpus).
- *
- * - preread we need to flush data which will very soon be stale from
- * the caches
- *
- * - prewrite we need to make sure our data hits the memory before the
- * gpu hoovers it up.
- *
- * The chipset also may need flushing, but that fits badly into
- * bus_dma and it done in the driver.
- */
- soff = trunc_page(offset);
- endoff = round_page(offset + size);
- if (ops & BUS_DMASYNC_POSTREAD || ops & BUS_DMASYNC_PREREAD ||
- ops & BUS_DMASYNC_PREWRITE) {
- if (curcpu()->ci_cflushsz == 0) {
- /* save some wbinvd()s. we're MD anyway so it's ok */
- wbinvd();
- return;
- }
-
- mfence();
- spm = dmam->_dm_cookie;
- switch (spm->spm_buftype) {
- case BUS_BUFTYPE_LINEAR:
- addr = spm->spm_origbuf + soff;
- while (soff < endoff) {
- pmap_flush_cache((vaddr_t)addr, PAGE_SIZE);
- soff += PAGE_SIZE;
- addr += PAGE_SIZE;
- } break;
- case BUS_BUFTYPE_RAW:
- segp = (bus_dma_segment_t *)spm->spm_origbuf;
- poff = 0;
-
- while (poff < soff) {
- if (poff + segp->ds_len > soff)
- break;
- poff += segp->ds_len;
- segp++;
- }
- /* first time round may not start at seg beginning */
- pa = segp->ds_addr + (soff - poff);
- while (poff < endoff) {
- for (; pa < segp->ds_addr + segp->ds_len &&
- poff < endoff; pa += PAGE_SIZE) {
- pmap_flush_page(pa);
- poff += PAGE_SIZE;
- }
- segp++;
- if (poff < endoff)
- pa = segp->ds_addr;
- }
- break;
- /* You do not want to load mbufs or uios onto a graphics card */
- case BUS_BUFTYPE_MBUF:
- /* FALLTHROUGH */
- case BUS_BUFTYPE_UIO:
- /* FALLTHROUGH */
- default:
- panic("intagp_dmamap_sync: bad buftype %d",
- spm->spm_buftype);
-
- }
- mfence();
- }
-}
-#endif /* NINTAGP > 0 */
diff --git a/sys/arch/i386/pci/agp_machdep.c b/sys/arch/i386/pci/agp_machdep.c
index ff33f36ea88..259d652627c 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.14 2013/12/07 10:57:06 kettenis Exp $ */
+/* $OpenBSD: agp_machdep.c,v 1.15 2013/12/09 19:52:11 kettenis Exp $ */
/*
* Copyright (c) 2008 - 2009 Owain G. Ainsworth <oga@openbsd.org>
@@ -56,15 +56,6 @@
#include <uvm/uvm.h>
-#include "intagp.h"
-
-/* bus_dma functions */
-
-#if NINTAGP > 0
-void intagp_dma_sync(bus_dma_tag_t, bus_dmamap_t, bus_addr_t,
- bus_size_t, int);
-#endif
-
void
agp_flush_cache(void)
{
@@ -170,122 +161,3 @@ agp_unmap_subregion(struct agp_map *map, bus_space_handle_t bsh,
{
return (_bus_space_unmap(map->bst, bsh, size, NULL));
}
-
-/*
- * ick ick ick. However, the rest of this driver is supposedly MI (though
- * they only exist on x86), so this can't be in dev/pci.
- */
-
-#if NINTAGP > 0
-
-/*
- * bus_dmamap_sync routine for intagp.
- *
- * This is tailored to the usage that drm with the GEM memory manager
- * will be using, since intagp is for intel IGD, and thus shouldn't be
- * used for anything other than gpu-based work. Essentially for the intel GEM
- * driver we use bus_dma as an abstraction to convert our memory into a gtt
- * address and deal with any cache incoherencies that we create.
- *
- * We use the cflush instruction to deal with clearing the caches, since our
- * cache is physically indexed, we can even map then clear the page and it'll
- * work. on i386 we need to check for the presence of cflush() in cpuid,
- * however, all cpus that have a new enough intel GMCH should be suitable.
- */
-void
-intagp_dma_sync(bus_dma_tag_t tag, bus_dmamap_t dmam,
- bus_addr_t offset, bus_size_t size, int ops)
-{
- bus_dma_segment_t *segp;
- struct sg_page_map *spm;
- void *addr;
- paddr_t pa;
- bus_addr_t poff, endoff, soff;
-
-#ifdef DIAGNOSTIC
- if ((ops & (BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE)) != 0 &&
- (ops & (BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE)) != 0)
- panic("agp_dmamap_sync: mix PRE and POST");
- if (offset >= dmam->dm_mapsize)
- panic("_intagp_dma_sync: bad offset %lu (size = %lu)",
- offset, dmam->dm_mapsize);
- if (size == 0 || (offset + size) > dmam->dm_mapsize)
- panic("intagp_dma_sync: bad length");
-#endif /* DIAGNOSTIC */
-
- /* Coherent mappings need no sync. */
- if (dmam->_dm_flags & BUS_DMA_COHERENT)
- return;
-
- /*
- * We need to clflush the object cache in all cases but postwrite.
- *
- * - Due to gpu incoherency, postread we need to flush speculative
- * reads (which are not written back on intel cpus).
- *
- * - preread we need to flush data which will very soon be stale from
- * the caches
- *
- * - prewrite we need to make sure our data hits the memory before the
- * gpu hoovers it up.
- *
- * The chipset also may need flushing, but that fits badly into
- * bus_dma and it done in the driver.
- */
- soff = trunc_page(offset);
- endoff = round_page(offset + size);
- if (ops & BUS_DMASYNC_POSTREAD || ops & BUS_DMASYNC_PREREAD ||
- ops & BUS_DMASYNC_PREWRITE) {
- if (curcpu()->ci_cflushsz == 0) {
- /* save some wbinvd()s. we're MD anyway so it's ok */
- wbinvd();
- return;
- }
-
- mfence();
- spm = dmam->_dm_cookie;
- switch (spm->spm_buftype) {
- case BUS_BUFTYPE_LINEAR:
- addr = spm->spm_origbuf + soff;
- while (soff < endoff) {
- pmap_flush_cache((vaddr_t)addr, PAGE_SIZE);
- soff += PAGE_SIZE;
- addr += PAGE_SIZE;
- } break;
- case BUS_BUFTYPE_RAW:
- segp = (bus_dma_segment_t *)spm->spm_origbuf;
- poff = 0;
-
- while (poff < soff) {
- if (poff + segp->ds_len > soff)
- break;
- poff += segp->ds_len;
- segp++;
- }
- /* first time round may not start at seg beginning */
- pa = segp->ds_addr + (soff - poff);
- while (poff < endoff) {
- for (; pa < segp->ds_addr + segp->ds_len &&
- poff < endoff; pa += PAGE_SIZE) {
- pmap_flush_page(pa);
- poff += PAGE_SIZE;
- }
- segp++;
- if (poff < endoff)
- pa = segp->ds_addr;
- }
- break;
- /* You do not want to load mbufs or uios onto a graphics card */
- case BUS_BUFTYPE_MBUF:
- /* FALLTHROUGH */
- case BUS_BUFTYPE_UIO:
- /* FALLTHROUGH */
- default:
- panic("intagp_dmamap_sync: bad buftype %d",
- spm->spm_buftype);
-
- }
- mfence();
- }
-}
-#endif /* NINTAGP > 0 */