00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035 #include <stdlib.h>
00036 #include <string.h>
00037 #if !defined(WIN32)
00038 #include <strings.h>
00039 #endif
00040 #if !defined(__SUNPRO_CC) || __SUNPRO_CC > 0x420
00041 #include <new>
00042 #endif
00043 #include "config.h"
00044
00045 #include "threadheap.h"
00046 #include "processheap.h"
00047 #include "arch-specific.h"
00048
00049
00050
00051
00052
00053
00054
00055 inline static processHeap * getAllocator (void) {
00056 static char * buf = (char *) hoardGetMemory (sizeof(processHeap));
00057 static processHeap * theAllocator = new (buf) processHeap;
00058 return theAllocator;
00059 }
00060
00061 #define HOARD_MALLOC(x) pmalloc(x)
00062 #define HOARD_FREE(x) pfree(x)
00063 #define HOARD_REALLOC(x,y) prealloc(x,y)
00064 #define HOARD_CALLOC(x,y) pcalloc(x,y)
00065 #define HOARD_MEMALIGN(x,y) pmemalign(x,y)
00066 #define HOARD_VALLOC(x) pvalloc(x)
00067 #define HOARD_GET_USABLE_SIZE(x) pmalloc_usable_size(x)
00068
00069 extern "C" void * HOARD_MALLOC(size_t);
00070 extern "C" void HOARD_FREE(void *);
00071 extern "C" void * HOARD_REALLOC(void *, size_t);
00072 extern "C" void * HOARD_CALLOC(size_t, size_t);
00073 extern "C" void * HOARD_MEMALIGN(size_t, size_t);
00074 extern "C" void * HOARD_VALLOC(size_t);
00075 extern "C" size_t HOARD_GET_USABLE_SIZE(void *);
00076
00077
00078 extern "C" void * HOARD_MALLOC (size_t sz)
00079 {
00080 static processHeap * pHeap = getAllocator();
00081 if (sz == 0) {
00082 sz = 1;
00083 }
00084 void * addr = pHeap->getHeap(pHeap->getHeapIndex()).malloc (sz);
00085 return addr;
00086 }
00087
00088 extern "C" void * HOARD_CALLOC (size_t nelem, size_t elsize)
00089 {
00090 static processHeap * pHeap = getAllocator();
00091 size_t sz = nelem * elsize;
00092 if (sz == 0) {
00093 sz = 1;
00094 }
00095 void * ptr = pHeap->getHeap(pHeap->getHeapIndex()).malloc (sz);
00096
00097 memset (ptr, 0, sz);
00098 return ptr;
00099 }
00100
00101 extern "C" void HOARD_FREE (void * ptr)
00102 {
00103 static processHeap * pHeap = getAllocator();
00104 pHeap->free (ptr);
00105 }
00106
00107
00108 extern "C" void * HOARD_MEMALIGN (size_t alignment, size_t size)
00109 {
00110 static processHeap * pHeap = getAllocator();
00111 void * addr = pHeap->getHeap(pHeap->getHeapIndex()).memalign (alignment, size);
00112 return addr;
00113 }
00114
00115
00116 extern "C" void * HOARD_VALLOC (size_t size)
00117 {
00118 return HOARD_MEMALIGN (hoardGetPageSize(), size);
00119 }
00120
00121
00122 extern "C" void * HOARD_REALLOC (void * ptr, size_t sz)
00123 {
00124 if (ptr == NULL) {
00125 return HOARD_MALLOC (sz);
00126 }
00127 if (sz == 0) {
00128 HOARD_FREE (ptr);
00129 return NULL;
00130 }
00131
00132
00133
00134
00135 size_t objSize = threadHeap::objectSize (ptr);
00136
00137 if (objSize >= sz) {
00138 return ptr;
00139 }
00140
00141
00142
00143 void * buf = HOARD_MALLOC (sz);
00144
00145
00146
00147
00148 size_t minSize = (objSize < sz) ? objSize : sz;
00149 memcpy (buf, ptr, minSize);
00150
00151
00152
00153 HOARD_FREE (ptr);
00154
00155
00156
00157 return buf;
00158 }
00159
00160 extern "C" size_t HOARD_GET_USABLE_SIZE (void * ptr)
00161 {
00162 return threadHeap::objectSize (ptr);
00163 }
00164
00165
00166 #if 0
00167 extern "C" void malloc_stats (void)
00168 {
00169 TheWrapper.TheAllocator()->stats();
00170 }
00171 #endif