From 4dc40bade411ddc1a0cc85ee9e242307ea2c96b2 Mon Sep 17 00:00:00 2001 From: Simon Wilkinson Date: Sat, 31 Mar 2012 15:23:22 -0400 Subject: [PATCH] ktime: Don't leak token list ktime_ParsePeriodic generates a malloc'd token list when it parses the time string passed to it. Make sure that we free this list before exiting from the function. Change-Id: I6edacc6504aeec06ede5b5ae36c22f69b0d6cea0 Reviewed-on: http://gerrit.openafs.org/7106 Tested-by: BuildBot Reviewed-by: Derrick Brashear --- src/util/ktime.c | 50 ++++++++++++++++++++++++++++-------------------- 1 file changed, 29 insertions(+), 21 deletions(-) diff --git a/src/util/ktime.c b/src/util/ktime.c index 9cb6f72421..b331b19546 100644 --- a/src/util/ktime.c +++ b/src/util/ktime.c @@ -37,10 +37,8 @@ static char *day[] = { }; /* free token list returned by parseLine */ -#ifdef undef -static -LocalFreeTokens(alist) - struct token *alist; +static void +LocalFreeTokens(struct token *alist) { struct token *nlist; for (; alist; alist = nlist) { @@ -48,9 +46,8 @@ LocalFreeTokens(alist) free(alist->key); free(alist); } - return 0; + return; } -#endif static int space(int x) @@ -80,9 +77,9 @@ LocalParseLine(char *aline, struct token **alist) if (inToken) { inToken = 0; /* end of this token */ *tptr++ = 0; - ttok = (struct token *)malloc(sizeof(struct token)); + ttok = malloc(sizeof(struct token)); ttok->next = NULL; - ttok->key = (char *)malloc(strlen(tbuffer) + 1); + ttok->key = malloc(strlen(tbuffer) + 1); strcpy(ttok->key, tbuffer); if (last) { last->next = ttok; @@ -251,11 +248,11 @@ ktime_ParsePeriodic(char *adate, struct ktime *ak) /* look at each token */ if (strcmp(tt->key, "now") == 0) { ak->mask |= KTIME_NOW; - return 0; + goto out; } if (strcmp(tt->key, "never") == 0) { ak->mask |= KTIME_NEVER; - return 0; + goto out; } if (strcmp(tt->key, "at") == 0) continue; @@ -264,14 +261,17 @@ ktime_ParsePeriodic(char *adate, struct ktime *ak) if (isdigit(tt->key[0])) { /* parse a time */ code = ParseTime(ak, tt->key); - if (code) - return -1; + if (code) { + code = -1; + goto out; + } continue; } /* otherwise use keyword table */ for (tp = ptkeys;; tp++) { if (tp->key == NULL) { - return -1; + code = -1; + goto out; } if (strcmp(tp->key, tt->key) == 0) break; @@ -286,23 +286,31 @@ ktime_ParsePeriodic(char *adate, struct ktime *ak) /* am or pm token */ if ((tp->value & 0xff) == 1) { /* pm */ - if (!(ak->mask & KTIME_HOUR)) - return -1; - if (ak->hour < 12) + if (!(ak->mask & KTIME_HOUR)) { + code = -1; + goto out; + } + if (ak->hour < 12) { ak->hour += 12; /* 12 is 12 PM */ - else if (ak->hour != 12) - return -1; + } else if (ak->hour != 12) { + code = -1; + goto out; + } } else { /* am is almost a noop, except that we map 12:01 am to 0:01 */ - if (ak->hour > 12) - return -1; + if (ak->hour > 12) { + code = -1; + goto out; + } if (ak->hour == 12) ak->hour = 0; } } } - return 0; +out: + LocalFreeTokens(tt); + return code; } /* ktime_DisplayString