Module: kamailio Branch: 4.2 Commit: 97f1ee6e287b6f711ddbe04700a82295341ed880 URL: https://github.com/kamailio/kamailio/commit/97f1ee6e287b6f711ddbe04700a82295...
Author: Timo Teräs timo.teras@iki.fi Committer: Timo Teräs timo.teras@iki.fi Date: 2015-04-16T12:55:04+03:00
sqlops: fix use-after-free by deep copying result name
When creating a new result handle, deep copy the result name. Otherwise we might end up accessing the name after it's freed.
(cherry picked from commit 6e2604464e64cfaaf1e0327228f53f4787b69470)
---
Modified: modules/sqlops/sql_api.c
---
Diff: https://github.com/kamailio/kamailio/commit/97f1ee6e287b6f711ddbe04700a82295... Patch: https://github.com/kamailio/kamailio/commit/97f1ee6e287b6f711ddbe04700a82295...
---
diff --git a/modules/sqlops/sql_api.c b/modules/sqlops/sql_api.c index eeb6fac..e11ae29 100644 --- a/modules/sqlops/sql_api.c +++ b/modules/sqlops/sql_api.c @@ -199,14 +199,16 @@ sql_result_t* sql_get_result(str *name) return sr; sr = sr->next; } - sr = (sql_result_t*)pkg_malloc(sizeof(sql_result_t)); + sr = (sql_result_t*)pkg_malloc(sizeof(sql_result_t) + name->len); if(sr==NULL) { LM_ERR("no pkg memory\n"); return NULL; } memset(sr, 0, sizeof(sql_result_t)); - sr->name = *name; + memcpy(sr+1, name->s, name->len); + sr->name.s = (char *)(sr + 1); + sr->name.len = name->len; sr->resid = resid; sr->next = _sql_result_root; _sql_result_root = sr; @@ -685,6 +687,7 @@ void sql_destroy(void) pkg_free(r); r = r0; } + _sql_result_root = NULL; }
/**