dbghelp: Speed up vector_add by avoiding pool_realloc calls. Remove no longer needed pool_realloc.

This commit is contained in:
Markus Amsler 2007-05-15 02:04:57 +02:00 committed by Alexandre Julliard
parent 0acb5810bf
commit f94127f2ca
2 changed files with 18 additions and 32 deletions

View File

@ -44,8 +44,6 @@ struct pool /* poor's man */
void pool_init(struct pool* a, unsigned arena_size); void pool_init(struct pool* a, unsigned arena_size);
void pool_destroy(struct pool* a); void pool_destroy(struct pool* a);
void* pool_alloc(struct pool* a, unsigned len); void* pool_alloc(struct pool* a, unsigned len);
/* void* pool_realloc(struct pool* a, void* p,
unsigned old_size, unsigned new_size); */
char* pool_strdup(struct pool* a, const char* str); char* pool_strdup(struct pool* a, const char* str);
struct vector struct vector
@ -55,6 +53,7 @@ struct vector
unsigned shift; unsigned shift;
unsigned num_elts; unsigned num_elts;
unsigned num_buckets; unsigned num_buckets;
unsigned buckets_allocated;
}; };
void vector_init(struct vector* v, unsigned elt_sz, unsigned bucket_sz); void vector_init(struct vector* v, unsigned elt_sz, unsigned bucket_sz);

View File

@ -101,33 +101,6 @@ void* pool_alloc(struct pool* pool, unsigned len)
return ret; return ret;
} }
static struct pool_arena* pool_is_last(const struct pool* pool, const void* p, unsigned old_size)
{
struct pool_arena* arena;
for (arena = pool->first; arena; arena = arena->next)
{
if (arena->current == (const char*)p + old_size) return arena;
}
return NULL;
}
static void* pool_realloc(struct pool* pool, void* p, unsigned old_size, unsigned new_size)
{
struct pool_arena* arena;
void* new;
if ((arena = pool_is_last(pool, p, old_size)) &&
(char*)p + new_size <= (char*)arena + pool->arena_size)
{
arena->current = (char*)p + new_size;
return p;
}
if ((new = pool_alloc(pool, new_size)) && old_size)
memcpy(new, p, min(old_size, new_size));
return new;
}
char* pool_strdup(struct pool* pool, const char* str) char* pool_strdup(struct pool* pool, const char* str)
{ {
char* ret; char* ret;
@ -155,6 +128,7 @@ void vector_init(struct vector* v, unsigned esz, unsigned bucket_sz)
default: assert(0); default: assert(0);
} }
v->num_buckets = 0; v->num_buckets = 0;
v->buckets_allocated = 0;
v->num_elts = 0; v->num_elts = 0;
} }
@ -180,9 +154,22 @@ void* vector_add(struct vector* v, struct pool* pool)
assert(v->num_elts > ncurr); assert(v->num_elts > ncurr);
if (ncurr == (v->num_buckets << v->shift)) if (ncurr == (v->num_buckets << v->shift))
{ {
v->buckets = pool_realloc(pool, v->buckets, if(v->num_buckets == v->buckets_allocated)
v->num_buckets * sizeof(void*), {
(v->num_buckets + 1) * sizeof(void*)); /* Double the bucket cache, so it scales well with big vectors.*/
unsigned new_reserved;
void* new;
new_reserved = 2*v->buckets_allocated;
if(new_reserved == 0) new_reserved = 1;
/* Don't even try to resize memory.
Pool datastructure is very inefficient with reallocs. */
new = pool_alloc(pool, new_reserved * sizeof(void*));
memcpy(new, v->buckets, v->buckets_allocated * sizeof(void*));
v->buckets = new;
v->buckets_allocated = new_reserved;
}
v->buckets[v->num_buckets] = pool_alloc(pool, v->elt_size << v->shift); v->buckets[v->num_buckets] = pool_alloc(pool, v->elt_size << v->shift);
return v->buckets[v->num_buckets++]; return v->buckets[v->num_buckets++];
} }