d82a5e6a34
Implement the *allocx() API, which is a successor to the *allocm() API. The *allocx() functions are slightly simpler to use because they have fewer parameters, they directly return the results of primary interest, and mallocx()/rallocx() avoid the strict aliasing pitfall that allocm()/rallocx() share with posix_memalign(). The following code violates strict aliasing rules: foo_t *foo; allocm((void **)&foo, NULL, 42, 0); whereas the following is safe: foo_t *foo; void *p; allocm(&p, NULL, 42, 0); foo = (foo_t *)p; mallocx() does not have this problem: foo_t *foo = (foo_t *)mallocx(42, 0);
59 lines
2.6 KiB
C
59 lines
2.6 KiB
C
/*
|
|
* The @je_@ prefix on the following public symbol declarations is an artifact
|
|
* of namespace management, and should be omitted in application code unless
|
|
* JEMALLOC_NO_DEMANGLE is defined (see jemalloc_mangle@install_suffix@.h).
|
|
*/
|
|
extern JEMALLOC_EXPORT const char *@je_@malloc_conf;
|
|
extern JEMALLOC_EXPORT void (*@je_@malloc_message)(void *cbopaque,
|
|
const char *s);
|
|
|
|
JEMALLOC_EXPORT void *@je_@malloc(size_t size) JEMALLOC_ATTR(malloc);
|
|
JEMALLOC_EXPORT void *@je_@calloc(size_t num, size_t size)
|
|
JEMALLOC_ATTR(malloc);
|
|
JEMALLOC_EXPORT int @je_@posix_memalign(void **memptr, size_t alignment,
|
|
size_t size) JEMALLOC_ATTR(nonnull(1));
|
|
JEMALLOC_EXPORT void *@je_@aligned_alloc(size_t alignment, size_t size)
|
|
JEMALLOC_ATTR(malloc);
|
|
JEMALLOC_EXPORT void *@je_@realloc(void *ptr, size_t size);
|
|
JEMALLOC_EXPORT void @je_@free(void *ptr);
|
|
|
|
JEMALLOC_EXPORT void *@je_@mallocx(size_t size, int flags);
|
|
JEMALLOC_EXPORT void *@je_@rallocx(void *ptr, size_t size, int flags);
|
|
JEMALLOC_EXPORT size_t @je_@xallocx(void *ptr, size_t size, size_t extra,
|
|
int flags);
|
|
JEMALLOC_EXPORT size_t @je_@sallocx(const void *ptr, int flags);
|
|
JEMALLOC_EXPORT void @je_@dallocx(void *ptr, int flags);
|
|
JEMALLOC_EXPORT size_t @je_@nallocx(size_t size, int flags);
|
|
|
|
JEMALLOC_EXPORT int @je_@mallctl(const char *name, void *oldp,
|
|
size_t *oldlenp, void *newp, size_t newlen);
|
|
JEMALLOC_EXPORT int @je_@mallctlnametomib(const char *name, size_t *mibp,
|
|
size_t *miblenp);
|
|
JEMALLOC_EXPORT int @je_@mallctlbymib(const size_t *mib, size_t miblen,
|
|
void *oldp, size_t *oldlenp, void *newp, size_t newlen);
|
|
JEMALLOC_EXPORT void @je_@malloc_stats_print(void (*write_cb)(void *,
|
|
const char *), void *@je_@cbopaque, const char *opts);
|
|
JEMALLOC_EXPORT size_t @je_@malloc_usable_size(
|
|
JEMALLOC_USABLE_SIZE_CONST void *ptr);
|
|
|
|
#ifdef JEMALLOC_OVERRIDE_MEMALIGN
|
|
JEMALLOC_EXPORT void * @je_@memalign(size_t alignment, size_t size)
|
|
JEMALLOC_ATTR(malloc);
|
|
#endif
|
|
|
|
#ifdef JEMALLOC_OVERRIDE_VALLOC
|
|
JEMALLOC_EXPORT void * @je_@valloc(size_t size) JEMALLOC_ATTR(malloc);
|
|
#endif
|
|
|
|
#ifdef JEMALLOC_EXPERIMENTAL
|
|
JEMALLOC_EXPORT int @je_@allocm(void **ptr, size_t *rsize, size_t size,
|
|
int flags) JEMALLOC_ATTR(nonnull(1));
|
|
JEMALLOC_EXPORT int @je_@rallocm(void **ptr, size_t *rsize, size_t size,
|
|
size_t extra, int flags) JEMALLOC_ATTR(nonnull(1));
|
|
JEMALLOC_EXPORT int @je_@sallocm(const void *ptr, size_t *rsize, int flags)
|
|
JEMALLOC_ATTR(nonnull(1));
|
|
JEMALLOC_EXPORT int @je_@dallocm(void *ptr, int flags)
|
|
JEMALLOC_ATTR(nonnull(1));
|
|
JEMALLOC_EXPORT int @je_@nallocm(size_t *rsize, size_t size, int flags);
|
|
#endif
|