2013-04-16 23:59:09 -04:00
|
|
|
#ident "Copyright (c) 2007-2010 Tokutek Inc. All rights reserved."
|
|
|
|
|
2013-04-16 23:57:53 -04:00
|
|
|
#include <toku_portability.h>
|
2013-04-16 23:57:34 -04:00
|
|
|
#include "memory.h"
|
|
|
|
#include <string.h>
|
2013-04-16 23:59:09 -04:00
|
|
|
#include <stdio.h>
|
2013-04-16 23:57:34 -04:00
|
|
|
#include <stdlib.h>
|
2013-04-16 23:57:34 -04:00
|
|
|
#include "toku_assert.h"
|
2013-04-16 23:57:34 -04:00
|
|
|
|
|
|
|
int toku_memory_check=0;
|
|
|
|
|
|
|
|
typedef void *(*malloc_fun_t)(size_t);
|
|
|
|
typedef void (*free_fun_t)(void*);
|
|
|
|
typedef void *(*realloc_fun_t)(void*,size_t);
|
|
|
|
|
|
|
|
static malloc_fun_t t_malloc = 0;
|
|
|
|
static free_fun_t t_free = 0;
|
|
|
|
static realloc_fun_t t_realloc = 0;
|
|
|
|
|
2013-04-16 23:57:34 -04:00
|
|
|
void *toku_malloc(size_t size) {
|
2013-04-16 23:59:11 -04:00
|
|
|
void *p;
|
2013-04-16 23:57:34 -04:00
|
|
|
if (t_malloc)
|
2013-04-16 23:59:11 -04:00
|
|
|
p = t_malloc(size);
|
2013-04-16 23:57:34 -04:00
|
|
|
else
|
2013-04-16 23:59:11 -04:00
|
|
|
p = os_malloc(size);
|
|
|
|
return p;
|
2013-04-16 23:57:34 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void *
|
|
|
|
toku_calloc(size_t nmemb, size_t size)
|
|
|
|
{
|
|
|
|
size_t newsize = nmemb * size;
|
|
|
|
void *vp = toku_malloc(newsize);
|
|
|
|
if (vp) memset(vp, 0, newsize);
|
|
|
|
return vp;
|
|
|
|
}
|
|
|
|
|
|
|
|
void *
|
|
|
|
toku_realloc(void *p, size_t size)
|
|
|
|
{
|
2013-04-16 23:59:11 -04:00
|
|
|
void *q;
|
2013-04-16 23:57:34 -04:00
|
|
|
if (t_realloc)
|
2013-04-16 23:59:11 -04:00
|
|
|
q = t_realloc(p, size);
|
2013-04-16 23:57:34 -04:00
|
|
|
else
|
2013-04-16 23:59:11 -04:00
|
|
|
q = os_realloc(p, size);
|
|
|
|
return q;
|
2013-04-16 23:57:34 -04:00
|
|
|
}
|
|
|
|
|
2013-04-16 23:59:12 -04:00
|
|
|
void *
|
|
|
|
toku_memdup (const void *v, size_t len)
|
|
|
|
{
|
|
|
|
void *r=toku_malloc(len);
|
|
|
|
if (r) memcpy(r,v,len);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
|
|
|
toku_strdup (const char *s)
|
|
|
|
{
|
|
|
|
return toku_memdup(s, strlen(s)+1);
|
|
|
|
}
|
|
|
|
|
2013-04-16 23:57:34 -04:00
|
|
|
void
|
2013-04-16 23:59:11 -04:00
|
|
|
toku_free(void *p)
|
2013-04-16 23:57:34 -04:00
|
|
|
{
|
|
|
|
if (t_free)
|
|
|
|
t_free(p);
|
|
|
|
else
|
|
|
|
os_free(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
toku_free_n(void* p, size_t size __attribute__((unused)))
|
|
|
|
{
|
|
|
|
toku_free(p);
|
|
|
|
}
|
|
|
|
|
2013-04-16 23:58:04 -04:00
|
|
|
void *
|
2013-04-16 23:59:12 -04:00
|
|
|
toku_xmalloc(size_t size) {
|
|
|
|
void *r = toku_malloc(size);
|
2013-04-16 23:59:33 -04:00
|
|
|
if (r == 0) // avoid function call in common case
|
|
|
|
resource_assert(r);
|
2013-04-16 23:58:04 -04:00
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2013-04-16 23:57:34 -04:00
|
|
|
void *
|
2013-04-16 23:59:12 -04:00
|
|
|
toku_xcalloc(size_t nmemb, size_t size)
|
2013-04-16 23:57:34 -04:00
|
|
|
{
|
2013-04-16 23:59:12 -04:00
|
|
|
size_t newsize = nmemb * size;
|
|
|
|
void *vp = toku_xmalloc(newsize);
|
|
|
|
if (vp) memset(vp, 0, newsize);
|
|
|
|
return vp;
|
|
|
|
}
|
|
|
|
|
|
|
|
void *
|
|
|
|
toku_xrealloc(void *v, size_t size)
|
|
|
|
{
|
|
|
|
void *r = toku_realloc(v, size);
|
2013-04-16 23:59:33 -04:00
|
|
|
if (r == 0) // avoid function call in common case
|
|
|
|
resource_assert(r);
|
2013-04-16 23:57:34 -04:00
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2013-04-16 23:59:12 -04:00
|
|
|
void *
|
|
|
|
toku_xmemdup (const void *v, size_t len)
|
2013-04-16 23:58:04 -04:00
|
|
|
{
|
2013-04-16 23:59:12 -04:00
|
|
|
void *r=toku_xmalloc(len);
|
|
|
|
memcpy(r,v,len);
|
|
|
|
return r;
|
2013-04-16 23:58:04 -04:00
|
|
|
}
|
|
|
|
|
2013-04-16 23:57:34 -04:00
|
|
|
char *
|
2013-04-16 23:59:12 -04:00
|
|
|
toku_xstrdup (const char *s)
|
2013-04-16 23:57:34 -04:00
|
|
|
{
|
2013-04-16 23:59:12 -04:00
|
|
|
return toku_xmemdup(s, strlen(s)+1);
|
2013-04-16 23:57:34 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
toku_set_func_malloc(malloc_fun_t f) {
|
|
|
|
t_malloc = f;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
toku_set_func_realloc(realloc_fun_t f) {
|
|
|
|
t_realloc = f;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
toku_set_func_free(free_fun_t f) {
|
|
|
|
t_free = f;
|
|
|
|
return 0;
|
|
|
|
}
|