From: Andreas Schneider Date: Tue, 15 Jul 2008 12:57:32 +0000 (+0200) Subject: Release still reachable memory if the smbclient context is freed. X-Git-Url: http://git.samba.org/?a=commitdiff_plain;h=88c9cf2fdc8f3d704f7f27c25ef6dc6940d451d3;p=samba.git Release still reachable memory if the smbclient context is freed. Signed-off-by: Andreas Schneider --- diff --git a/source/libsmb/libsmb_context.c b/source/libsmb/libsmb_context.c index dd78bcee355..85de44e15e3 100644 --- a/source/libsmb/libsmb_context.c +++ b/source/libsmb/libsmb_context.c @@ -200,6 +200,22 @@ smbc_free_context(SMBCCTX *context, smbc_setUser(context, NULL); DEBUG(3, ("Context %p successfully freed\n", context)); + + gfree_names(); + gfree_loadparm(); + gfree_case_tables(); + gfree_charcnv(); + gfree_interfaces(); + + gencache_shutdown(); + secrets_shutdown(); + + /* release the talloc null_context memory last */ + talloc_disable_null_tracking(); + + gfree_debugsyms(); + + SAFE_FREE(context->internal); SAFE_FREE(context); return 0; } @@ -411,6 +427,9 @@ smbc_init_context(SMBCCTX *context) char *user = NULL; char *home = NULL; + /* track talloc null_context memory */ + talloc_enable_null_tracking(); + if (!context) { errno = EBADF; return NULL;