MonoMemPool *pool = g_malloc (MONO_MEMPOOL_PAGESIZE);
pool->next = NULL;
- pool->pos = (char *)pool + sizeof (MonoMemPool);
+ pool->pos = (guint8*)pool + sizeof (MonoMemPool);
pool->end = pool->pos + MONO_MEMPOOL_PAGESIZE - sizeof (MonoMemPool);
pool->d.allocated = pool->size = MONO_MEMPOOL_PAGESIZE;
return pool;
void
mono_mempool_empty (MonoMemPool *pool)
{
- pool->pos = (char *)pool + sizeof (MonoMemPool);
+ pool->pos = (guint8*)pool + sizeof (MonoMemPool);
pool->end = pool->pos + MONO_MEMPOOL_PAGESIZE - sizeof (MonoMemPool);
}
void
mono_mempool_stats (MonoMemPool *pool)
{
- MonoMemPool *p, *n;
+ MonoMemPool *p;
int count = 0;
guint32 still_free = 0;
p = pool;
while (p) {
still_free += p->end - p->pos;
- n = p->next;
- p = n;
+ p = p->next;
count++;
}
if (pool) {
size = (size + MEM_ALIGN - 1) & ~(MEM_ALIGN - 1);
rval = pool->pos;
- pool->pos = (char*)rval + size;
+ pool->pos = (guint8*)rval + size;
if (G_UNLIKELY (pool->pos >= pool->end)) {
pool->pos -= size;
MonoMemPool *np = g_malloc (sizeof (MonoMemPool) + size);
np->next = pool->next;
pool->next = np;
+ np->pos = (guint8*)np + sizeof (MonoMemPool);
np->size = sizeof (MonoMemPool) + size;
+ np->end = np->pos + np->size - sizeof (MonoMemPool);
pool->d.allocated += sizeof (MonoMemPool) + size;
- return (char *)np + sizeof (MonoMemPool);
+ return (guint8*)np + sizeof (MonoMemPool);
} else {
MonoMemPool *np = g_malloc (MONO_MEMPOOL_PAGESIZE);
np->next = pool->next;
pool->next = np;
- pool->pos = (char *)np + sizeof (MonoMemPool);
+ pool->pos = (guint8*)np + sizeof (MonoMemPool);
+ np->pos = (guint8*)np + sizeof (MonoMemPool);
np->size = MONO_MEMPOOL_PAGESIZE;
+ np->end = np->pos;
pool->end = pool->pos + MONO_MEMPOOL_PAGESIZE - sizeof (MonoMemPool);
pool->d.allocated += MONO_MEMPOOL_PAGESIZE;
size = (size + MEM_ALIGN - 1) & ~(MEM_ALIGN - 1);
rval = pool->pos;
- pool->pos = (char*)rval + size;
+ pool->pos = (guint8*)rval + size;
if (G_UNLIKELY (pool->pos >= pool->end)) {
rval = mono_mempool_alloc (pool, size);
return res;
}
+/**
+ * mono_mempool_get_allocated:
+ *
+ * Return the amount of memory allocated for this mempool.
+ */
+guint32
+mono_mempool_get_allocated (MonoMemPool *pool)
+{
+ return pool->d.allocated;
+}