[Asterisk-code-review] config.c: Fix potential memory corruption after [section](+). (asterisk[certified/13.1])
Richard Mudgett
asteriskteam at digium.com
Mon Oct 12 15:16:24 CDT 2015
Richard Mudgett has uploaded a new change for review.
https://gerrit.asterisk.org/1429
Change subject: config.c: Fix potential memory corruption after [section](+).
......................................................................
config.c: Fix potential memory corruption after [section](+).
The memory corruption could happen if the [section](+) is the last section
in the file with trailing comments. In this case process_text_line() has
left *last_cat is set to newcat and newcat is destroyed.
Change-Id: I0d1d999f553986f591becd000e7cc6ddfb978d93
---
M main/config.c
1 file changed, 23 insertions(+), 12 deletions(-)
git pull ssh://gerrit.asterisk.org:29418/asterisk refs/changes/29/1429/1
diff --git a/main/config.c b/main/config.c
index e1c8729..5ced524 100644
--- a/main/config.c
+++ b/main/config.c
@@ -1627,7 +1627,7 @@
* You can put a comma-separated list of categories and templates
* and '!' and '+' between parentheses, with obvious meaning.
*/
- struct ast_category *newcat = NULL;
+ struct ast_category *newcat;
char *catname;
c = strchr(cur, ']');
@@ -1640,14 +1640,13 @@
if (*c++ != '(')
c = NULL;
catname = cur;
- if (!(*cat = newcat = ast_category_new(catname,
- S_OR(suggested_include_file, cfg->include_level == 1 ? "" : configfile),
- lineno))) {
+ *cat = newcat = ast_category_new(catname,
+ S_OR(suggested_include_file, cfg->include_level == 1 ? "" : configfile),
+ lineno);
+ if (!newcat) {
return -1;
}
(*cat)->lineno = lineno;
- *last_var = 0;
- *last_cat = newcat;
/* add comments */
if (ast_test_flag(&flags, CONFIG_FLAG_WITHCOMMENTS))
@@ -1670,8 +1669,9 @@
} else if (!strcasecmp(cur, "+")) {
*cat = ast_category_get(cfg, catname, NULL);
if (!(*cat)) {
- if (newcat)
+ if (newcat) {
ast_category_destroy(newcat);
+ }
ast_log(LOG_WARNING, "Category addition requested, but category '%s' does not exist, line %d of %s\n", catname, lineno, configfile);
return -1;
}
@@ -1694,8 +1694,19 @@
}
}
}
- if (newcat)
- ast_category_append(cfg, *cat);
+
+ /*
+ * We need to set *last_cat to newcat here regardless. If the
+ * category is being appended to we have no place for trailing
+ * comments on the appended category. The appended category
+ * may be in another file or it already has trailing comments
+ * that we would then leak.
+ */
+ *last_var = NULL;
+ *last_cat = newcat;
+ if (newcat) {
+ ast_category_append(cfg, newcat);
+ }
} else if (cur[0] == '#') { /* A directive - #include or #exec */
char *cur2;
char real_inclusion_name[256];
@@ -1851,7 +1862,7 @@
} else if ((v = ast_variable_new(cur, ast_strip(c), S_OR(suggested_include_file, cfg->include_level == 1 ? "" : configfile)))) {
v->lineno = lineno;
v->object = object;
- *last_cat = 0;
+ *last_cat = NULL;
*last_var = v;
/* Put and reset comments */
v->blanklines = 0;
@@ -1891,8 +1902,8 @@
struct stat statbuf;
struct cache_file_mtime *cfmtime = NULL;
struct cache_file_include *cfinclude;
- struct ast_variable *last_var = 0;
- struct ast_category *last_cat = 0;
+ struct ast_variable *last_var = NULL;
+ struct ast_category *last_cat = NULL;
/*! Growable string buffer */
struct ast_str *comment_buffer = NULL; /*!< this will be a comment collector.*/
struct ast_str *lline_buffer = NULL; /*!< A buffer for stuff behind the ; */
--
To view, visit https://gerrit.asterisk.org/1429
To unsubscribe, visit https://gerrit.asterisk.org/settings
Gerrit-MessageType: newchange
Gerrit-Change-Id: I0d1d999f553986f591becd000e7cc6ddfb978d93
Gerrit-PatchSet: 1
Gerrit-Project: asterisk
Gerrit-Branch: certified/13.1
Gerrit-Owner: Richard Mudgett <rmudgett at digium.com>
More information about the asterisk-code-review
mailing list