From 7e1ba386dd51aebe3fb05b5d7b3d9ff42e3fb77a Mon Sep 17 00:00:00 2001 From: Raghavendra G Date: Sun, 6 Dec 2009 04:46:24 +0000 Subject: performance/stat-prefetch: fix memory leak. - rbt_hash_remove only removes entry from the hash table. It does not free the data. Signed-off-by: Raghavendra G Signed-off-by: Anand V. Avati BUG: 438 (Memory leak) URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=438 --- xlators/performance/stat-prefetch/src/stat-prefetch.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/xlators/performance/stat-prefetch/src/stat-prefetch.c b/xlators/performance/stat-prefetch/src/stat-prefetch.c index d5a206aee10..0e77abc0897 100644 --- a/xlators/performance/stat-prefetch/src/stat-prefetch.c +++ b/xlators/performance/stat-prefetch/src/stat-prefetch.c @@ -373,6 +373,7 @@ sp_cache_remove_entry (sp_cache_t *cache, char *name, char remove_all) rbthash_table_t *table = NULL; xlator_t *this; sp_private_t *priv = NULL; + void *data = NULL; if ((cache == NULL) || ((name == NULL) && !remove_all)) { goto out; @@ -404,7 +405,9 @@ sp_cache_remove_entry (sp_cache_t *cache, char *name, char remove_all) ret = 0; } } else { - rbthash_remove (cache->table, name, strlen (name)); + data = rbthash_remove (cache->table, name, + strlen (name)); + FREE (data); ret = 0; } } -- cgit