| posix_memalign(3) | Library Functions Manual | posix_memalign(3) |
NAME
posix_memalign - allocate aligned memory
LIBRARY
Standard C library (libc, -lc)
SYNOPSIS
#include <stdlib.h>
int posix_memalign(void **memptr, size_t alignment, size_t size);
posix_memalign():
_POSIX_C_SOURCE >= 200112L
DESCRIPTION
posix_memalign() allocates size bytes and places the address of the allocated memory in *memptr. The address of the allocated memory will be a multiple of alignment, which must be a power of two and a multiple of sizeof(void *). This address can later be successfully passed to free(3). If size is 0, then the value placed in *memptr is either NULL or a unique pointer value.
The memory is not zeroed.
aligned_alloc(3) is a standard function that provides the same functionality, and has a more ergonomic prototype. Use that instead.
RETURN VALUE
posix_memalign() returns zero on success, or one of the error values listed in the next section on failure. The value of errno is not set.
ERRORS
ATTRIBUTES
For an explanation of the terms used in this section, see attributes(7).
| Interface | Attribute | Value |
| posix_memalign () | Thread safety | MT-Safe |
STANDARDS
POSIX.1-2024.
HISTORY
glibc 2.1.91. POSIX.1d, POSIX.1-2001.
CAVEATS
On Linux (and other systems), posix_memalign() does not modify memptr on failure. A requirement standardizing this behavior was added in POSIX.1-2008 TC2.
SEE ALSO
| 2026-02-08 | Linux man-pages 6.17 |