summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorHenric Jungheim <henric@cvs.openbsd.org>2003-06-11 04:00:12 +0000
committerHenric Jungheim <henric@cvs.openbsd.org>2003-06-11 04:00:12 +0000
commitf04cb9ef520e6182c25ddcf08af3c908a4c4e6e5 (patch)
tree05b8d1a63405d053c6fb1ec8f75c4233ee1ae5bf /sys/arch
parentd0449284a5d9ab063aac52134b6972df7e393109 (diff)
It is important not to forget "membar(MemIssue)". Got missed
when extracting the minimal diff for the previous iommu change. ok jason@
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc64/dev/iommu.c54
1 files changed, 34 insertions, 20 deletions
diff --git a/sys/arch/sparc64/dev/iommu.c b/sys/arch/sparc64/dev/iommu.c
index 2ee311b4a4e..6cdda01bf10 100644
--- a/sys/arch/sparc64/dev/iommu.c
+++ b/sys/arch/sparc64/dev/iommu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: iommu.c,v 1.31 2003/06/11 03:16:12 henric Exp $ */
+/* $OpenBSD: iommu.c,v 1.32 2003/06/11 04:00:11 henric Exp $ */
/* $NetBSD: iommu.c,v 1.47 2002/02/08 20:03:45 eeh Exp $ */
/*
@@ -96,6 +96,8 @@ int iommu_iomap_unload_map(struct iommu_state *, struct iommu_map_state *);
struct iommu_map_state *iommu_iomap_create(int);
void iommu_iomap_destroy(struct iommu_map_state *);
void iommu_iomap_clear_pages(struct iommu_map_state *);
+void _iommu_dvmamap_sync(bus_dma_tag_t, bus_dma_tag_t, bus_dmamap_t,
+ bus_addr_t, bus_size_t, int);
/*
* Initiate an STC entry flush.
@@ -1467,7 +1469,7 @@ iommu_dvmamap_print_map(bus_dma_tag_t t, struct iommu_state *is,
}
void
-iommu_dvmamap_sync(bus_dma_tag_t t, bus_dma_tag_t t0, bus_dmamap_t map,
+_iommu_dvmamap_sync(bus_dma_tag_t t, bus_dma_tag_t t0, bus_dmamap_t map,
bus_addr_t offset, bus_size_t len, int ops)
{
struct iommu_state *is;
@@ -1476,27 +1478,9 @@ iommu_dvmamap_sync(bus_dma_tag_t t, bus_dma_tag_t t0, bus_dmamap_t map,
bus_size_t count;
int i, needsflush = 0;
-#ifdef DEBUG
- if (ims == NULL)
- panic("iommu_dvmamap_sync: null map state");
- if (ims->ims_sb == NULL)
- panic("iommu_dvmamap_sync: null sb");
- if (ims->ims_sb->sb_iommu == NULL)
- panic("iommu_dvmamap_sync: null iommu");
-#endif /* DEBUG */
-
sb = ims->ims_sb;
is = sb->sb_iommu;
- if ((ims->ims_flags & IOMMU_MAP_STREAM) == 0 || (len == 0))
- return;
-
- if (ops & (BUS_DMASYNC_PREREAD | BUS_DMASYNC_POSTWRITE))
- return;
-
- if ((ops & (BUS_DMASYNC_POSTREAD | BUS_DMASYNC_PREWRITE)) == 0)
- return;
-
for (i = 0; i < map->dm_nsegs; i++) {
if (offset < map->dm_segs[i].ds_len)
break;
@@ -1514,13 +1498,43 @@ iommu_dvmamap_sync(bus_dma_tag_t t, bus_dma_tag_t t0, bus_dmamap_t map,
len -= count;
}
+#ifdef DIAGNOSTIC
if (i == map->dm_nsegs && len > 0)
panic("iommu_dvmamap_sync: leftover %lu", len);
+#endif
if (needsflush)
iommu_strbuf_flush_done(ims);
}
+void
+iommu_dvmamap_sync(bus_dma_tag_t t, bus_dma_tag_t t0, bus_dmamap_t map,
+ bus_addr_t offset, bus_size_t len, int ops)
+{
+ struct iommu_map_state *ims = map->_dm_cookie;
+
+#ifdef DIAGNOSTIC
+ if (ims == NULL)
+ panic("iommu_dvmamap_sync: null map state");
+ if (ims->ims_sb == NULL)
+ panic("iommu_dvmamap_sync: null sb");
+ if (ims->ims_sb->sb_iommu == NULL)
+ panic("iommu_dvmamap_sync: null iommu");
+#endif
+ if (len == 0)
+ return;
+
+ if (ops & BUS_DMASYNC_PREWRITE)
+ membar(MemIssue);
+
+ if ((ims->ims_flags & IOMMU_MAP_STREAM) &&
+ (ops & (BUS_DMASYNC_POSTREAD | BUS_DMASYNC_PREWRITE)))
+ _iommu_dvmamap_sync(t, t0, map, offset, len, ops);
+
+ if (ops & BUS_DMASYNC_POSTREAD)
+ membar(MemIssue);
+}
+
/*
* Flush an individual dma segment, returns non-zero if the streaming buffers
* need flushing afterwards.