X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavutil%2Fmem.h;h=97243d297aacf1643dc8fb645aab829ec83b33e8;hb=4d55404fcaec83f1ac2beb640198ad9399116bb8;hp=0d3e7f3ba0cba24a6405a023613702244c792fee;hpb=8a2d973dfc92011b8e9e09e471faa8b14882e1e5;p=ffmpeg diff --git a/libavutil/mem.h b/libavutil/mem.h index 0d3e7f3ba0c..97243d297aa 100644 --- a/libavutil/mem.h +++ b/libavutil/mem.h @@ -20,53 +20,85 @@ /** * @file mem.h - * Memory handling functions. + * memory handling functions */ -#ifndef AV_MEM_H -#define AV_MEM_H +#ifndef AVUTIL_MEM_H +#define AVUTIL_MEM_H -#ifdef __GNUC__ - #define DECLARE_ALIGNED(n,t,v) t v __attribute__ ((aligned (n))) +#include "common.h" + +#if AV_GCC_VERSION_AT_LEAST(3,1) + #define av_malloc_attrib __attribute__((__malloc__)) +#else + #define av_malloc_attrib +#endif + +#if (!defined(__ICC) || __ICC > 1100) && AV_GCC_VERSION_AT_LEAST(4,3) + #define av_alloc_size(n) __attribute__((alloc_size(n))) #else - #define DECLARE_ALIGNED(n,t,v) __declspec(align(n)) t v + #define av_alloc_size(n) #endif /** - * Memory allocation of size bytes with alignment suitable for all - * memory accesses (including vectors if available on the - * CPU). av_malloc(0) must return a non-NULL pointer. + * Allocates a block of \p size bytes with alignment suitable for all + * memory accesses (including vectors if available on the CPU). + * @param size Size in bytes for the memory block to be allocated. + * @return Pointer to the allocated block, NULL if the block cannot + * be allocated. + * @see av_mallocz() */ -void *av_malloc(unsigned int size); +void *av_malloc(unsigned int size) av_malloc_attrib av_alloc_size(1); /** - * av_realloc semantics (same as glibc): If ptr is NULL and size > 0, - * identical to malloc(size). If size is zero, it is identical to - * free(ptr) and NULL is returned. + * Allocates or reallocates a block of memory. + * If \p ptr is NULL and \p size > 0, allocates a new block. If \p + * size is zero, frees the memory block pointed to by \p ptr. + * @param size Size in bytes for the memory block to be allocated or + * reallocated. + * @param ptr Pointer to a memory block already allocated with + * av_malloc(z)() or av_realloc() or NULL. + * @return Pointer to a newly reallocated block or NULL if the block + * cannot be reallocated or the function is used to free the memory block. + * @see av_fast_realloc() */ -void *av_realloc(void *ptr, unsigned int size); +void *av_realloc(void *ptr, unsigned int size) av_alloc_size(2); /** - * Free memory which has been allocated with av_malloc(z)() or av_realloc(). - * NOTE: ptr = NULL is explicitly allowed. - * Note2: It is recommended that you use av_freep() instead. + * Frees a memory block which has been allocated with av_malloc(z)() or + * av_realloc(). + * @param ptr Pointer to the memory block which should be freed. + * @note ptr = NULL is explicitly allowed. + * @note It is recommended that you use av_freep() instead. + * @see av_freep() */ void av_free(void *ptr); -void *av_mallocz(unsigned int size); +/** + * Allocates a block of \p size bytes with alignment suitable for all + * memory accesses (including vectors if available on the CPU) and + * zeroes all the bytes of the block. + * @param size Size in bytes for the memory block to be allocated. + * @return Pointer to the allocated block, NULL if it cannot be allocated. + * @see av_malloc() + */ +void *av_mallocz(unsigned int size) av_malloc_attrib av_alloc_size(1); /** - * Duplicate the string \p s. - * @param s String to be duplicated. + * Duplicates the string \p s. + * @param s string to be duplicated * @return Pointer to a newly allocated string containing a - * copy of \p s or NULL if it cannot be allocated. + * copy of \p s or NULL if the string cannot be allocated. */ -char *av_strdup(const char *s); +char *av_strdup(const char *s) av_malloc_attrib; /** - * Free memory and set the pointer to NULL. - * @param ptr pointer to the pointer which should be freed. + * Frees a memory block which has been allocated with av_malloc(z)() or + * av_realloc() and set the pointer pointing to it to NULL. + * @param ptr Pointer to the pointer to the memory block which should + * be freed. + * @see av_free() */ void av_freep(void *ptr); -#endif /* AV_MEM_H */ +#endif /* AVUTIL_MEM_H */