Merge "Hides valloc(3)/pvalloc(3) on LP64."
This commit is contained in:
commit
65b1c90a32
|
@ -61,9 +61,13 @@ static const MallocDebug __libc_malloc_default_dispatch __attribute__((aligned(3
|
||||||
Malloc(malloc_usable_size),
|
Malloc(malloc_usable_size),
|
||||||
Malloc(memalign),
|
Malloc(memalign),
|
||||||
Malloc(posix_memalign),
|
Malloc(posix_memalign),
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
Malloc(pvalloc),
|
Malloc(pvalloc),
|
||||||
|
#endif
|
||||||
Malloc(realloc),
|
Malloc(realloc),
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
Malloc(valloc),
|
Malloc(valloc),
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
// Selector of dispatch table to use for dispatching malloc calls.
|
// Selector of dispatch table to use for dispatching malloc calls.
|
||||||
|
@ -258,17 +262,21 @@ extern "C" int posix_memalign(void** memptr, size_t alignment, size_t size) {
|
||||||
return __libc_malloc_dispatch->posix_memalign(memptr, alignment, size);
|
return __libc_malloc_dispatch->posix_memalign(memptr, alignment, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
extern "C" void* pvalloc(size_t bytes) {
|
extern "C" void* pvalloc(size_t bytes) {
|
||||||
return __libc_malloc_dispatch->pvalloc(bytes);
|
return __libc_malloc_dispatch->pvalloc(bytes);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
extern "C" void* realloc(void* oldMem, size_t bytes) {
|
extern "C" void* realloc(void* oldMem, size_t bytes) {
|
||||||
return __libc_malloc_dispatch->realloc(oldMem, bytes);
|
return __libc_malloc_dispatch->realloc(oldMem, bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
extern "C" void* valloc(size_t bytes) {
|
extern "C" void* valloc(size_t bytes) {
|
||||||
return __libc_malloc_dispatch->valloc(bytes);
|
return __libc_malloc_dispatch->valloc(bytes);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// We implement malloc debugging only in libc.so, so the code below
|
// We implement malloc debugging only in libc.so, so the code below
|
||||||
// must be excluded if we compile this file for static libc.a
|
// must be excluded if we compile this file for static libc.a
|
||||||
|
@ -299,9 +307,13 @@ static void InitMalloc(void* malloc_impl_handler, MallocDebug* table, const char
|
||||||
InitMallocFunction<MallocDebugMallocUsableSize>(malloc_impl_handler, &table->malloc_usable_size, prefix, "malloc_usable_size");
|
InitMallocFunction<MallocDebugMallocUsableSize>(malloc_impl_handler, &table->malloc_usable_size, prefix, "malloc_usable_size");
|
||||||
InitMallocFunction<MallocDebugMemalign>(malloc_impl_handler, &table->memalign, prefix, "memalign");
|
InitMallocFunction<MallocDebugMemalign>(malloc_impl_handler, &table->memalign, prefix, "memalign");
|
||||||
InitMallocFunction<MallocDebugPosixMemalign>(malloc_impl_handler, &table->posix_memalign, prefix, "posix_memalign");
|
InitMallocFunction<MallocDebugPosixMemalign>(malloc_impl_handler, &table->posix_memalign, prefix, "posix_memalign");
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
InitMallocFunction<MallocDebugPvalloc>(malloc_impl_handler, &table->pvalloc, prefix, "pvalloc");
|
InitMallocFunction<MallocDebugPvalloc>(malloc_impl_handler, &table->pvalloc, prefix, "pvalloc");
|
||||||
|
#endif
|
||||||
InitMallocFunction<MallocDebugRealloc>(malloc_impl_handler, &table->realloc, prefix, "realloc");
|
InitMallocFunction<MallocDebugRealloc>(malloc_impl_handler, &table->realloc, prefix, "realloc");
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
InitMallocFunction<MallocDebugValloc>(malloc_impl_handler, &table->valloc, prefix, "valloc");
|
InitMallocFunction<MallocDebugValloc>(malloc_impl_handler, &table->valloc, prefix, "valloc");
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initializes memory allocation framework once per process.
|
// Initializes memory allocation framework once per process.
|
||||||
|
@ -447,9 +459,14 @@ static void malloc_init_impl() {
|
||||||
(malloc_dispatch_table.malloc_usable_size == NULL) ||
|
(malloc_dispatch_table.malloc_usable_size == NULL) ||
|
||||||
(malloc_dispatch_table.memalign == NULL) ||
|
(malloc_dispatch_table.memalign == NULL) ||
|
||||||
(malloc_dispatch_table.posix_memalign == NULL) ||
|
(malloc_dispatch_table.posix_memalign == NULL) ||
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
(malloc_dispatch_table.pvalloc == NULL) ||
|
(malloc_dispatch_table.pvalloc == NULL) ||
|
||||||
(malloc_dispatch_table.realloc == NULL) ||
|
#endif
|
||||||
(malloc_dispatch_table.valloc == NULL)) {
|
(malloc_dispatch_table.realloc == NULL)
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
|
|| (malloc_dispatch_table.valloc == NULL)
|
||||||
|
#endif
|
||||||
|
) {
|
||||||
error_log("%s: some symbols for libc.debug.malloc level %d were not found (see above)",
|
error_log("%s: some symbols for libc.debug.malloc level %d were not found (see above)",
|
||||||
getprogname(), g_malloc_debug_level);
|
getprogname(), g_malloc_debug_level);
|
||||||
dlclose(malloc_impl_handle);
|
dlclose(malloc_impl_handle);
|
||||||
|
|
|
@ -61,6 +61,12 @@
|
||||||
#define Malloc(function) dl ## function
|
#define Malloc(function) dl ## function
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// valloc(3) and pvalloc(3) were removed from POSIX 2004. We do not include them
|
||||||
|
// for LP64, but the symbols remain in LP32 for binary compatibility.
|
||||||
|
#ifndef __LP64__
|
||||||
|
#define HAVE_DEPRECATED_MALLOC_FUNCS 1
|
||||||
|
#endif
|
||||||
|
|
||||||
// =============================================================================
|
// =============================================================================
|
||||||
// Structures
|
// Structures
|
||||||
// =============================================================================
|
// =============================================================================
|
||||||
|
@ -90,9 +96,14 @@ typedef void* (*MallocDebugMalloc)(size_t);
|
||||||
typedef size_t (*MallocDebugMallocUsableSize)(const void*);
|
typedef size_t (*MallocDebugMallocUsableSize)(const void*);
|
||||||
typedef void* (*MallocDebugMemalign)(size_t, size_t);
|
typedef void* (*MallocDebugMemalign)(size_t, size_t);
|
||||||
typedef int (*MallocDebugPosixMemalign)(void**, size_t, size_t);
|
typedef int (*MallocDebugPosixMemalign)(void**, size_t, size_t);
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
typedef void* (*MallocDebugPvalloc)(size_t);
|
typedef void* (*MallocDebugPvalloc)(size_t);
|
||||||
|
#endif
|
||||||
typedef void* (*MallocDebugRealloc)(void*, size_t);
|
typedef void* (*MallocDebugRealloc)(void*, size_t);
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
typedef void* (*MallocDebugValloc)(size_t);
|
typedef void* (*MallocDebugValloc)(size_t);
|
||||||
|
#endif
|
||||||
|
|
||||||
struct MallocDebug {
|
struct MallocDebug {
|
||||||
MallocDebugCalloc calloc;
|
MallocDebugCalloc calloc;
|
||||||
MallocDebugFree free;
|
MallocDebugFree free;
|
||||||
|
@ -101,9 +112,13 @@ struct MallocDebug {
|
||||||
MallocDebugMallocUsableSize malloc_usable_size;
|
MallocDebugMallocUsableSize malloc_usable_size;
|
||||||
MallocDebugMemalign memalign;
|
MallocDebugMemalign memalign;
|
||||||
MallocDebugPosixMemalign posix_memalign;
|
MallocDebugPosixMemalign posix_memalign;
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
MallocDebugPvalloc pvalloc;
|
MallocDebugPvalloc pvalloc;
|
||||||
|
#endif
|
||||||
MallocDebugRealloc realloc;
|
MallocDebugRealloc realloc;
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
MallocDebugValloc valloc;
|
MallocDebugValloc valloc;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef bool (*MallocDebugInit)(HashTable*);
|
typedef bool (*MallocDebugInit)(HashTable*);
|
||||||
|
|
|
@ -35,9 +35,6 @@ extern void free(void* p);
|
||||||
extern void* memalign(size_t alignment, size_t byte_count) __mallocfunc __wur __attribute__((alloc_size(2)));
|
extern void* memalign(size_t alignment, size_t byte_count) __mallocfunc __wur __attribute__((alloc_size(2)));
|
||||||
extern size_t malloc_usable_size(const void* p);
|
extern size_t malloc_usable_size(const void* p);
|
||||||
|
|
||||||
extern void* valloc(size_t byte_count) __mallocfunc __wur __attribute__((alloc_size(1)));
|
|
||||||
extern void* pvalloc(size_t byte_count) __mallocfunc __wur __attribute__((alloc_size(1)));
|
|
||||||
|
|
||||||
#ifndef STRUCT_MALLINFO_DECLARED
|
#ifndef STRUCT_MALLINFO_DECLARED
|
||||||
#define STRUCT_MALLINFO_DECLARED 1
|
#define STRUCT_MALLINFO_DECLARED 1
|
||||||
struct mallinfo {
|
struct mallinfo {
|
||||||
|
|
|
@ -115,9 +115,18 @@ libBionicStandardTests_src_files := \
|
||||||
libBionicStandardTests_cflags := \
|
libBionicStandardTests_cflags := \
|
||||||
$(test_cflags) \
|
$(test_cflags) \
|
||||||
|
|
||||||
|
ifeq ($(MALLOC_IMPL),jemalloc)
|
||||||
|
libBionicStandardTests_cflags += -DUSE_JEMALLOC
|
||||||
|
else
|
||||||
|
libBionicStandardTests_cflags += -DUSE_DLMALLOC
|
||||||
|
endif
|
||||||
|
|
||||||
libBionicStandardTests_cppflags := \
|
libBionicStandardTests_cppflags := \
|
||||||
$(test_cppflags) \
|
$(test_cppflags) \
|
||||||
|
|
||||||
|
libBionicStandardTests_c_includes := \
|
||||||
|
bionic/libc \
|
||||||
|
|
||||||
libBionicStandardTests_ldlibs_host := \
|
libBionicStandardTests_ldlibs_host := \
|
||||||
-lrt \
|
-lrt \
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,10 @@
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#if defined(__BIONIC__)
|
||||||
|
#include <libc/bionic/malloc_debug_common.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
TEST(malloc, malloc_std) {
|
TEST(malloc, malloc_std) {
|
||||||
// Simple malloc test.
|
// Simple malloc test.
|
||||||
void *ptr = malloc(100);
|
void *ptr = malloc(100);
|
||||||
|
@ -291,6 +295,10 @@ TEST(malloc, realloc_overflow) {
|
||||||
free(ptr);
|
free(ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(HAVE_DEPRECATED_MALLOC_FUNCS)
|
||||||
|
extern "C" void* pvalloc(size_t);
|
||||||
|
extern "C" void* valloc(size_t);
|
||||||
|
|
||||||
TEST(malloc, pvalloc_std) {
|
TEST(malloc, pvalloc_std) {
|
||||||
size_t pagesize = sysconf(_SC_PAGESIZE);
|
size_t pagesize = sysconf(_SC_PAGESIZE);
|
||||||
void* ptr = pvalloc(100);
|
void* ptr = pvalloc(100);
|
||||||
|
@ -315,3 +323,4 @@ TEST(malloc, valloc_std) {
|
||||||
TEST(malloc, valloc_overflow) {
|
TEST(malloc, valloc_overflow) {
|
||||||
ASSERT_EQ(NULL, valloc(SIZE_MAX));
|
ASSERT_EQ(NULL, valloc(SIZE_MAX));
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <malloc.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
@ -143,9 +144,9 @@ struct StringTestState {
|
||||||
int max_alignment = 64;
|
int max_alignment = 64;
|
||||||
|
|
||||||
// TODO: fix the tests to not sometimes use twice their specified "MAX_LEN".
|
// TODO: fix the tests to not sometimes use twice their specified "MAX_LEN".
|
||||||
glob_ptr = reinterpret_cast<Character*>(valloc(2 * sizeof(Character) * MAX_LEN + max_alignment));
|
glob_ptr = reinterpret_cast<Character*>(memalign(sysconf(_SC_PAGESIZE), 2 * sizeof(Character) * MAX_LEN + max_alignment));
|
||||||
glob_ptr1 = reinterpret_cast<Character*>(valloc(2 * sizeof(Character) * MAX_LEN + max_alignment));
|
glob_ptr1 = reinterpret_cast<Character*>(memalign(sysconf(_SC_PAGESIZE), 2 * sizeof(Character) * MAX_LEN + max_alignment));
|
||||||
glob_ptr2 = reinterpret_cast<Character*>(valloc(2 * sizeof(Character) * MAX_LEN + max_alignment));
|
glob_ptr2 = reinterpret_cast<Character*>(memalign(sysconf(_SC_PAGESIZE), 2 * sizeof(Character) * MAX_LEN + max_alignment));
|
||||||
|
|
||||||
InitLenArray();
|
InitLenArray();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue