| @@ -82,6 +82,16 @@ | |||||
| */ | */ | ||||
| void *av_malloc(size_t size) av_malloc_attrib av_alloc_size(1); | void *av_malloc(size_t size) av_malloc_attrib av_alloc_size(1); | ||||
| /** | |||||
| * Allocate a block of size bytes with alignment suitable for all | |||||
| * memory accesses (including vectors if available on the CPU) and | |||||
| * zero 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(size_t size) av_malloc_attrib av_alloc_size(1); | |||||
| /** | /** | ||||
| * Allocate a block of size * nmemb bytes with av_malloc(). | * Allocate a block of size * nmemb bytes with av_malloc(). | ||||
| * @param nmemb Number of elements | * @param nmemb Number of elements | ||||
| @@ -97,6 +107,34 @@ av_alloc_size(1, 2) static inline void *av_malloc_array(size_t nmemb, size_t siz | |||||
| return av_malloc(nmemb * size); | return av_malloc(nmemb * size); | ||||
| } | } | ||||
| /** | |||||
| * Allocate a block of size * nmemb bytes with av_mallocz(). | |||||
| * @param nmemb Number of elements | |||||
| * @param size Size of the single element | |||||
| * @return Pointer to the allocated block, NULL if the block cannot | |||||
| * be allocated. | |||||
| * @see av_mallocz() | |||||
| * @see av_malloc_array() | |||||
| */ | |||||
| av_alloc_size(1, 2) static inline void *av_mallocz_array(size_t nmemb, size_t size) | |||||
| { | |||||
| if (!size || nmemb >= INT_MAX / size) | |||||
| return NULL; | |||||
| return av_mallocz(nmemb * size); | |||||
| } | |||||
| /** | |||||
| * Allocate a block of nmemb * size bytes with alignment suitable for all | |||||
| * memory accesses (including vectors if available on the CPU) and | |||||
| * zero all the bytes of the block. | |||||
| * The allocation will fail if nmemb * size is greater than or equal | |||||
| * to INT_MAX. | |||||
| * @param nmemb | |||||
| * @param size | |||||
| * @return Pointer to the allocated block, NULL if it cannot be allocated. | |||||
| */ | |||||
| void *av_calloc(size_t nmemb, size_t size) av_malloc_attrib; | |||||
| /** | /** | ||||
| * Allocate or reallocate a block of memory. | * Allocate or reallocate a block of memory. | ||||
| * If ptr is NULL and size > 0, allocate a new block. If | * If ptr is NULL and size > 0, allocate a new block. If | ||||
| @@ -117,16 +155,6 @@ av_alloc_size(1, 2) static inline void *av_malloc_array(size_t nmemb, size_t siz | |||||
| */ | */ | ||||
| void *av_realloc(void *ptr, size_t size) av_alloc_size(2); | void *av_realloc(void *ptr, size_t size) av_alloc_size(2); | ||||
| /** | |||||
| * Allocate or reallocate a block of memory. | |||||
| * This function does the same thing as av_realloc, except: | |||||
| * - It takes two arguments and checks the result of the multiplication for | |||||
| * integer overflow. | |||||
| * - It frees the input block in case of failure, thus avoiding the memory | |||||
| * leak with the classic "buf = realloc(buf); if (!buf) return -1;". | |||||
| */ | |||||
| void *av_realloc_f(void *ptr, size_t nelem, size_t elsize); | |||||
| /** | /** | ||||
| * Allocate or reallocate a block of memory. | * Allocate or reallocate a block of memory. | ||||
| * If *ptr is NULL and size > 0, allocate a new block. If | * If *ptr is NULL and size > 0, allocate a new block. If | ||||
| @@ -147,6 +175,16 @@ void *av_realloc_f(void *ptr, size_t nelem, size_t elsize); | |||||
| av_warn_unused_result | av_warn_unused_result | ||||
| int av_reallocp(void *ptr, size_t size); | int av_reallocp(void *ptr, size_t size); | ||||
| /** | |||||
| * Allocate or reallocate a block of memory. | |||||
| * This function does the same thing as av_realloc, except: | |||||
| * - It takes two arguments and checks the result of the multiplication for | |||||
| * integer overflow. | |||||
| * - It frees the input block in case of failure, thus avoiding the memory | |||||
| * leak with the classic "buf = realloc(buf); if (!buf) return -1;". | |||||
| */ | |||||
| void *av_realloc_f(void *ptr, size_t nelem, size_t elsize); | |||||
| /** | /** | ||||
| * Allocate or reallocate an array. | * Allocate or reallocate an array. | ||||
| * If ptr is NULL and nmemb > 0, allocate a new block. If | * If ptr is NULL and nmemb > 0, allocate a new block. If | ||||
| @@ -185,6 +223,42 @@ av_alloc_size(2, 3) void *av_realloc_array(void *ptr, size_t nmemb, size_t size) | |||||
| */ | */ | ||||
| av_alloc_size(2, 3) int av_reallocp_array(void *ptr, size_t nmemb, size_t size); | av_alloc_size(2, 3) int av_reallocp_array(void *ptr, size_t nmemb, size_t size); | ||||
| /** | |||||
| * Reallocate the given block if it is not large enough, otherwise do nothing. | |||||
| * | |||||
| * @see av_realloc | |||||
| */ | |||||
| void *av_fast_realloc(void *ptr, unsigned int *size, size_t min_size); | |||||
| /** | |||||
| * Allocate a buffer, reusing the given one if large enough. | |||||
| * | |||||
| * Contrary to av_fast_realloc the current buffer contents might not be | |||||
| * preserved and on error the old buffer is freed, thus no special | |||||
| * handling to avoid memleaks is necessary. | |||||
| * | |||||
| * @param ptr pointer to pointer to already allocated buffer, overwritten with pointer to new buffer | |||||
| * @param size size of the buffer *ptr points to | |||||
| * @param min_size minimum size of *ptr buffer after returning, *ptr will be NULL and | |||||
| * *size 0 if an error occurred. | |||||
| */ | |||||
| void av_fast_malloc(void *ptr, unsigned int *size, size_t min_size); | |||||
| /** | |||||
| * Allocate a buffer, reusing the given one if large enough. | |||||
| * | |||||
| * All newly allocated space is initially cleared | |||||
| * Contrary to av_fast_realloc the current buffer contents might not be | |||||
| * preserved and on error the old buffer is freed, thus no special | |||||
| * handling to avoid memleaks is necessary. | |||||
| * | |||||
| * @param ptr pointer to pointer to already allocated buffer, overwritten with pointer to new buffer | |||||
| * @param size size of the buffer *ptr points to | |||||
| * @param min_size minimum size of *ptr buffer after returning, *ptr will be NULL and | |||||
| * *size 0 if an error occurred. | |||||
| */ | |||||
| void av_fast_mallocz(void *ptr, unsigned int *size, size_t min_size); | |||||
| /** | /** | ||||
| * Free a memory block which has been allocated with av_malloc(z)() or | * Free a memory block which has been allocated with av_malloc(z)() or | ||||
| * av_realloc(). | * av_realloc(). | ||||
| @@ -196,42 +270,14 @@ av_alloc_size(2, 3) int av_reallocp_array(void *ptr, size_t nmemb, size_t size); | |||||
| void av_free(void *ptr); | void av_free(void *ptr); | ||||
| /** | /** | ||||
| * Allocate a block of size bytes with alignment suitable for all | |||||
| * memory accesses (including vectors if available on the CPU) and | |||||
| * zero 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(size_t size) av_malloc_attrib av_alloc_size(1); | |||||
| /** | |||||
| * Allocate a block of nmemb * size bytes with alignment suitable for all | |||||
| * memory accesses (including vectors if available on the CPU) and | |||||
| * zero all the bytes of the block. | |||||
| * The allocation will fail if nmemb * size is greater than or equal | |||||
| * to INT_MAX. | |||||
| * @param nmemb | |||||
| * @param size | |||||
| * @return Pointer to the allocated block, NULL if it cannot be allocated. | |||||
| */ | |||||
| void *av_calloc(size_t nmemb, size_t size) av_malloc_attrib; | |||||
| /** | |||||
| * Allocate a block of size * nmemb bytes with av_mallocz(). | |||||
| * @param nmemb Number of elements | |||||
| * @param size Size of the single element | |||||
| * @return Pointer to the allocated block, NULL if the block cannot | |||||
| * be allocated. | |||||
| * @see av_mallocz() | |||||
| * @see av_malloc_array() | |||||
| * Free 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. | |||||
| * @note passing a pointer to a NULL pointer is safe and leads to no action. | |||||
| * @see av_free() | |||||
| */ | */ | ||||
| av_alloc_size(1, 2) static inline void *av_mallocz_array(size_t nmemb, size_t size) | |||||
| { | |||||
| if (!size || nmemb >= INT_MAX / size) | |||||
| return NULL; | |||||
| return av_mallocz(nmemb * size); | |||||
| } | |||||
| void av_freep(void *ptr); | |||||
| /** | /** | ||||
| * Duplicate the string s. | * Duplicate the string s. | ||||
| @@ -260,14 +306,15 @@ char *av_strndup(const char *s, size_t len) av_malloc_attrib; | |||||
| void *av_memdup(const void *p, size_t size); | void *av_memdup(const void *p, size_t size); | ||||
| /** | /** | ||||
| * Free 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. | |||||
| * @note passing a pointer to a NULL pointer is safe and leads to no action. | |||||
| * @see av_free() | |||||
| * deliberately overlapping memcpy implementation | |||||
| * @param dst destination buffer | |||||
| * @param back how many bytes back we start (the initial size of the overlapping window), must be > 0 | |||||
| * @param cnt number of bytes to copy, must be >= 0 | |||||
| * | |||||
| * cnt > back is valid, this will copy the bytes we just copied, | |||||
| * thus creating a repeating pattern with a period length of back. | |||||
| */ | */ | ||||
| void av_freep(void *ptr); | |||||
| void av_memcpy_backptr(uint8_t *dst, int back, int cnt); | |||||
| /** | /** | ||||
| * Add an element to a dynamic array. | * Add an element to a dynamic array. | ||||
| @@ -352,53 +399,6 @@ static inline int av_size_mult(size_t a, size_t b, size_t *r) | |||||
| */ | */ | ||||
| void av_max_alloc(size_t max); | void av_max_alloc(size_t max); | ||||
| /** | |||||
| * deliberately overlapping memcpy implementation | |||||
| * @param dst destination buffer | |||||
| * @param back how many bytes back we start (the initial size of the overlapping window), must be > 0 | |||||
| * @param cnt number of bytes to copy, must be >= 0 | |||||
| * | |||||
| * cnt > back is valid, this will copy the bytes we just copied, | |||||
| * thus creating a repeating pattern with a period length of back. | |||||
| */ | |||||
| void av_memcpy_backptr(uint8_t *dst, int back, int cnt); | |||||
| /** | |||||
| * Reallocate the given block if it is not large enough, otherwise do nothing. | |||||
| * | |||||
| * @see av_realloc | |||||
| */ | |||||
| void *av_fast_realloc(void *ptr, unsigned int *size, size_t min_size); | |||||
| /** | |||||
| * Allocate a buffer, reusing the given one if large enough. | |||||
| * | |||||
| * Contrary to av_fast_realloc the current buffer contents might not be | |||||
| * preserved and on error the old buffer is freed, thus no special | |||||
| * handling to avoid memleaks is necessary. | |||||
| * | |||||
| * @param ptr pointer to pointer to already allocated buffer, overwritten with pointer to new buffer | |||||
| * @param size size of the buffer *ptr points to | |||||
| * @param min_size minimum size of *ptr buffer after returning, *ptr will be NULL and | |||||
| * *size 0 if an error occurred. | |||||
| */ | |||||
| void av_fast_malloc(void *ptr, unsigned int *size, size_t min_size); | |||||
| /** | |||||
| * Allocate a buffer, reusing the given one if large enough. | |||||
| * | |||||
| * All newly allocated space is initially cleared | |||||
| * Contrary to av_fast_realloc the current buffer contents might not be | |||||
| * preserved and on error the old buffer is freed, thus no special | |||||
| * handling to avoid memleaks is necessary. | |||||
| * | |||||
| * @param ptr pointer to pointer to already allocated buffer, overwritten with pointer to new buffer | |||||
| * @param size size of the buffer *ptr points to | |||||
| * @param min_size minimum size of *ptr buffer after returning, *ptr will be NULL and | |||||
| * *size 0 if an error occurred. | |||||
| */ | |||||
| void av_fast_mallocz(void *ptr, unsigned int *size, size_t min_size); | |||||
| /** | /** | ||||
| * @} | * @} | ||||
| */ | */ | ||||