diff options
author | rnoland <rnoland@FreeBSD.org> | 2009-03-20 04:48:27 +0000 |
---|---|---|
committer | rnoland <rnoland@FreeBSD.org> | 2009-03-20 04:48:27 +0000 |
commit | 074d756fc92f869cf7eaa7828068fd3e084ac9c4 (patch) | |
tree | 3e2db534b12daf1a8fd2a402182ec4310d44f204 | |
parent | 783a250e72fa461c162c4c31070c7a2cefa9f8aa (diff) | |
download | FreeBSD-src-074d756fc92f869cf7eaa7828068fd3e084ac9c4.zip FreeBSD-src-074d756fc92f869cf7eaa7828068fd3e084ac9c4.tar.gz |
Adjust the flags to bus_dmamem around here too.
MFC after: 3 days
-rw-r--r-- | sys/dev/drm/ati_pcigart.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/sys/dev/drm/ati_pcigart.c b/sys/dev/drm/ati_pcigart.c index 3073cb1..10be0af 100644 --- a/sys/dev/drm/ati_pcigart.c +++ b/sys/dev/drm/ati_pcigart.c @@ -75,18 +75,15 @@ drm_ati_alloc_pcigart_table(struct drm_device *dev, NULL, NULL, /* filtfunc, filtfuncargs */ gart_info->table_size, 1, /* maxsize, nsegs */ gart_info->table_size, /* maxsegsize */ - BUS_DMA_ALLOCNOW, NULL, NULL, /* flags, lockfunc, lockfuncargs */ + 0, NULL, NULL, /* flags, lockfunc, lockfuncargs */ &dmah->tag); if (ret != 0) { free(dmah, DRM_MEM_DMA); return ENOMEM; } - flags = BUS_DMA_NOWAIT | BUS_DMA_ZERO; - if (gart_info->gart_reg_if == DRM_ATI_GART_IGP) - flags |= BUS_DMA_NOCACHE; - - ret = bus_dmamem_alloc(dmah->tag, &dmah->vaddr, flags, &dmah->map); + ret = bus_dmamem_alloc(dmah->tag, &dmah->vaddr, + BUS_DMA_WAITOK | BUS_DMA_ZERO, &dmah->map); if (ret != 0) { bus_dma_tag_destroy(dmah->tag); free(dmah, DRM_MEM_DMA); @@ -94,8 +91,12 @@ drm_ati_alloc_pcigart_table(struct drm_device *dev, } DRM_LOCK(); + flags = BUS_DMA_NOWAIT; + if (gart_info->gart_reg_if == DRM_ATI_GART_IGP) + flags |= BUS_DMA_NOCACHE; + ret = bus_dmamap_load(dmah->tag, dmah->map, dmah->vaddr, - gart_info->table_size, drm_ati_alloc_pcigart_table_cb, dmah, 0); + gart_info->table_size, drm_ati_alloc_pcigart_table_cb, dmah, flags); if (ret != 0) { bus_dmamem_free(dmah->tag, dmah->vaddr, dmah->map); bus_dma_tag_destroy(dmah->tag); |