diff options
author | Tom Tromey <tromey@redhat.com> | 2008-08-05 20:43:17 +0000 |
---|---|---|
committer | Tom Tromey <tromey@redhat.com> | 2008-08-05 20:43:17 +0000 |
commit | e6ad058ac447711a1175a07b168bfb27d3ed7ce8 (patch) | |
tree | 6baff88c6677730d8ae2c5dfbbcbc5b9bf69eb92 /gdb/bcache.c | |
parent | 11d31d9471cd17e3256b5583a79a7889c4fce645 (diff) | |
download | gdb-e6ad058ac447711a1175a07b168bfb27d3ed7ce8.zip gdb-e6ad058ac447711a1175a07b168bfb27d3ed7ce8.tar.gz gdb-e6ad058ac447711a1175a07b168bfb27d3ed7ce8.tar.bz2 |
* bcache.c (deprecated_bcache_added): Initialize obstack.
(bcache_xmalloc): Don't initialize obstack.
(bcache_xfree): Conditionally free obstack.
(bcache_memory_used): Update.
Diffstat (limited to 'gdb/bcache.c')
-rw-r--r-- | gdb/bcache.c | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/gdb/bcache.c b/gdb/bcache.c index 589de6a..f96993b 100644 --- a/gdb/bcache.c +++ b/gdb/bcache.c @@ -217,6 +217,16 @@ bcache_full (const void *addr, int length, struct bcache *bcache, int *added) if (added) *added = 0; + /* Lazily initialize the obstack. This can save quite a bit of + memory in some cases. */ + if (bcache->total_count == 0) + { + /* We could use obstack_specify_allocation here instead, but + gdb_obstack.h specifies the allocation/deallocation + functions. */ + obstack_init (&bcache->cache); + } + /* If our average chain length is too high, expand the hash table. */ if (bcache->unique_count >= bcache->num_buckets * CHAIN_LENGTH_THRESHOLD) expand_hash_table (bcache); @@ -271,10 +281,6 @@ bcache_xmalloc (void) { /* Allocate the bcache pre-zeroed. */ struct bcache *b = XCALLOC (1, struct bcache); - /* We could use obstack_specify_allocation here instead, but - gdb_obstack.h specifies the allocation/deallocation - functions. */ - obstack_init (&b->cache); return b; } @@ -284,7 +290,9 @@ bcache_xfree (struct bcache *bcache) { if (bcache == NULL) return; - obstack_free (&bcache->cache, 0); + /* Only free the obstack if we actually initialized it. */ + if (bcache->total_count > 0) + obstack_free (&bcache->cache, 0); xfree (bcache->bucket); xfree (bcache); } @@ -443,5 +451,7 @@ print_bcache_statistics (struct bcache *c, char *type) int bcache_memory_used (struct bcache *bcache) { + if (bcache->total_count == 0) + return 0; return obstack_memory_used (&bcache->cache); } |