aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char/drm/drm_bufs.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/char/drm/drm_bufs.c')
-rw-r--r--drivers/char/drm/drm_bufs.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/drivers/char/drm/drm_bufs.c b/drivers/char/drm/drm_bufs.c
index eb3cf550626d..be54efbefe84 100644
--- a/drivers/char/drm/drm_bufs.c
+++ b/drivers/char/drm/drm_bufs.c
@@ -90,6 +90,7 @@ int drm_addmap( struct inode *inode, struct file *filp,
90 drm_map_t *map; 90 drm_map_t *map;
91 drm_map_t __user *argp = (void __user *)arg; 91 drm_map_t __user *argp = (void __user *)arg;
92 drm_map_list_t *list; 92 drm_map_list_t *list;
93 drm_dma_handle_t *dmah;
93 94
94 if ( !(filp->f_mode & 3) ) return -EACCES; /* Require read/write */ 95 if ( !(filp->f_mode & 3) ) return -EACCES; /* Require read/write */
95 96
@@ -181,21 +182,19 @@ int drm_addmap( struct inode *inode, struct file *filp,
181 map->offset += dev->sg->handle; 182 map->offset += dev->sg->handle;
182 break; 183 break;
183 case _DRM_CONSISTENT: 184 case _DRM_CONSISTENT:
184 {
185 /* dma_addr_t is 64bit on i386 with CONFIG_HIGHMEM64G, 185 /* dma_addr_t is 64bit on i386 with CONFIG_HIGHMEM64G,
186 * As we're limit the address to 2^32-1 (or lses), 186 * As we're limiting the address to 2^32-1 (or less),
187 * casting it down to 32 bits is no problem, but we 187 * casting it down to 32 bits is no problem, but we
188 * need to point to a 64bit variable first. */ 188 * need to point to a 64bit variable first. */
189 dma_addr_t bus_addr; 189 dmah = drm_pci_alloc(dev, map->size, map->size, 0xffffffffUL);
190 map->handle = drm_pci_alloc(dev, map->size, map->size, 190 if (!dmah) {
191 0xffffffffUL, &bus_addr);
192 map->offset = (unsigned long)bus_addr;
193 if (!map->handle) {
194 drm_free(map, sizeof(*map), DRM_MEM_MAPS); 191 drm_free(map, sizeof(*map), DRM_MEM_MAPS);
195 return -ENOMEM; 192 return -ENOMEM;
196 } 193 }
194 map->handle = dmah->vaddr;
195 map->offset = (unsigned long)dmah->busaddr;
196 kfree(dmah);
197 break; 197 break;
198 }
199 default: 198 default:
200 drm_free( map, sizeof(*map), DRM_MEM_MAPS ); 199 drm_free( map, sizeof(*map), DRM_MEM_MAPS );
201 return -EINVAL; 200 return -EINVAL;
@@ -286,6 +285,8 @@ int drm_rmmap(struct inode *inode, struct file *filp,
286 } 285 }
287 286
288 if(!found_maps) { 287 if(!found_maps) {
288 drm_dma_handle_t dmah;
289
289 switch (map->type) { 290 switch (map->type) {
290 case _DRM_REGISTERS: 291 case _DRM_REGISTERS:
291 case _DRM_FRAME_BUFFER: 292 case _DRM_FRAME_BUFFER:
@@ -307,7 +308,10 @@ int drm_rmmap(struct inode *inode, struct file *filp,
307 case _DRM_SCATTER_GATHER: 308 case _DRM_SCATTER_GATHER:
308 break; 309 break;
309 case _DRM_CONSISTENT: 310 case _DRM_CONSISTENT:
310 drm_pci_free(dev, map->size, map->handle, map->offset); 311 dmah.vaddr = map->handle;
312 dmah.busaddr = map->offset;
313 dmah.size = map->size;
314 __drm_pci_free(dev, &dmah);
311 break; 315 break;
312 } 316 }
313 drm_free(map, sizeof(*map), DRM_MEM_MAPS); 317 drm_free(map, sizeof(*map), DRM_MEM_MAPS);