|
Packit Service |
724aca |
#include "test/jemalloc_test.h"
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
#include "jemalloc/internal/util.h"
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
static arena_dalloc_junk_small_t *arena_dalloc_junk_small_orig;
|
|
Packit Service |
724aca |
static large_dalloc_junk_t *large_dalloc_junk_orig;
|
|
Packit Service |
724aca |
static large_dalloc_maybe_junk_t *large_dalloc_maybe_junk_orig;
|
|
Packit Service |
724aca |
static void *watch_for_junking;
|
|
Packit Service |
724aca |
static bool saw_junking;
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
static void
|
|
Packit Service |
724aca |
watch_junking(void *p) {
|
|
Packit Service |
724aca |
watch_for_junking = p;
|
|
Packit Service |
724aca |
saw_junking = false;
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
static void
|
|
Packit Service |
724aca |
arena_dalloc_junk_small_intercept(void *ptr, const bin_info_t *bin_info) {
|
|
Packit Service |
724aca |
size_t i;
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
arena_dalloc_junk_small_orig(ptr, bin_info);
|
|
Packit Service |
724aca |
for (i = 0; i < bin_info->reg_size; i++) {
|
|
Packit Service |
724aca |
assert_u_eq(((uint8_t *)ptr)[i], JEMALLOC_FREE_JUNK,
|
|
Packit Service |
724aca |
"Missing junk fill for byte %zu/%zu of deallocated region",
|
|
Packit Service |
724aca |
i, bin_info->reg_size);
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
if (ptr == watch_for_junking) {
|
|
Packit Service |
724aca |
saw_junking = true;
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
static void
|
|
Packit Service |
724aca |
large_dalloc_junk_intercept(void *ptr, size_t usize) {
|
|
Packit Service |
724aca |
size_t i;
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
large_dalloc_junk_orig(ptr, usize);
|
|
Packit Service |
724aca |
for (i = 0; i < usize; i++) {
|
|
Packit Service |
724aca |
assert_u_eq(((uint8_t *)ptr)[i], JEMALLOC_FREE_JUNK,
|
|
Packit Service |
724aca |
"Missing junk fill for byte %zu/%zu of deallocated region",
|
|
Packit Service |
724aca |
i, usize);
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
if (ptr == watch_for_junking) {
|
|
Packit Service |
724aca |
saw_junking = true;
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
static void
|
|
Packit Service |
724aca |
large_dalloc_maybe_junk_intercept(void *ptr, size_t usize) {
|
|
Packit Service |
724aca |
large_dalloc_maybe_junk_orig(ptr, usize);
|
|
Packit Service |
724aca |
if (ptr == watch_for_junking) {
|
|
Packit Service |
724aca |
saw_junking = true;
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
static void
|
|
Packit Service |
724aca |
test_junk(size_t sz_min, size_t sz_max) {
|
|
Packit Service |
724aca |
uint8_t *s;
|
|
Packit Service |
724aca |
size_t sz_prev, sz, i;
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
if (opt_junk_free) {
|
|
Packit Service |
724aca |
arena_dalloc_junk_small_orig = arena_dalloc_junk_small;
|
|
Packit Service |
724aca |
arena_dalloc_junk_small = arena_dalloc_junk_small_intercept;
|
|
Packit Service |
724aca |
large_dalloc_junk_orig = large_dalloc_junk;
|
|
Packit Service |
724aca |
large_dalloc_junk = large_dalloc_junk_intercept;
|
|
Packit Service |
724aca |
large_dalloc_maybe_junk_orig = large_dalloc_maybe_junk;
|
|
Packit Service |
724aca |
large_dalloc_maybe_junk = large_dalloc_maybe_junk_intercept;
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
sz_prev = 0;
|
|
Packit Service |
724aca |
s = (uint8_t *)mallocx(sz_min, 0);
|
|
Packit Service |
724aca |
assert_ptr_not_null((void *)s, "Unexpected mallocx() failure");
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
for (sz = sallocx(s, 0); sz <= sz_max;
|
|
Packit Service |
724aca |
sz_prev = sz, sz = sallocx(s, 0)) {
|
|
Packit Service |
724aca |
if (sz_prev > 0) {
|
|
Packit Service |
724aca |
assert_u_eq(s[0], 'a',
|
|
Packit Service |
724aca |
"Previously allocated byte %zu/%zu is corrupted",
|
|
Packit Service |
724aca |
ZU(0), sz_prev);
|
|
Packit Service |
724aca |
assert_u_eq(s[sz_prev-1], 'a',
|
|
Packit Service |
724aca |
"Previously allocated byte %zu/%zu is corrupted",
|
|
Packit Service |
724aca |
sz_prev-1, sz_prev);
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
for (i = sz_prev; i < sz; i++) {
|
|
Packit Service |
724aca |
if (opt_junk_alloc) {
|
|
Packit Service |
724aca |
assert_u_eq(s[i], JEMALLOC_ALLOC_JUNK,
|
|
Packit Service |
724aca |
"Newly allocated byte %zu/%zu isn't "
|
|
Packit Service |
724aca |
"junk-filled", i, sz);
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
s[i] = 'a';
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
if (xallocx(s, sz+1, 0, 0) == sz) {
|
|
Packit Service |
724aca |
uint8_t *t;
|
|
Packit Service |
724aca |
watch_junking(s);
|
|
Packit Service |
724aca |
t = (uint8_t *)rallocx(s, sz+1, 0);
|
|
Packit Service |
724aca |
assert_ptr_not_null((void *)t,
|
|
Packit Service |
724aca |
"Unexpected rallocx() failure");
|
|
Packit Service |
724aca |
assert_zu_ge(sallocx(t, 0), sz+1,
|
|
Packit Service |
724aca |
"Unexpectedly small rallocx() result");
|
|
Packit Service |
724aca |
if (!background_thread_enabled()) {
|
|
Packit Service |
724aca |
assert_ptr_ne(s, t,
|
|
Packit Service |
724aca |
"Unexpected in-place rallocx()");
|
|
Packit Service |
724aca |
assert_true(!opt_junk_free || saw_junking,
|
|
Packit Service |
724aca |
"Expected region of size %zu to be "
|
|
Packit Service |
724aca |
"junk-filled", sz);
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
s = t;
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
watch_junking(s);
|
|
Packit Service |
724aca |
dallocx(s, 0);
|
|
Packit Service |
724aca |
assert_true(!opt_junk_free || saw_junking,
|
|
Packit Service |
724aca |
"Expected region of size %zu to be junk-filled", sz);
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
if (opt_junk_free) {
|
|
Packit Service |
724aca |
arena_dalloc_junk_small = arena_dalloc_junk_small_orig;
|
|
Packit Service |
724aca |
large_dalloc_junk = large_dalloc_junk_orig;
|
|
Packit Service |
724aca |
large_dalloc_maybe_junk = large_dalloc_maybe_junk_orig;
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
TEST_BEGIN(test_junk_small) {
|
|
Packit Service |
724aca |
test_skip_if(!config_fill);
|
|
Packit Service |
724aca |
test_junk(1, SC_SMALL_MAXCLASS - 1);
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
TEST_END
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
TEST_BEGIN(test_junk_large) {
|
|
Packit Service |
724aca |
test_skip_if(!config_fill);
|
|
Packit Service |
724aca |
test_junk(SC_SMALL_MAXCLASS + 1, (1U << (SC_LG_LARGE_MINCLASS + 1)));
|
|
Packit Service |
724aca |
}
|
|
Packit Service |
724aca |
TEST_END
|
|
Packit Service |
724aca |
|
|
Packit Service |
724aca |
int
|
|
Packit Service |
724aca |
main(void) {
|
|
Packit Service |
724aca |
return test(
|
|
Packit Service |
724aca |
test_junk_small,
|
|
Packit Service |
724aca |
test_junk_large);
|
|
Packit Service |
724aca |
}
|