summaryrefslogtreecommitdiff
path: root/sys/arch/amd64
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/amd64')
-rw-r--r--sys/arch/amd64/pci/iommu.c36
1 files changed, 15 insertions, 21 deletions
diff --git a/sys/arch/amd64/pci/iommu.c b/sys/arch/amd64/pci/iommu.c
index e6f8476d4db..993ed28d72f 100644
--- a/sys/arch/amd64/pci/iommu.c
+++ b/sys/arch/amd64/pci/iommu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: iommu.c,v 1.17 2007/02/09 02:58:10 jason Exp $ */
+/* $OpenBSD: iommu.c,v 1.18 2007/02/09 04:48:10 jason Exp $ */
/*
* Copyright (c) 2005 Jason L. Wright (jason@thought.net)
@@ -128,9 +128,8 @@ void amdgart_invalidate_wait(void);
void amdgart_invalidate(void);
void amdgart_probe(struct pcibus_attach_args *);
void amdgart_dumpregs(void);
-int amdgart_iommu_map(bus_dmamap_t, struct extent *, paddr_t,
- paddr_t *, psize_t);
-int amdgart_iommu_unmap(struct extent *, paddr_t, psize_t);
+int amdgart_iommu_map(bus_dmamap_t, struct extent *, bus_dma_segment_t *);
+int amdgart_iommu_unmap(struct extent *, bus_dma_segment_t *);
int amdgart_reload(struct extent *, bus_dmamap_t);
int amdgart_ok(pci_chipset_tag_t, pcitag_t);
void amdgart_initpt(struct amdgart_softc *, u_long);
@@ -421,27 +420,21 @@ amdgart_reload(struct extent *ex, bus_dmamap_t dmam)
int i, j, err;
for (i = 0; i < dmam->dm_nsegs; i++) {
- paddr_t opa, npa;
psize_t len;
- opa = dmam->dm_segs[i].ds_addr;
len = dmam->dm_segs[i].ds_len;
- err = amdgart_iommu_map(dmam, ex, opa, &npa, len);
+ err = amdgart_iommu_map(dmam, ex, &dmam->dm_segs[i]);
if (err) {
for (j = 0; j < i - 1; j++)
- amdgart_iommu_unmap(ex,
- dmam->dm_segs[j].ds_addr,
- dmam->dm_segs[j].ds_len);
+ amdgart_iommu_unmap(ex, &dmam->dm_segs[j]);
return (err);
}
- dmam->dm_segs[i].ds_addr = npa;
}
return (0);
}
int
-amdgart_iommu_map(bus_dmamap_t dmam, struct extent *ex, paddr_t opa,
- paddr_t *npa, psize_t len)
+amdgart_iommu_map(bus_dmamap_t dmam, struct extent *ex, bus_dma_segment_t *seg)
{
paddr_t base, end, idx;
psize_t alen;
@@ -449,9 +442,10 @@ amdgart_iommu_map(bus_dmamap_t dmam, struct extent *ex, paddr_t opa,
int err, s;
u_int32_t pgno, flags;
- base = trunc_page(opa);
- end = roundup(opa + len, PAGE_SIZE);
+ base = trunc_page(seg->ds_addr);
+ end = roundup(seg->ds_addr + seg->ds_len, PAGE_SIZE);
alen = end - base;
+
s = splhigh();
err = extent_alloc(ex, alen, PAGE_SIZE, 0, dmam->_dm_boundary,
EX_NOWAIT, &res);
@@ -460,7 +454,8 @@ amdgart_iommu_map(bus_dmamap_t dmam, struct extent *ex, paddr_t opa,
printf("GART: extent_alloc %d\n", err);
return (err);
}
- *npa = res | (opa & PGOFSET);
+
+ seg->ds_addr = res | (seg->ds_addr & PGOFSET);
for (idx = 0; idx < alen; idx += PAGE_SIZE) {
pgno = ((res + idx) - amdgart_softcs[0].g_pa) >> PGSHIFT;
@@ -474,15 +469,15 @@ amdgart_iommu_map(bus_dmamap_t dmam, struct extent *ex, paddr_t opa,
}
int
-amdgart_iommu_unmap(struct extent *ex, paddr_t pa, psize_t len)
+amdgart_iommu_unmap(struct extent *ex, bus_dma_segment_t *seg)
{
paddr_t base, end, idx;
psize_t alen;
int err, s;
u_int32_t pgno;
- base = trunc_page(pa);
- end = roundup(pa + len, PAGE_SIZE);
+ base = trunc_page(seg->ds_addr);
+ end = roundup(seg->ds_addr + seg->ds_len, PAGE_SIZE);
alen = end - base;
/*
@@ -598,8 +593,7 @@ amdgart_dmamap_unload(bus_dma_tag_t tag, bus_dmamap_t dmam)
int i;
for (i = 0; i < dmam->dm_nsegs; i++)
- amdgart_iommu_unmap(amdgart_softcs[0].g_ex,
- dmam->dm_segs[i].ds_addr, dmam->dm_segs[i].ds_len);
+ amdgart_iommu_unmap(amdgart_softcs[0].g_ex, &dmam->dm_segs[i]);
/* XXX should we invalidate here? */
bus_dmamap_unload(amdgart_softcs[0].g_dmat, dmam);
}