2011-05-09 04:52:55 -04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2011-11-23 15:36:25 -05:00
|
|
|
#include <unistd.h>
|
2011-05-09 04:52:55 -04:00
|
|
|
#include <string.h>
|
2011-11-23 15:36:25 -05:00
|
|
|
#include <assert.h>
|
2011-05-09 04:52:55 -04:00
|
|
|
|
|
|
|
#define JEMALLOC_MANGLE
|
|
|
|
#include "jemalloc_test.h"
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
2011-11-23 15:36:25 -05:00
|
|
|
size_t pagesize;
|
2011-05-09 04:52:55 -04:00
|
|
|
void *p, *q;
|
|
|
|
size_t sz, tsz;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
fprintf(stderr, "Test begin\n");
|
|
|
|
|
2011-11-23 15:36:25 -05:00
|
|
|
/* Get page size. */
|
|
|
|
{
|
|
|
|
long result = sysconf(_SC_PAGESIZE);
|
|
|
|
assert(result != -1);
|
|
|
|
pagesize = (size_t)result;
|
|
|
|
}
|
|
|
|
|
2011-05-09 04:52:55 -04:00
|
|
|
r = JEMALLOC_P(allocm)(&p, &sz, 42, 0);
|
|
|
|
if (r != ALLOCM_SUCCESS) {
|
|
|
|
fprintf(stderr, "Unexpected allocm() error\n");
|
|
|
|
abort();
|
|
|
|
}
|
|
|
|
|
|
|
|
q = p;
|
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, sz, 0, ALLOCM_NO_MOVE);
|
|
|
|
if (r != ALLOCM_SUCCESS)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() error\n");
|
|
|
|
if (q != p)
|
|
|
|
fprintf(stderr, "Unexpected object move\n");
|
|
|
|
if (tsz != sz) {
|
|
|
|
fprintf(stderr, "Unexpected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
|
|
|
|
q = p;
|
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, sz, 5, ALLOCM_NO_MOVE);
|
|
|
|
if (r != ALLOCM_SUCCESS)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() error\n");
|
|
|
|
if (q != p)
|
|
|
|
fprintf(stderr, "Unexpected object move\n");
|
|
|
|
if (tsz != sz) {
|
|
|
|
fprintf(stderr, "Unexpected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
|
|
|
|
q = p;
|
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, sz + 5, 0, ALLOCM_NO_MOVE);
|
|
|
|
if (r != ALLOCM_ERR_NOT_MOVED)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() result\n");
|
|
|
|
if (q != p)
|
|
|
|
fprintf(stderr, "Unexpected object move\n");
|
|
|
|
if (tsz != sz) {
|
|
|
|
fprintf(stderr, "Unexpected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
|
|
|
|
q = p;
|
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, sz + 5, 0, 0);
|
|
|
|
if (r != ALLOCM_SUCCESS)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() error\n");
|
|
|
|
if (q == p)
|
|
|
|
fprintf(stderr, "Expected object move\n");
|
|
|
|
if (tsz == sz) {
|
|
|
|
fprintf(stderr, "Expected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
p = q;
|
|
|
|
sz = tsz;
|
|
|
|
|
2011-11-23 15:36:25 -05:00
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, pagesize*2, 0, 0);
|
2011-05-09 04:52:55 -04:00
|
|
|
if (r != ALLOCM_SUCCESS)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() error\n");
|
|
|
|
if (q == p)
|
|
|
|
fprintf(stderr, "Expected object move\n");
|
|
|
|
if (tsz == sz) {
|
|
|
|
fprintf(stderr, "Expected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
p = q;
|
|
|
|
sz = tsz;
|
|
|
|
|
2011-11-23 15:36:25 -05:00
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, pagesize*4, 0, 0);
|
2011-05-09 04:52:55 -04:00
|
|
|
if (r != ALLOCM_SUCCESS)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() error\n");
|
|
|
|
if (tsz == sz) {
|
|
|
|
fprintf(stderr, "Expected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
p = q;
|
|
|
|
sz = tsz;
|
|
|
|
|
2011-11-23 15:36:25 -05:00
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, pagesize*2, 0, ALLOCM_NO_MOVE);
|
2011-05-09 04:52:55 -04:00
|
|
|
if (r != ALLOCM_SUCCESS)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() error\n");
|
|
|
|
if (q != p)
|
|
|
|
fprintf(stderr, "Unexpected object move\n");
|
|
|
|
if (tsz == sz) {
|
|
|
|
fprintf(stderr, "Expected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
sz = tsz;
|
|
|
|
|
2011-11-23 15:36:25 -05:00
|
|
|
r = JEMALLOC_P(rallocm)(&q, &tsz, pagesize*4, 0, ALLOCM_NO_MOVE);
|
2011-05-09 04:52:55 -04:00
|
|
|
if (r != ALLOCM_SUCCESS)
|
|
|
|
fprintf(stderr, "Unexpected rallocm() error\n");
|
|
|
|
if (q != p)
|
|
|
|
fprintf(stderr, "Unexpected object move\n");
|
|
|
|
if (tsz == sz) {
|
|
|
|
fprintf(stderr, "Expected size change: %zu --> %zu\n",
|
|
|
|
sz, tsz);
|
|
|
|
}
|
|
|
|
sz = tsz;
|
|
|
|
|
|
|
|
JEMALLOC_P(dallocm)(p, 0);
|
|
|
|
|
|
|
|
fprintf(stderr, "Test end\n");
|
|
|
|
return (0);
|
|
|
|
}
|