2015-10-06 10:18:30 -04:00
|
|
|
#include "test/jemalloc_test.h"
|
|
|
|
|
|
|
|
JEMALLOC_INLINE_C void
|
2017-01-30 03:58:34 -05:00
|
|
|
time_func(timedelta_t *timer, uint64_t nwarmup, uint64_t niter,
|
|
|
|
void (*func)(void))
|
2015-10-06 10:18:30 -04:00
|
|
|
{
|
|
|
|
uint64_t i;
|
|
|
|
|
|
|
|
for (i = 0; i < nwarmup; i++)
|
|
|
|
func();
|
|
|
|
timer_start(timer);
|
|
|
|
for (i = 0; i < niter; i++)
|
|
|
|
func();
|
|
|
|
timer_stop(timer);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
compare_funcs(uint64_t nwarmup, uint64_t niter, const char *name_a,
|
|
|
|
void (*func_a), const char *name_b, void (*func_b))
|
|
|
|
{
|
|
|
|
timedelta_t timer_a, timer_b;
|
|
|
|
char ratio_buf[6];
|
|
|
|
void *p;
|
|
|
|
|
|
|
|
p = mallocx(1, 0);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected mallocx() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
time_func(&timer_a, nwarmup, niter, func_a);
|
|
|
|
time_func(&timer_b, nwarmup, niter, func_b);
|
|
|
|
|
|
|
|
timer_ratio(&timer_a, &timer_b, ratio_buf, sizeof(ratio_buf));
|
|
|
|
malloc_printf("%"FMTu64" iterations, %s=%"FMTu64"us, "
|
|
|
|
"%s=%"FMTu64"us, ratio=1:%s\n",
|
|
|
|
niter, name_a, timer_usec(&timer_a), name_b, timer_usec(&timer_b),
|
|
|
|
ratio_buf);
|
|
|
|
|
|
|
|
dallocx(p, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
malloc_free(void)
|
|
|
|
{
|
|
|
|
/* The compiler can optimize away free(malloc(1))! */
|
|
|
|
void *p = malloc(1);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected malloc() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
free(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
mallocx_free(void)
|
|
|
|
{
|
|
|
|
void *p = mallocx(1, 0);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected mallocx() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
free(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_BEGIN(test_malloc_vs_mallocx)
|
|
|
|
{
|
|
|
|
|
|
|
|
compare_funcs(10*1000*1000, 100*1000*1000, "malloc",
|
|
|
|
malloc_free, "mallocx", mallocx_free);
|
|
|
|
}
|
|
|
|
TEST_END
|
|
|
|
|
|
|
|
static void
|
|
|
|
malloc_dallocx(void)
|
|
|
|
{
|
|
|
|
void *p = malloc(1);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected malloc() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
dallocx(p, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
malloc_sdallocx(void)
|
|
|
|
{
|
|
|
|
void *p = malloc(1);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected malloc() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
sdallocx(p, 1, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_BEGIN(test_free_vs_dallocx)
|
|
|
|
{
|
|
|
|
|
|
|
|
compare_funcs(10*1000*1000, 100*1000*1000, "free", malloc_free,
|
|
|
|
"dallocx", malloc_dallocx);
|
|
|
|
}
|
|
|
|
TEST_END
|
|
|
|
|
|
|
|
TEST_BEGIN(test_dallocx_vs_sdallocx)
|
|
|
|
{
|
|
|
|
|
|
|
|
compare_funcs(10*1000*1000, 100*1000*1000, "dallocx", malloc_dallocx,
|
|
|
|
"sdallocx", malloc_sdallocx);
|
|
|
|
}
|
|
|
|
TEST_END
|
|
|
|
|
|
|
|
static void
|
|
|
|
malloc_mus_free(void)
|
|
|
|
{
|
|
|
|
void *p;
|
|
|
|
|
|
|
|
p = malloc(1);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected malloc() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
malloc_usable_size(p);
|
|
|
|
free(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
malloc_sallocx_free(void)
|
|
|
|
{
|
|
|
|
void *p;
|
|
|
|
|
|
|
|
p = malloc(1);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected malloc() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (sallocx(p, 0) < 1)
|
|
|
|
test_fail("Unexpected sallocx() failure");
|
|
|
|
free(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_BEGIN(test_mus_vs_sallocx)
|
|
|
|
{
|
|
|
|
|
|
|
|
compare_funcs(10*1000*1000, 100*1000*1000, "malloc_usable_size",
|
|
|
|
malloc_mus_free, "sallocx", malloc_sallocx_free);
|
|
|
|
}
|
|
|
|
TEST_END
|
|
|
|
|
|
|
|
static void
|
|
|
|
malloc_nallocx_free(void)
|
|
|
|
{
|
|
|
|
void *p;
|
|
|
|
|
|
|
|
p = malloc(1);
|
|
|
|
if (p == NULL) {
|
|
|
|
test_fail("Unexpected malloc() failure");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (nallocx(1, 0) < 1)
|
|
|
|
test_fail("Unexpected nallocx() failure");
|
|
|
|
free(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_BEGIN(test_sallocx_vs_nallocx)
|
|
|
|
{
|
|
|
|
|
|
|
|
compare_funcs(10*1000*1000, 100*1000*1000, "sallocx",
|
|
|
|
malloc_sallocx_free, "nallocx", malloc_nallocx_free);
|
|
|
|
}
|
|
|
|
TEST_END
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
|
|
|
|
return (test(
|
|
|
|
test_malloc_vs_mallocx,
|
|
|
|
test_free_vs_dallocx,
|
|
|
|
test_dallocx_vs_sdallocx,
|
|
|
|
test_mus_vs_sallocx,
|
|
|
|
test_sallocx_vs_nallocx));
|
|
|
|
}
|