diff options
-rw-r--r-- | sys/dev/pci/drm/drmP.h | 37 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_agpsupport.c | 8 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_auth.c | 4 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_bufs.c | 69 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_context.c | 4 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_dma.c | 19 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_drv.c | 12 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_heap.c | 12 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_irq.c | 5 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_memory.c | 10 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_scatter.c | 4 | ||||
-rw-r--r-- | sys/dev/pci/drm/i915_mem.c | 4 | ||||
-rw-r--r-- | sys/dev/pci/drm/mach64_dma.c | 11 | ||||
-rw-r--r-- | sys/dev/pci/drm/mach64_state.c | 10 | ||||
-rw-r--r-- | sys/dev/pci/drm/mga_dma.c | 7 | ||||
-rw-r--r-- | sys/dev/pci/drm/r128_cce.c | 5 | ||||
-rw-r--r-- | sys/dev/pci/drm/r128_state.c | 84 | ||||
-rw-r--r-- | sys/dev/pci/drm/radeon_mem.c | 4 | ||||
-rw-r--r-- | sys/dev/pci/drm/radeon_state.c | 10 | ||||
-rw-r--r-- | sys/dev/pci/drm/savage_bci.c | 13 | ||||
-rw-r--r-- | sys/dev/pci/drm/savage_state.c | 16 | ||||
-rw-r--r-- | sys/dev/pci/drm/sis_ds.c | 14 |
22 files changed, 146 insertions, 216 deletions
diff --git a/sys/dev/pci/drm/drmP.h b/sys/dev/pci/drm/drmP.h index 8c1af418073..7ad25792d2d 100644 --- a/sys/dev/pci/drm/drmP.h +++ b/sys/dev/pci/drm/drmP.h @@ -75,30 +75,6 @@ #define DRM_KERNEL_CONTEXT 0 /* Change drm_resctx if changed */ #define DRM_RESERVED_CONTEXTS 1 /* Change drm_resctx if changed */ -#define DRM_MEM_DMA 0 -#define DRM_MEM_SAREA 1 -#define DRM_MEM_DRIVER 2 -#define DRM_MEM_MAGIC 3 -#define DRM_MEM_IOCTLS 4 -#define DRM_MEM_MAPS 5 -#define DRM_MEM_BUFS 6 -#define DRM_MEM_SEGS 7 -#define DRM_MEM_PAGES 8 -#define DRM_MEM_FILES 9 -#define DRM_MEM_QUEUES 10 -#define DRM_MEM_CMDS 11 -#define DRM_MEM_MAPPINGS 12 -#define DRM_MEM_BUFLISTS 13 -#define DRM_MEM_AGPLISTS 14 -#define DRM_MEM_TOTALAGP 15 -#define DRM_MEM_BOUNDAGP 16 -#define DRM_MEM_CTXBITMAP 17 -#define DRM_MEM_CTXLIST 18 -#define DRM_MEM_STUB 19 -#define DRM_MEM_SGLISTS 20 -#define DRM_MEM_DRAWABLE 21 -#define DRM_MEM_MM 22 - #define DRM_MAX_CTXBITMAP (PAGE_SIZE * 8) /* Internal types and structures */ @@ -557,15 +533,10 @@ drm_pci_id_list_t *drm_find_description(int , int , drm_pci_id_list_t *); struct drm_file *drm_find_file_by_minor(struct drm_device *, int); /* Memory management support (drm_memory.c) */ -void *_drm_alloc(size_t); -#define drm_alloc(size, area) _drm_alloc(size) -void *_drm_calloc(size_t, size_t); -#define drm_calloc(nmemb, size, area) _drm_calloc(nmemb, size) -void *_drm_realloc(void *, size_t, size_t); -#define drm_realloc(old, oldsz, size, area) _drm_realloc(old, oldsz, size) -void _drm_free(void *); -#define drm_free(ptr, size, area) do { _drm_free(ptr); (void)(size); \ -} while( /*CONSTCOND*/ 0) +void *drm_alloc(size_t); +void *drm_calloc(size_t, size_t); +void *drm_realloc(void *, size_t, size_t); +void drm_free(void *); void *drm_ioremap(struct drm_device *, drm_local_map_t *); void drm_ioremapfree(drm_local_map_t *); int drm_mtrr_add(unsigned long, size_t, int); diff --git a/sys/dev/pci/drm/drm_agpsupport.c b/sys/dev/pci/drm/drm_agpsupport.c index 9125cde4a7a..1a2c89e01cb 100644 --- a/sys/dev/pci/drm/drm_agpsupport.c +++ b/sys/dev/pci/drm/drm_agpsupport.c @@ -154,7 +154,7 @@ drm_agp_alloc(struct drm_device *dev, struct drm_agp_buffer *request) if (dev->agp == NULL || !dev->agp->acquired) return (EINVAL); - entry = drm_alloc(sizeof(*entry), DRM_MEM_AGPLISTS); + entry = drm_alloc(sizeof(*entry)); if (entry == NULL) return (ENOMEM); @@ -164,7 +164,7 @@ drm_agp_alloc(struct drm_device *dev, struct drm_agp_buffer *request) handle = agp_alloc_memory(dev->agp->agpdev, type, pages << AGP_PAGE_SHIFT); if (handle == NULL) { - drm_free(entry, sizeof(*entry), DRM_MEM_AGPLISTS); + drm_free(entry); return (ENOMEM); } @@ -291,7 +291,7 @@ drm_agp_remove_entry(struct drm_device *dev, struct drm_agp_mem *entry) if (entry->bound) agp_unbind_memory(dev->agp->agpdev, entry->handle); agp_free_memory(dev->agp->agpdev, entry->handle); - drm_free(entry, sizeof(*entry), DRM_MEM_AGPLISTS); + drm_free(entry); } void @@ -360,7 +360,7 @@ drm_agp_init(void) DRM_DEBUG("agp_available = %d\n", agp_available); if (agp_available) { - head = drm_calloc(1, sizeof(*head), DRM_MEM_AGPLISTS); + head = drm_calloc(1, sizeof(*head)); if (head == NULL) return (NULL); head->agpdev = agpdev; diff --git a/sys/dev/pci/drm/drm_auth.c b/sys/dev/pci/drm/drm_auth.c index 3a7e4af340e..c2fd04709a8 100644 --- a/sys/dev/pci/drm/drm_auth.c +++ b/sys/dev/pci/drm/drm_auth.c @@ -53,7 +53,7 @@ drm_getmagic(struct drm_device *dev, void *data, struct drm_file *file_priv) if (file_priv->magic) { auth->magic = file_priv->magic; } else { - entry = drm_alloc(sizeof(*entry), DRM_MEM_MAGIC); + entry = drm_alloc(sizeof(*entry)); if (entry == NULL) return (ENOMEM); DRM_LOCK(); @@ -93,7 +93,7 @@ drm_authmagic(struct drm_device *dev, void *data, struct drm_file *file_priv) SPLAY_REMOVE(drm_magic_tree, &dev->magiclist, pt); DRM_UNLOCK(); - drm_free(pt, sizeof(*pt), DRM_MEM_MAGIC); + drm_free(pt); return (0); } diff --git a/sys/dev/pci/drm/drm_bufs.c b/sys/dev/pci/drm/drm_bufs.c index 3c95734e9e7..a77336a3c89 100644 --- a/sys/dev/pci/drm/drm_bufs.c +++ b/sys/dev/pci/drm/drm_bufs.c @@ -113,7 +113,7 @@ drm_addmap(struct drm_device * dev, unsigned long offset, unsigned long size, /* Allocate a new map structure, fill it in, and do any type-specific * initialization necessary. */ - map = drm_calloc(1, sizeof(*map), DRM_MEM_MAPS); + map = drm_calloc(1, sizeof(*map)); if (map == NULL) { DRM_LOCK(); return ENOMEM; @@ -131,7 +131,7 @@ drm_addmap(struct drm_device * dev, unsigned long offset, unsigned long size, if (ret) { DRM_ERROR("can't find free offset\n"); DRM_UNLOCK(); - drm_free(map, sizeof(*map), DRM_MEM_MAPS); + drm_free(map); return (ret); } DRM_UNLOCK(); @@ -178,7 +178,7 @@ drm_addmap(struct drm_device * dev, unsigned long offset, unsigned long size, } if (!TAILQ_EMPTY(&dev->agp->memory) && !valid) { DRM_UNLOCK(); - drm_free(map, sizeof(*map), DRM_MEM_MAPS); + drm_free(map); DRM_ERROR("invalid agp map requested\n"); return (EACCES); } @@ -187,7 +187,7 @@ drm_addmap(struct drm_device * dev, unsigned long offset, unsigned long size, break; case _DRM_SCATTER_GATHER: if (dev->sg == NULL) { - drm_free(map, sizeof(*map), DRM_MEM_MAPS); + drm_free(map); return (EINVAL); } map->offset += dev->sg->handle; @@ -206,7 +206,7 @@ drm_addmap(struct drm_device * dev, unsigned long offset, unsigned long size, map->dmamem = drm_dmamem_alloc(dev->dmat, map->size, align, 1, map->size, 0, 0); if (map->dmamem == NULL) { - drm_free(map, sizeof(*map), DRM_MEM_MAPS); + drm_free(map); return (ENOMEM); } map->handle = map->dmamem->kva; @@ -217,7 +217,7 @@ drm_addmap(struct drm_device * dev, unsigned long offset, unsigned long size, if (dev->lock.hw_lock != NULL) { DRM_UNLOCK(); drm_dmamem_free(dev->dmat, map->dmamem); - drm_free(map, sizeof(*map), DRM_MEM_MAPS); + drm_free(map); return (EBUSY); } dev->lock.hw_lock = map->handle; @@ -226,7 +226,7 @@ drm_addmap(struct drm_device * dev, unsigned long offset, unsigned long size, break; default: DRM_ERROR("Bad map type %d\n", map->type); - drm_free(map, sizeof(*map), DRM_MEM_MAPS); + drm_free(map); return EINVAL; } @@ -313,7 +313,7 @@ drm_rmmap_locked(struct drm_device *dev, drm_local_map_t *map) /* NOCOALESCE set, can't fail */ extent_free(dev->handle_ext, map->ext, map->size, EX_NOWAIT); - drm_free(map, sizeof(*map), DRM_MEM_MAPS); + drm_free(map); } /* Remove a map private from list and deallocate resources if the mapping @@ -417,8 +417,7 @@ drm_do_addbufs_agp(struct drm_device *dev, struct drm_buf_desc *request) entry = &dma->bufs[order]; - entry->buflist = drm_calloc(count, sizeof(*entry->buflist), - DRM_MEM_BUFS); + entry->buflist = drm_calloc(count, sizeof(*entry->buflist)); if (entry->buflist == NULL) return ENOMEM; @@ -438,8 +437,7 @@ drm_do_addbufs_agp(struct drm_device *dev, struct drm_buf_desc *request) buf->pending = 0; buf->file_priv = NULL; - buf->dev_private = drm_calloc(1, dev->driver->buf_priv_size, - DRM_MEM_BUFS); + buf->dev_private = drm_calloc(1, dev->driver->buf_priv_size); if (buf->dev_private == NULL) { /* Set count correctly so we free the proper amount. */ entry->buf_count = count; @@ -457,7 +455,7 @@ drm_do_addbufs_agp(struct drm_device *dev, struct drm_buf_desc *request) /* OpenBSD lacks realloc in kernel */ temp_buflist = drm_realloc(dma->buflist, dma->buf_count * sizeof(*dma->buflist), - (dma->buf_count + entry->buf_count) * sizeof(*dma->buflist), M_DRM); + (dma->buf_count + entry->buf_count) * sizeof(*dma->buflist)); if (temp_buflist == NULL) { /* Free the entry because it isn't valid */ drm_cleanup_buf(dev, entry); @@ -515,25 +513,20 @@ drm_do_addbufs_pci(struct drm_device *dev, struct drm_buf_desc *request) entry = &dma->bufs[order]; - entry->buflist = drm_calloc(count, sizeof(*entry->buflist), - DRM_MEM_BUFS); - entry->seglist = drm_calloc(count, sizeof(*entry->seglist), - DRM_MEM_BUFS); + entry->buflist = drm_calloc(count, sizeof(*entry->buflist)); + entry->seglist = drm_calloc(count, sizeof(*entry->seglist)); /* Keep the original pagelist until we know all the allocations * have succeeded */ temp_pagelist = drm_calloc((dma->page_count + (count << page_order)), - sizeof(*dma->pagelist), DRM_MEM_BUFS); + sizeof(*dma->pagelist)); if (entry->buflist == NULL || entry->seglist == NULL || temp_pagelist == NULL) { - drm_free(temp_pagelist, (dma->page_count + (count << - page_order)) * sizeof(*dma->pagelist), DRM_MEM_BUFS); - drm_free(entry->seglist, count * sizeof(*entry->seglist), - DRM_MEM_BUFS); - drm_free(entry->buflist, count * sizeof(*entry->buflist), - DRM_MEM_BUFS); + drm_free(temp_pagelist); + drm_free(entry->seglist); + drm_free(entry->buflist); return ENOMEM; } @@ -556,9 +549,7 @@ drm_do_addbufs_pci(struct drm_device *dev, struct drm_buf_desc *request) entry->buf_count = count; entry->seg_count = count; drm_cleanup_buf(dev, entry); - drm_free(temp_pagelist, (dma->page_count + - (count << page_order)) * sizeof(*dma->pagelist), - DRM_MEM_BUFS); + drm_free(temp_pagelist); return ENOMEM; } @@ -584,16 +575,13 @@ drm_do_addbufs_pci(struct drm_device *dev, struct drm_buf_desc *request) buf->file_priv = NULL; buf->dev_private = drm_calloc(1, - dev->driver->buf_priv_size, DRM_MEM_BUFS); + dev->driver->buf_priv_size); if (buf->dev_private == NULL) { /* Set count so we free the proper amount. */ entry->buf_count = count; entry->seg_count = count; drm_cleanup_buf(dev, entry); - drm_free(temp_pagelist, (dma->page_count + - (count << page_order)) * - sizeof(*dma->pagelist), - DRM_MEM_BUFS); + drm_free(temp_pagelist); return ENOMEM; } @@ -605,13 +593,11 @@ drm_do_addbufs_pci(struct drm_device *dev, struct drm_buf_desc *request) temp_buflist = drm_realloc(dma->buflist, dma->buf_count * sizeof(*dma->buflist), - (dma->buf_count + entry->buf_count) * sizeof(*dma->buflist), M_DRM); + (dma->buf_count + entry->buf_count) * sizeof(*dma->buflist)); if (temp_buflist == NULL) { /* Free the entry because it isn't valid */ drm_cleanup_buf(dev, entry); - drm_free(temp_pagelist, (dma->page_count + - (count << page_order)) * sizeof(*dma->pagelist), - DRM_MEM_BUFS); + drm_free(temp_pagelist); return ENOMEM; } dma->buflist = temp_buflist; @@ -622,8 +608,7 @@ drm_do_addbufs_pci(struct drm_device *dev, struct drm_buf_desc *request) /* No allocations failed, so now we can replace the orginal pagelist * with the new one. */ - drm_free(dma->pagelist, dma->page_count * sizeof(*dma->pagelist), - DRM_MEM_BUFS); + drm_free(dma->pagelist); dma->pagelist = temp_pagelist; dma->buf_count += entry->buf_count; @@ -678,8 +663,7 @@ drm_do_addbufs_sg(struct drm_device *dev, struct drm_buf_desc *request) entry = &dma->bufs[order]; - entry->buflist = drm_calloc(count, sizeof(*entry->buflist), - DRM_MEM_BUFS); + entry->buflist = drm_calloc(count, sizeof(*entry->buflist)); if (entry->buflist == NULL) return ENOMEM; @@ -699,8 +683,7 @@ drm_do_addbufs_sg(struct drm_device *dev, struct drm_buf_desc *request) buf->pending = 0; buf->file_priv = NULL; - buf->dev_private = drm_calloc(1, dev->driver->buf_priv_size, - DRM_MEM_BUFS); + buf->dev_private = drm_calloc(1, dev->driver->buf_priv_size); if (buf->dev_private == NULL) { /* Set count correctly so we free the proper amount. */ entry->buf_count = count; @@ -719,7 +702,7 @@ drm_do_addbufs_sg(struct drm_device *dev, struct drm_buf_desc *request) temp_buflist = drm_realloc(dma->buflist, dma->buf_count * sizeof(*dma->buflist), - (dma->buf_count + entry->buf_count) * sizeof(*dma->buflist), M_DRM); + (dma->buf_count + entry->buf_count) * sizeof(*dma->buflist)); if (temp_buflist == NULL) { /* Free the entry because it isn't valid */ drm_cleanup_buf(dev, entry); diff --git a/sys/dev/pci/drm/drm_context.c b/sys/dev/pci/drm/drm_context.c index 67538152db4..7c3135bb422 100644 --- a/sys/dev/pci/drm/drm_context.c +++ b/sys/dev/pci/drm/drm_context.c @@ -82,7 +82,7 @@ drm_ctxbitmap_init(struct drm_device *dev) int i, temp; - bitmap = drm_calloc(1, PAGE_SIZE, DRM_MEM_CTXBITMAP); + bitmap = drm_calloc(1, PAGE_SIZE); if (bitmap == NULL) return (ENOMEM); DRM_LOCK(); @@ -106,7 +106,7 @@ drm_ctxbitmap_cleanup(struct drm_device *dev) bitmap = dev->ctx_bitmap; dev->ctx_bitmap = NULL; DRM_UNLOCK(); - drm_free(bitmap, PAGE_SIZE, DRM_MEM_CTXBITMAP); + drm_free(bitmap); } int diff --git a/sys/dev/pci/drm/drm_dma.c b/sys/dev/pci/drm/drm_dma.c index e0385def268..2f527efcb5c 100644 --- a/sys/dev/pci/drm/drm_dma.c +++ b/sys/dev/pci/drm/drm_dma.c @@ -42,7 +42,7 @@ int drm_dma_setup(struct drm_device *dev) { - dev->dma = drm_calloc(1, sizeof(*dev->dma), DRM_MEM_DRIVER); + dev->dma = drm_calloc(1, sizeof(*dev->dma)); if (dev->dma == NULL) return ENOMEM; @@ -61,19 +61,16 @@ drm_cleanup_buf(struct drm_device *dev, drm_buf_entry_t *entry) if (entry->seg_count) { for (i = 0; i < entry->seg_count; i++) drm_dmamem_free(dev->dmat, entry->seglist[i]); - drm_free(entry->seglist, entry->seg_count * - sizeof(*entry->seglist), DRM_MEM_BUFS); + drm_free(entry->seglist); entry->seg_count = 0; } if (entry->buf_count) { for (i = 0; i < entry->buf_count; i++) { - drm_free(entry->buflist[i].dev_private, - dev->driver->buf_priv_size, DRM_MEM_BUFS); + drm_free(entry->buflist[i].dev_private); } - drm_free(entry->buflist, entry->buf_count * - sizeof(*entry->buflist), DRM_MEM_BUFS); + drm_free(entry->buflist); entry->buf_count = 0; } @@ -92,11 +89,9 @@ drm_dma_takedown(struct drm_device *dev) for (i = 0; i <= DRM_MAX_ORDER; i++) drm_cleanup_buf(dev, &dma->bufs[i]); - drm_free(dma->buflist, dma->buf_count * sizeof(*dma->buflist), - DRM_MEM_BUFS); - drm_free(dma->pagelist, dma->page_count * sizeof(*dma->pagelist), - DRM_MEM_BUFS); - drm_free(dev->dma, sizeof(*dev->dma), DRM_MEM_DMA); + drm_free(dma->buflist); + drm_free(dma->pagelist); + drm_free(dev->dma); dev->dma = NULL; DRM_SPINUNINIT(&dev->dma_lock); } diff --git a/sys/dev/pci/drm/drm_drv.c b/sys/dev/pci/drm/drm_drv.c index a862478b9c3..04d7eb1ed90 100644 --- a/sys/dev/pci/drm/drm_drv.c +++ b/sys/dev/pci/drm/drm_drv.c @@ -205,7 +205,7 @@ drm_detach(struct device *self, int flags) if (dev->agp != NULL) { - drm_free(dev->agp, sizeof(*dev->agp), DRM_MEM_AGPLISTS); + drm_free(dev->agp); dev->agp = NULL; } @@ -317,7 +317,7 @@ drm_lastclose(struct drm_device *dev) /* Clear pid list */ while ((pt = SPLAY_ROOT(&dev->magiclist)) != NULL) { SPLAY_REMOVE(drm_magic_tree, &dev->magiclist, pt); - drm_free(pt, sizeof(*pt), DRM_MEM_MAGIC); + drm_free(pt); } if (dev->sg != NULL) { @@ -399,7 +399,7 @@ drmopen(dev_t kdev, int flags, int fmt, struct proc *p) /* always allocate at least enough space for our data */ priv = drm_calloc(1, max(dev->driver->file_priv_size, - sizeof(*priv)), DRM_MEM_FILES); + sizeof(*priv))); if (priv == NULL) { ret = ENOMEM; goto err; @@ -436,8 +436,7 @@ drmopen(dev_t kdev, int flags, int fmt, struct proc *p) return (0); free_priv: - drm_free(priv, max(dev->driver->file_priv_size, - sizeof(*priv)), DRM_MEM_FILES); + drm_free(priv); err: DRM_LOCK(); --dev->open_count; @@ -518,8 +517,7 @@ drmclose(dev_t kdev, int flags, int fmt, struct proc *p) DRM_LOCK(); TAILQ_REMOVE(&dev->files, file_priv, link); - drm_free(file_priv, max(dev->driver->file_priv_size, - sizeof(*file_priv)), DRM_MEM_FILES); + drm_free(file_priv); done: if (--dev->open_count == 0) { diff --git a/sys/dev/pci/drm/drm_heap.c b/sys/dev/pci/drm/drm_heap.c index ed55f2401be..0a62863b2c8 100644 --- a/sys/dev/pci/drm/drm_heap.c +++ b/sys/dev/pci/drm/drm_heap.c @@ -44,8 +44,7 @@ drm_split_block(struct drm_heap *heap, struct drm_mem *p, int start, { /* Maybe cut off the start of an existing block */ if (start > p->start) { - struct drm_mem *newblock = - drm_alloc(sizeof(*newblock), DRM_MEM_BUFS); + struct drm_mem *newblock = drm_alloc(sizeof(*newblock)); if (newblock == NULL) goto out; newblock->start = start; @@ -58,8 +57,7 @@ drm_split_block(struct drm_heap *heap, struct drm_mem *p, int start, /* Maybe cut off the end of an existing block */ if (size < p->size) { - struct drm_mem *newblock = - drm_alloc(sizeof(*newblock), DRM_MEM_BUFS); + struct drm_mem *newblock = drm_alloc(sizeof(*newblock)); if (newblock == NULL) goto out; newblock->start = start + size; @@ -115,14 +113,14 @@ drm_free_block(struct drm_heap *heap, struct drm_mem *p) q->file_priv == NULL) { p->size += q->size; TAILQ_REMOVE(heap, q, link); - drm_free(q, sizeof(*q), DRM_MEM_BUFS); + drm_free(q); } if ((q = TAILQ_PREV(p, drm_heap, link)) != TAILQ_END(heap) && q->file_priv == NULL) { q->size += p->size; TAILQ_REMOVE(heap, p, link); - drm_free(p, sizeof(*p), DRM_MEM_BUFS); + drm_free(p); } } @@ -136,7 +134,7 @@ drm_init_heap(struct drm_heap *heap, int start, int size) if (!TAILQ_EMPTY(heap)) return (EBUSY); - if ((blocks = drm_alloc(sizeof(*blocks), DRM_MEM_BUFS)) == NULL) + if ((blocks = drm_alloc(sizeof(*blocks))) == NULL) return (ENOMEM); blocks->start = start; diff --git a/sys/dev/pci/drm/drm_irq.c b/sys/dev/pci/drm/drm_irq.c index 7e38de2a1de..12a99740caa 100644 --- a/sys/dev/pci/drm/drm_irq.c +++ b/sys/dev/pci/drm/drm_irq.c @@ -178,8 +178,7 @@ drm_vblank_cleanup(struct drm_device *dev) vblank_disable(dev); - drm_free(dev->vblank, sizeof(*dev->vblank) * - dev->num_crtcs, M_DRM); + drm_free(dev->vblank); dev->vblank = NULL; dev->num_crtcs = 0; @@ -193,7 +192,7 @@ drm_vblank_init(struct drm_device *dev, int num_crtcs) mtx_init(&dev->vbl_lock, IPL_BIO); dev->num_crtcs = num_crtcs; - dev->vblank = drm_calloc(num_crtcs, sizeof(*dev->vblank), M_DRM); + dev->vblank = drm_calloc(num_crtcs, sizeof(*dev->vblank)); if (dev->vblank == NULL) goto err; diff --git a/sys/dev/pci/drm/drm_memory.c b/sys/dev/pci/drm/drm_memory.c index fd53412b0dc..031d23cda98 100644 --- a/sys/dev/pci/drm/drm_memory.c +++ b/sys/dev/pci/drm/drm_memory.c @@ -39,13 +39,13 @@ #include "drmP.h" void* -_drm_alloc(size_t size) +drm_alloc(size_t size) { - return malloc(size, M_DRM, M_NOWAIT); + return (malloc(size, M_DRM, M_NOWAIT)); } void * -_drm_calloc(size_t nmemb, size_t size) +drm_calloc(size_t nmemb, size_t size) { if (nmemb == 0 || SIZE_MAX / nmemb < size) return (NULL); @@ -54,7 +54,7 @@ _drm_calloc(size_t nmemb, size_t size) } void * -_drm_realloc(void *oldpt, size_t oldsize, size_t size) +drm_realloc(void *oldpt, size_t oldsize, size_t size) { void *pt; @@ -69,7 +69,7 @@ _drm_realloc(void *oldpt, size_t oldsize, size_t size) } void -_drm_free(void *pt) +drm_free(void *pt) { if (pt != NULL) free(pt, M_DRM); diff --git a/sys/dev/pci/drm/drm_scatter.c b/sys/dev/pci/drm/drm_scatter.c index 14e9ba2ac9d..592ca8b1f00 100644 --- a/sys/dev/pci/drm/drm_scatter.c +++ b/sys/dev/pci/drm/drm_scatter.c @@ -42,7 +42,7 @@ drm_sg_cleanup(struct drm_device *dev, struct drm_sg_mem *entry) return; drm_dmamem_free(dev->dmat, entry->mem); - drm_free(entry, sizeof(entry), DRM_MEM_SGLISTS); + drm_free(entry); } int @@ -55,7 +55,7 @@ drm_sg_alloc(struct drm_device * dev, struct drm_scatter_gather *request) if (dev->sg != NULL) return (EINVAL); - entry = drm_calloc(1, sizeof(*entry), DRM_MEM_SGLISTS); + entry = drm_calloc(1, sizeof(*entry)); if (entry == NULL) return (ENOMEM); diff --git a/sys/dev/pci/drm/i915_mem.c b/sys/dev/pci/drm/i915_mem.c index c2559eee733..429b36da7ec 100644 --- a/sys/dev/pci/drm/i915_mem.c +++ b/sys/dev/pci/drm/i915_mem.c @@ -110,7 +110,7 @@ i915_mem_release(struct drm_device * dev, struct drm_file *file_priv, q->file_priv == NULL) { p->size += q->size; TAILQ_REMOVE(heap, q, link); - drm_free(q, sizeof(*q), DRM_MEM_DRIVER); + drm_free(q); } q = TAILQ_NEXT(p, link); } @@ -128,7 +128,7 @@ i915_mem_takedown(struct drm_heap *heap) while ((p = TAILQ_FIRST(heap)) != NULL) { TAILQ_REMOVE(heap, p, link); - drm_free(p, sizeof(*p), DRM_MEM_BUFLISTS); + drm_free(p); } } diff --git a/sys/dev/pci/drm/mach64_dma.c b/sys/dev/pci/drm/mach64_dma.c index 8ea1fcba8db..73f84d1d4a9 100644 --- a/sys/dev/pci/drm/mach64_dma.c +++ b/sys/dev/pci/drm/mach64_dma.c @@ -1439,10 +1439,7 @@ int mach64_init_freelist(struct drm_device * dev) DRM_DEBUG("adding %d buffers to freelist\n", dma->buf_count); for (i = 0; i < dma->buf_count; i++) { - if ((entry = - (drm_mach64_freelist_t *) - drm_calloc(1, sizeof(drm_mach64_freelist_t), - DRM_MEM_BUFLISTS)) == NULL) + if ((entry = drm_calloc(1, sizeof(*entry))) == NULL) return ENOMEM; entry->buf = dma->buflist[i]; ptr = &entry->list; @@ -1464,18 +1461,18 @@ void mach64_destroy_freelist(struct drm_device * dev) list_for_each_safe(ptr, tmp, &dev_priv->pending) { list_del(ptr); entry = list_entry(ptr, drm_mach64_freelist_t, list); - drm_free(entry, sizeof(*entry), DRM_MEM_BUFLISTS); + drm_free(entry); } list_for_each_safe(ptr, tmp, &dev_priv->placeholders) { list_del(ptr); entry = list_entry(ptr, drm_mach64_freelist_t, list); - drm_free(entry, sizeof(*entry), DRM_MEM_BUFLISTS); + drm_free(entry); } list_for_each_safe(ptr, tmp, &dev_priv->free_list) { list_del(ptr); entry = list_entry(ptr, drm_mach64_freelist_t, list); - drm_free(entry, sizeof(*entry), DRM_MEM_BUFLISTS); + drm_free(entry); } } diff --git a/sys/dev/pci/drm/mach64_state.c b/sys/dev/pci/drm/mach64_state.c index 97d0e6508e1..7f597f50204 100644 --- a/sys/dev/pci/drm/mach64_state.c +++ b/sys/dev/pci/drm/mach64_state.c @@ -471,12 +471,12 @@ static __inline__ int copy_from_user_vertex(u32 *to, unsigned long n = bytes; /* dwords remaining in buffer */ u32 *from, *orig_from; - from = drm_alloc(bytes, DRM_MEM_DRIVER); + from = drm_alloc(bytes); if (from == NULL) return ENOMEM; if (DRM_COPY_FROM_USER(from, ufrom, bytes)) { - drm_free(from, bytes, DRM_MEM_DRIVER); + drm_free(from); return EFAULT; } orig_from = from; /* we'll be modifying the "from" ptr, so save it */ @@ -507,19 +507,19 @@ static __inline__ int copy_from_user_vertex(u32 *to, to += count; } else { DRM_ERROR("Got bad command: 0x%04x\n", reg); - drm_free(orig_from, bytes, DRM_MEM_DRIVER); + drm_free(orig_from); return EACCES; } } else { DRM_ERROR ("Got bad command count(=%u) dwords remaining=%lu\n", count, n); - drm_free(orig_from, bytes, DRM_MEM_DRIVER); + drm_free(orig_from); return EINVAL; } } - drm_free(orig_from, bytes, DRM_MEM_DRIVER); + drm_free(orig_from); if (n == 0) return 0; else { diff --git a/sys/dev/pci/drm/mga_dma.c b/sys/dev/pci/drm/mga_dma.c index 88a7c5b772e..295a39b4911 100644 --- a/sys/dev/pci/drm/mga_dma.c +++ b/sys/dev/pci/drm/mga_dma.c @@ -253,7 +253,7 @@ static int mga_freelist_init(struct drm_device * dev, drm_mga_private_t * dev_pr int i; DRM_DEBUG("count=%d\n", dma->buf_count); - dev_priv->head = drm_calloc(1, sizeof(drm_mga_freelist_t), DRM_MEM_DRIVER); + dev_priv->head = drm_calloc(1, sizeof(*(dev_priv->head))); if (dev_priv->head == NULL) return ENOMEM; @@ -263,8 +263,7 @@ static int mga_freelist_init(struct drm_device * dev, drm_mga_private_t * dev_pr buf = dma->buflist[i]; buf_priv = (drm_mga_buf_priv_t *)buf; - entry = drm_calloc(1, sizeof(drm_mga_freelist_t), - DRM_MEM_DRIVER); + entry = drm_calloc(1, sizeof(*entry)); if (entry == NULL) return ENOMEM; @@ -297,7 +296,7 @@ static void mga_freelist_cleanup(struct drm_device * dev) entry = dev_priv->head; while (entry) { next = entry->next; - drm_free(entry, sizeof(drm_mga_freelist_t), DRM_MEM_DRIVER); + drm_free(entry); entry = next; } diff --git a/sys/dev/pci/drm/r128_cce.c b/sys/dev/pci/drm/r128_cce.c index 272a9fe6713..aae7092cc79 100644 --- a/sys/dev/pci/drm/r128_cce.c +++ b/sys/dev/pci/drm/r128_cce.c @@ -728,8 +728,7 @@ static int r128_freelist_init(struct drm_device * dev) drm_r128_freelist_t *entry; int i; - dev_priv->head = drm_calloc(1, sizeof(drm_r128_freelist_t), - DRM_MEM_DRIVER); + dev_priv->head = drm_calloc(1, sizeof(*dev_priv->head)); if (dev_priv->head == NULL) return ENOMEM; @@ -739,7 +738,7 @@ static int r128_freelist_init(struct drm_device * dev) buf = dma->buflist[i]; buf_priv = buf->dev_private; - entry = drm_alloc(sizeof(drm_r128_freelist_t), DRM_MEM_DRIVER); + entry = drm_alloc(sizeof(*entry)); if (!entry) return ENOMEM; diff --git a/sys/dev/pci/drm/r128_state.c b/sys/dev/pci/drm/r128_state.c index e7c8c58254b..a9fff384d5f 100644 --- a/sys/dev/pci/drm/r128_state.c +++ b/sys/dev/pci/drm/r128_state.c @@ -838,24 +838,24 @@ static int r128_cce_dispatch_write_span(struct drm_device * dev, } buffer_size = depth->n * sizeof(u32); - buffer = drm_alloc(buffer_size, DRM_MEM_BUFS); + buffer = drm_alloc(buffer_size); if (buffer == NULL) return ENOMEM; if (DRM_COPY_FROM_USER(buffer, depth->buffer, buffer_size)) { - drm_free(buffer, buffer_size, DRM_MEM_BUFS); + drm_free(buffer); return EFAULT; } mask_size = depth->n * sizeof(u8); if (depth->mask) { - mask = drm_alloc(mask_size, DRM_MEM_BUFS); + mask = drm_alloc(mask_size); if (mask == NULL) { - drm_free(buffer, buffer_size, DRM_MEM_BUFS); + drm_free(buffer); return ENOMEM; } if (DRM_COPY_FROM_USER(mask, depth->mask, mask_size)) { - drm_free(buffer, buffer_size, DRM_MEM_BUFS); - drm_free(mask, mask_size, DRM_MEM_BUFS); + drm_free(buffer); + drm_free(mask); return EFAULT; } @@ -882,7 +882,7 @@ static int r128_cce_dispatch_write_span(struct drm_device * dev, } } - drm_free(mask, mask_size, DRM_MEM_BUFS); + drm_free(mask); } else { for (i = 0; i < count; i++, x++) { BEGIN_RING(6); @@ -906,7 +906,7 @@ static int r128_cce_dispatch_write_span(struct drm_device * dev, } } - drm_free(buffer, buffer_size, DRM_MEM_BUFS); + drm_free(buffer); return 0; } @@ -928,54 +928,54 @@ static int r128_cce_dispatch_write_pixels(struct drm_device * dev, xbuf_size = count * sizeof(*x); ybuf_size = count * sizeof(*y); - x = drm_alloc(xbuf_size, DRM_MEM_BUFS); + x = drm_alloc(xbuf_size); if (x == NULL) { return ENOMEM; } - y = drm_alloc(ybuf_size, DRM_MEM_BUFS); + y = drm_alloc(ybuf_size); if (y == NULL) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); + drm_free(x); return ENOMEM; } if (DRM_COPY_FROM_USER(x, depth->x, xbuf_size)) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); return EFAULT; } if (DRM_COPY_FROM_USER(y, depth->y, xbuf_size)) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); return EFAULT; } buffer_size = depth->n * sizeof(u32); - buffer = drm_alloc(buffer_size, DRM_MEM_BUFS); + buffer = drm_alloc(buffer_size); if (buffer == NULL) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); return ENOMEM; } if (DRM_COPY_FROM_USER(buffer, depth->buffer, buffer_size)) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); - drm_free(buffer, buffer_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); + drm_free(buffer); return EFAULT; } if (depth->mask) { mask_size = depth->n * sizeof(u8); - mask = drm_alloc(mask_size, DRM_MEM_BUFS); + mask = drm_alloc(mask_size); if (mask == NULL) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); - drm_free(buffer, buffer_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); + drm_free(buffer); return ENOMEM; } if (DRM_COPY_FROM_USER(mask, depth->mask, mask_size)) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); - drm_free(buffer, buffer_size, DRM_MEM_BUFS); - drm_free(mask, mask_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); + drm_free(buffer); + drm_free(mask); return EFAULT; } @@ -1002,7 +1002,7 @@ static int r128_cce_dispatch_write_pixels(struct drm_device * dev, } } - drm_free(mask, mask_size, DRM_MEM_BUFS); + drm_free(mask); } else { for (i = 0; i < count; i++) { BEGIN_RING(6); @@ -1026,9 +1026,9 @@ static int r128_cce_dispatch_write_pixels(struct drm_device * dev, } } - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); - drm_free(buffer, buffer_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); + drm_free(buffer); return 0; } @@ -1095,23 +1095,23 @@ static int r128_cce_dispatch_read_pixels(struct drm_device * dev, xbuf_size = count * sizeof(*x); ybuf_size = count * sizeof(*y); - x = drm_alloc(xbuf_size, DRM_MEM_BUFS); + x = drm_alloc(xbuf_size); if (x == NULL) { return ENOMEM; } - y = drm_alloc(ybuf_size, DRM_MEM_BUFS); + y = drm_alloc(ybuf_size); if (y == NULL) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); + drm_free(x); return ENOMEM; } if (DRM_COPY_FROM_USER(x, depth->x, xbuf_size)) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); return EFAULT; } if (DRM_COPY_FROM_USER(y, depth->y, ybuf_size)) { - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); return EFAULT; } @@ -1138,8 +1138,8 @@ static int r128_cce_dispatch_read_pixels(struct drm_device * dev, ADVANCE_RING(); } - drm_free(x, xbuf_size, DRM_MEM_BUFS); - drm_free(y, ybuf_size, DRM_MEM_BUFS); + drm_free(x); + drm_free(y); return 0; } diff --git a/sys/dev/pci/drm/radeon_mem.c b/sys/dev/pci/drm/radeon_mem.c index f753edc80b5..d095959bde7 100644 --- a/sys/dev/pci/drm/radeon_mem.c +++ b/sys/dev/pci/drm/radeon_mem.c @@ -57,7 +57,7 @@ radeon_mem_release(struct drm_file *file_priv, struct drm_heap *heap) q->file_priv == NULL) { p->size += q->size; TAILQ_REMOVE(heap, q, link); - drm_free(q, sizeof(*q), DRM_MEM_DRIVER); + drm_free(q); } q = TAILQ_NEXT(p, link); } @@ -75,7 +75,7 @@ radeon_mem_takedown(struct drm_heap *heap) while ((p = TAILQ_FIRST(heap)) != NULL) { TAILQ_REMOVE(heap, p, link); - drm_free(p, sizeof(*p), DRM_MEM_DRIVER); + drm_free(p); } } diff --git a/sys/dev/pci/drm/radeon_state.c b/sys/dev/pci/drm/radeon_state.c index f6f8f8044d3..e5e99517470 100644 --- a/sys/dev/pci/drm/radeon_state.c +++ b/sys/dev/pci/drm/radeon_state.c @@ -2184,12 +2184,12 @@ radeon_cp_cmdbuf(struct drm_device *dev, void *data, */ orig_bufsz = cmdbuf->bufsz; if (orig_bufsz != 0) { - kbuf = drm_alloc(cmdbuf->bufsz, DRM_MEM_DRIVER); + kbuf = drm_alloc(cmdbuf->bufsz); if (kbuf == NULL) return ENOMEM; if (DRM_COPY_FROM_USER(kbuf, (void __user *)cmdbuf->buf, cmdbuf->bufsz)) { - drm_free(kbuf, orig_bufsz, DRM_MEM_DRIVER); + drm_free(kbuf); return EFAULT; } cmdbuf->buf = kbuf; @@ -2202,7 +2202,7 @@ radeon_cp_cmdbuf(struct drm_device *dev, void *data, temp = r300_do_cp_cmdbuf(dev, file_priv, cmdbuf); if (orig_bufsz != 0) - drm_free(kbuf, orig_bufsz, DRM_MEM_DRIVER); + drm_free(kbuf); return temp; } @@ -2309,7 +2309,7 @@ radeon_cp_cmdbuf(struct drm_device *dev, void *data, } if (orig_bufsz != 0) - drm_free(kbuf, orig_bufsz, DRM_MEM_DRIVER); + drm_free(kbuf); DRM_DEBUG("DONE\n"); COMMIT_RING(); @@ -2317,7 +2317,7 @@ radeon_cp_cmdbuf(struct drm_device *dev, void *data, err: if (orig_bufsz != 0) - drm_free(kbuf, orig_bufsz, DRM_MEM_DRIVER); + drm_free(kbuf); return EINVAL; } diff --git a/sys/dev/pci/drm/savage_bci.c b/sys/dev/pci/drm/savage_bci.c index 58c9b07a377..d0a0e4bb775 100644 --- a/sys/dev/pci/drm/savage_bci.c +++ b/sys/dev/pci/drm/savage_bci.c @@ -298,8 +298,7 @@ static int savage_dma_init(drm_savage_private_t *dev_priv) dev_priv->nr_dma_pages = dev_priv->cmd_dma->size / (SAVAGE_DMA_PAGE_SIZE*4); - dev_priv->dma_pages = drm_calloc(sizeof(drm_savage_dma_page_t), - dev_priv->nr_dma_pages, DRM_MEM_DRIVER); + dev_priv->dma_pages = drm_calloc(1, sizeof(*dev_priv->dma_pages)); if (dev_priv->dma_pages == NULL) return ENOMEM; @@ -735,8 +734,7 @@ static int savage_do_init_bci(struct drm_device *dev, drm_savage_init_t *init) dev_priv->fake_dma.offset = 0; dev_priv->fake_dma.size = SAVAGE_FAKE_DMA_SIZE; dev_priv->fake_dma.type = _DRM_SHM; - dev_priv->fake_dma.handle = drm_alloc(SAVAGE_FAKE_DMA_SIZE, - DRM_MEM_DRIVER); + dev_priv->fake_dma.handle = drm_alloc(SAVAGE_FAKE_DMA_SIZE); if (!dev_priv->fake_dma.handle) { DRM_ERROR("could not allocate faked DMA buffer!\n"); savage_do_cleanup_bci(dev); @@ -836,8 +834,7 @@ static int savage_do_cleanup_bci(struct drm_device *dev) if (dev_priv->cmd_dma == &dev_priv->fake_dma) { if (dev_priv->fake_dma.handle) - drm_free(dev_priv->fake_dma.handle, - SAVAGE_FAKE_DMA_SIZE, DRM_MEM_DRIVER); + drm_free(dev_priv->fake_dma.handle); } else if (dev_priv->cmd_dma && dev_priv->cmd_dma->handle && dev_priv->cmd_dma->type == _DRM_AGP && dev_priv->dma_type == SAVAGE_DMA_AGP) @@ -853,9 +850,7 @@ static int savage_do_cleanup_bci(struct drm_device *dev) } if (dev_priv->dma_pages) - drm_free(dev_priv->dma_pages, - sizeof(drm_savage_dma_page_t)*dev_priv->nr_dma_pages, - DRM_MEM_DRIVER); + drm_free(dev_priv->dma_pages); return 0; } diff --git a/sys/dev/pci/drm/savage_state.c b/sys/dev/pci/drm/savage_state.c index 024cc46370e..25e1aeb6005 100644 --- a/sys/dev/pci/drm/savage_state.c +++ b/sys/dev/pci/drm/savage_state.c @@ -987,20 +987,20 @@ int savage_bci_cmdbuf(struct drm_device *dev, void *data, struct drm_file *file_ * for locking on FreeBSD. */ if (cmdbuf->size) { - kcmd_addr = drm_calloc(cmdbuf->size, 8, DRM_MEM_DRIVER); + kcmd_addr = drm_calloc(cmdbuf->size, 8); if (kcmd_addr == NULL) return ENOMEM; if (DRM_COPY_FROM_USER(kcmd_addr, cmdbuf->cmd_addr, cmdbuf->size * 8)) { - drm_free(kcmd_addr, cmdbuf->size * 8, DRM_MEM_DRIVER); + drm_free(kcmd_addr); return EFAULT; } cmdbuf->cmd_addr = kcmd_addr; } if (cmdbuf->vb_size) { - kvb_addr = drm_alloc(cmdbuf->vb_size, DRM_MEM_DRIVER); + kvb_addr = drm_alloc(cmdbuf->vb_size); if (kvb_addr == NULL) { ret = ENOMEM; goto done; @@ -1014,8 +1014,7 @@ int savage_bci_cmdbuf(struct drm_device *dev, void *data, struct drm_file *file_ cmdbuf->vb_addr = kvb_addr; } if (cmdbuf->nbox) { - kbox_addr = drm_calloc(cmdbuf->nbox, - sizeof(struct drm_clip_rect), DRM_MEM_DRIVER); + kbox_addr = drm_calloc(cmdbuf->nbox, sizeof(*kbox_addr)); if (kbox_addr == NULL) { ret = ENOMEM; goto done; @@ -1156,10 +1155,9 @@ int savage_bci_cmdbuf(struct drm_device *dev, void *data, struct drm_file *file_ done: /* If we didn't need to allocate them, these'll be NULL */ - drm_free(kcmd_addr, cmdbuf->size * 8, DRM_MEM_DRIVER); - drm_free(kvb_addr, cmdbuf->vb_size, DRM_MEM_DRIVER); - drm_free(kbox_addr, cmdbuf->nbox * sizeof(struct drm_clip_rect), - DRM_MEM_DRIVER); + drm_free(kcmd_addr); + drm_free(kvb_addr); + drm_free(kbox_addr); return ret; } diff --git a/sys/dev/pci/drm/sis_ds.c b/sys/dev/pci/drm/sis_ds.c index 2e485d48294..959ddd96927 100644 --- a/sys/dev/pci/drm/sis_ds.c +++ b/sys/dev/pci/drm/sis_ds.c @@ -41,7 +41,7 @@ set_t *setInit(void) int i; set_t *set; - set = (set_t *) drm_alloc(sizeof(set_t), DRM_MEM_DRIVER); + set = drm_alloc(sizeof(*set)); if (set != NULL) { for (i = 0; i < SET_SIZE; i++) { set->list[i].free_next = i + 1; @@ -127,7 +127,7 @@ int setNext(set_t * set, ITEM_TYPE * item) int setDestroy(set_t * set) { - drm_free(set, sizeof(set_t), DRM_MEM_DRIVER); + drm_free(set); return 1; } @@ -165,7 +165,7 @@ memHeap_t *mmInit(int ofs, int size) if (size <= 0) return NULL; - blocks = (TMemBlock *) drm_calloc(1, sizeof(TMemBlock), DRM_MEM_DRIVER); + blocks = drm_calloc(1, sizeof(*blocks)); if (blocks != NULL) { blocks->ofs = ofs; blocks->size = size; @@ -201,8 +201,7 @@ static TMemBlock *SliceBlock(TMemBlock * p, /* break left */ if (startofs > p->ofs) { - newblock = (TMemBlock *) drm_calloc(1, sizeof(TMemBlock), - DRM_MEM_DRIVER); + newblock = drm_calloc(1, sizeof(*newblock)); newblock->ofs = startofs; newblock->size = p->size - (startofs - p->ofs); newblock->free = 1; @@ -214,8 +213,7 @@ static TMemBlock *SliceBlock(TMemBlock * p, /* break right */ if (size < p->size) { - newblock = (TMemBlock *) drm_calloc(1, sizeof(TMemBlock), - DRM_MEM_DRIVER); + newblock = drm_calloc(1, sizeof(*newblock)); newblock->ofs = startofs + size; newblock->size = p->size - size; newblock->free = 1; @@ -267,7 +265,7 @@ static __inline__ int Join2Blocks(TMemBlock * p) TMemBlock *q = p->next; p->size += q->size; p->next = q->next; - drm_free(q, sizeof(TMemBlock), DRM_MEM_DRIVER); + drm_free(q); return 1; } return 0; |