summaryrefslogtreecommitdiff
path: root/sys/dev/pci/drm
diff options
context:
space:
mode:
authorOwain Ainsworth <oga@cvs.openbsd.org>2009-02-15 19:54:00 +0000
committerOwain Ainsworth <oga@cvs.openbsd.org>2009-02-15 19:54:00 +0000
commitbe17f950b28ed994c2a8755fac99beee62ab8f67 (patch)
treee77bcbce89598e7702ba4d205997ae668b382e8a /sys/dev/pci/drm
parent298391c1d66394b015b45d4bd7c17dfe2c0efb01 (diff)
Convert machdrm over to new dmamem api.
Diffstat (limited to 'sys/dev/pci/drm')
-rw-r--r--sys/dev/pci/drm/mach64_dma.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/sys/dev/pci/drm/mach64_dma.c b/sys/dev/pci/drm/mach64_dma.c
index c8fe9974beb..581feb7b9e4 100644
--- a/sys/dev/pci/drm/mach64_dma.c
+++ b/sys/dev/pci/drm/mach64_dma.c
@@ -821,7 +821,7 @@ int mach64_add_hostdata_buf_to_ring(drm_mach64_private_t *dev_priv,
static int mach64_bm_dma_test(struct drm_device * dev)
{
drm_mach64_private_t *dev_priv = dev->dev_private;
- drm_dma_handle_t *cpu_addr_dmah;
+ struct drm_dmamem *cpu_addr_dmah;
u32 data_addr;
u32 *table, *data;
u32 expected[2];
@@ -834,14 +834,14 @@ static int mach64_bm_dma_test(struct drm_device * dev)
/* FIXME: get a dma buffer from the freelist here */
DRM_DEBUG("Allocating data memory ...\n");
- cpu_addr_dmah =
- drm_pci_alloc(dev->dmat, 0x1000, 0x1000, 0xfffffffful);
- if (!cpu_addr_dmah) {
+ cpu_addr_dmah = drm_dmamem_alloc(dev->dmat, 0x1000, 0x1000, 1,
+ 0x1000, 0, 0);
+ if (cpu_addr_dmah == NULL) {
DRM_INFO("data-memory allocation failed!\n");
return ENOMEM;
} else {
- data = (u32 *) cpu_addr_dmah->vaddr;
- data_addr = (u32) cpu_addr_dmah->busaddr;
+ data = (u_int32_t *)cpu_addr_dmah->kva;
+ data_addr = (u_int32_t)cpu_addr_dmah->map->dm_segs[0].ds_addr;
}
/* Save the X server's value for SRC_CNTL and restore it
@@ -869,7 +869,7 @@ static int mach64_bm_dma_test(struct drm_device * dev)
DRM_INFO("resetting engine ...\n");
mach64_do_engine_reset(dev_priv);
DRM_INFO("freeing data buffer memory.\n");
- drm_pci_free(dev->dmat, cpu_addr_dmah);
+ drm_dmamem_free(dev->dmat, cpu_addr_dmah);
return EIO;
}
}
@@ -924,7 +924,7 @@ static int mach64_bm_dma_test(struct drm_device * dev)
MACH64_WRITE(MACH64_PAT_REG0, pat_reg0);
MACH64_WRITE(MACH64_PAT_REG1, pat_reg1);
DRM_INFO("freeing data buffer memory.\n");
- drm_pci_free(dev->dmat, cpu_addr_dmah);
+ drm_dmamem_free(dev->dmat, cpu_addr_dmah);
return i;
}
DRM_DEBUG("waiting for idle...done\n");
@@ -960,7 +960,7 @@ static int mach64_bm_dma_test(struct drm_device * dev)
MACH64_WRITE(MACH64_PAT_REG0, pat_reg0);
MACH64_WRITE(MACH64_PAT_REG1, pat_reg1);
DRM_INFO("freeing data buffer memory.\n");
- drm_pci_free(dev->dmat, cpu_addr_dmah);
+ drm_dmamem_free(dev->dmat, cpu_addr_dmah);
return i;
}
@@ -988,7 +988,7 @@ static int mach64_bm_dma_test(struct drm_device * dev)
MACH64_WRITE(MACH64_PAT_REG1, pat_reg1);
DRM_DEBUG("freeing data buffer memory.\n");
- drm_pci_free(dev->dmat, cpu_addr_dmah);
+ drm_dmamem_free(dev->dmat, cpu_addr_dmah);
DRM_DEBUG("returning ...\n");
return failed;