diff --git a/source/utils/nmblookup.c b/source/utils/nmblookup.c index 8bb80239174..bf158fe4a06 100644 --- a/source/utils/nmblookup.c +++ b/source/utils/nmblookup.c @@ -193,6 +193,7 @@ int main(int argc,char *argv[]) static BOOL find_master=False; static BOOL lookup_by_ip = False; poptContext pc; + TALLOC_CTX *frame = talloc_stackframe(); struct poptOption long_options[] = { POPT_AUTOHELP @@ -292,6 +293,6 @@ int main(int argc,char *argv[]) } poptFreeContext(pc); - + TALLOC_FREE(frame); return(0); } diff --git a/source/utils/pdbedit.c b/source/utils/pdbedit.c index c5a132a55d1..cea2cd7cfaa 100644 --- a/source/utils/pdbedit.c +++ b/source/utils/pdbedit.c @@ -758,6 +758,7 @@ int main (int argc, char **argv) static BOOL pw_from_stdin = False; struct pdb_methods *bin, *bout, *bdef; char *configfile = NULL; + TALLOC_CTX *frame = talloc_stackframe(); poptContext pc; struct poptOption long_options[] = { POPT_AUTOHELP @@ -798,6 +799,7 @@ int main (int argc, char **argv) /* we shouldn't have silly checks like this */ if (getuid() != 0) { d_fprintf(stderr, "You must be root to use pdbedit\n"); + TALLOC_FREE(frame); return -1; } @@ -1050,5 +1052,6 @@ int main (int argc, char **argv) } poptPrintHelp(pc, stderr, 0); + TALLOC_FREE(frame); return 1; } diff --git a/source/utils/sharesec.c b/source/utils/sharesec.c index a1774d698eb..45bde5cf8e3 100644 --- a/source/utils/sharesec.c +++ b/source/utils/sharesec.c @@ -507,7 +507,7 @@ int main(int argc, const char *argv[]) { NULL } }; - if ( !(ctx = talloc_init("main")) ) { + if ( !(ctx = talloc_stackframe()) ) { fprintf( stderr, "Failed to initialize talloc context!\n"); return -1; } diff --git a/source/utils/smbcacls.c b/source/utils/smbcacls.c index db81b447a18..6324dcc1927 100644 --- a/source/utils/smbcacls.c +++ b/source/utils/smbcacls.c @@ -824,7 +824,7 @@ static struct cli_state *connect_one(const char *share) load_case_tables(); - ctx=talloc_init("main"); + ctx=talloc_stackframe(); /* set default debug level to 1 regardless of what smb.conf sets */ setup_logging( "smbcacls", True ); diff --git a/source/utils/smbcquotas.c b/source/utils/smbcquotas.c index 70d28a7e4a3..8d954ac20ae 100644 --- a/source/utils/smbcquotas.c +++ b/source/utils/smbcquotas.c @@ -401,6 +401,7 @@ static struct cli_state *connect_one(const char *share) struct cli_state *cli; BOOL fix_user = False; SMB_NTQUOTA_STRUCT qt; + TALLOC_CTX *frame = talloc_stackframe(); poptContext pc; struct poptOption long_options[] = { POPT_AUTOHELP @@ -544,6 +545,8 @@ FSQFLAGS:QUOTA_ENABLED/DENY_DISK/LOG_SOFTLIMIT/LOG_HARD_LIMIT", "SETSTRING" }, break; } + talloc_free(frame); + return result; } diff --git a/source/utils/smbfilter.c b/source/utils/smbfilter.c index 450adc41ef3..b3c038c0cf1 100644 --- a/source/utils/smbfilter.c +++ b/source/utils/smbfilter.c @@ -220,6 +220,7 @@ int main(int argc, char *argv[]) { char *desthost; pstring configfile; + TALLOC_CTX *frame = talloc_stackframe(); setup_logging(argv[0],True); @@ -240,5 +241,6 @@ int main(int argc, char *argv[]) } start_filter(desthost); + TALLOC_FREE(frame); return 0; } diff --git a/source/utils/smbget.c b/source/utils/smbget.c index 5848fd4057e..ac662e6acee 100644 --- a/source/utils/smbget.c +++ b/source/utils/smbget.c @@ -521,6 +521,7 @@ int main(int argc, const char **argv) int c = 0; const char *file = NULL; char *rcfile = NULL; + TALLOC_CTX *frame = talloc_stackframe(); struct poptOption long_options[] = { {"guest", 'a', POPT_ARG_NONE, NULL, 'a', "Work as user guest" }, {"resume", 'r', POPT_ARG_NONE, &_resume, 0, "Automatically resume aborted files" }, @@ -597,6 +598,6 @@ int main(int argc, const char **argv) } clean_exit(); - + TALLOC_FREE(frame); return 0; } diff --git a/source/utils/smbpasswd.c b/source/utils/smbpasswd.c index 1da9b5e5288..f1a23870900 100644 --- a/source/utils/smbpasswd.c +++ b/source/utils/smbpasswd.c @@ -550,7 +550,9 @@ static int process_nonroot(int local_flags) **********************************************************/ int main(int argc, char **argv) { + TALLOC_CTX *frame = talloc_stackframe(); int local_flags = 0; + int ret; AllowDebugChange = False; @@ -587,5 +589,7 @@ int main(int argc, char **argv) return process_root(local_flags); } - return process_nonroot(local_flags); + ret = process_nonroot(local_flags); + TALLOC_FREE(frame); + return ret; } diff --git a/source/utils/smbtree.c b/source/utils/smbtree.c index b30ce08c5a4..a29aa52fefe 100644 --- a/source/utils/smbtree.c +++ b/source/utils/smbtree.c @@ -249,6 +249,7 @@ static BOOL print_tree(struct user_auth_info *user_info) ****************************************************************************/ int main(int argc,char *argv[]) { + TALLOC_CTX *frame = talloc_stackframe(); struct poptOption long_options[] = { POPT_AUTOHELP { "broadcast", 'b', POPT_ARG_VAL, &use_bcast, True, "Use broadcast instead of using the master browser" }, @@ -289,8 +290,11 @@ static BOOL print_tree(struct user_auth_info *user_info) /* Now do our stuff */ - if (!print_tree(&cmdline_auth_info)) + if (!print_tree(&cmdline_auth_info)) { + TALLOC_FREE(frame); return 1; + } + TALLOC_FREE(frame); return 0; }