mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-04-23 19:45:35 +00:00
[Core] scan-build: Fix false-positive use-after-free in switch_xml_free_attr(). Add unit test.
This commit is contained in:
parent
95fb8c7773
commit
e42ebbb33f
@ -1000,15 +1000,15 @@ static char *switch_xml_str2utf8(char **s, switch_size_t *len)
|
|||||||
/* frees a tag attribute list */
|
/* frees a tag attribute list */
|
||||||
static void switch_xml_free_attr(char **attr)
|
static void switch_xml_free_attr(char **attr)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i, c = 0;
|
||||||
char *m;
|
char *m;
|
||||||
|
|
||||||
if (!attr || attr == SWITCH_XML_NIL)
|
if (!attr || attr == SWITCH_XML_NIL)
|
||||||
return; /* nothing to free */
|
return; /* nothing to free */
|
||||||
while (attr[i])
|
while (attr[c])
|
||||||
i += 2; /* find end of attribute list */
|
c += 2; /* find end of attribute list */
|
||||||
m = attr[i + 1]; /* list of which names and values are malloced */
|
m = attr[c + 1]; /* list of which names and values are malloced */
|
||||||
for (i = 0; m[i]; i++) {
|
for (i = c / 2 - 1; i >= 0 ; i--) {
|
||||||
if (m[i] & SWITCH_XML_NAMEM)
|
if (m[i] & SWITCH_XML_NAMEM)
|
||||||
free(attr[i * 2]);
|
free(attr[i * 2]);
|
||||||
if (m[i] & SWITCH_XML_TXTM)
|
if (m[i] & SWITCH_XML_TXTM)
|
||||||
|
@ -53,6 +53,16 @@ FST_CORE_BEGIN("./conf")
|
|||||||
}
|
}
|
||||||
FST_TEARDOWN_END()
|
FST_TEARDOWN_END()
|
||||||
|
|
||||||
|
FST_TEST_BEGIN(test_xml_free_attr)
|
||||||
|
{
|
||||||
|
switch_xml_t parent_xml = switch_xml_new("xml");
|
||||||
|
switch_xml_t xml = switch_xml_add_child_d(parent_xml, "test", 1);
|
||||||
|
switch_xml_set_attr(xml, "a1", "v1");
|
||||||
|
switch_xml_set_attr_d(xml, "a2", "v2");
|
||||||
|
switch_xml_free(parent_xml);
|
||||||
|
}
|
||||||
|
FST_TEST_END()
|
||||||
|
|
||||||
FST_TEST_BEGIN(test_xml_set_attr)
|
FST_TEST_BEGIN(test_xml_set_attr)
|
||||||
{
|
{
|
||||||
switch_xml_t parent_xml = switch_xml_new("xml");
|
switch_xml_t parent_xml = switch_xml_new("xml");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user