From: Scott MacVicar Date: Fri, 13 May 2011 05:54:34 +0000 (+0000) Subject: Fix use after free() in XMLReader::xml() X-Git-Tag: php-5.3.7RC1~131 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=df0ce635e445d0bfe7181ac49b1f2c08696df4e1;p=php Fix use after free() in XMLReader::xml() --- diff --git a/ext/xmlreader/php_xmlreader.c b/ext/xmlreader/php_xmlreader.c index d029f5efca..9b9f852169 100644 --- a/ext/xmlreader/php_xmlreader.c +++ b/ext/xmlreader/php_xmlreader.c @@ -1092,9 +1092,7 @@ PHP_METHOD(xmlreader, XML) uri = (char *) xmlCanonicPath((const xmlChar *) resolved_path); } reader = xmlNewTextReader(inputbfr, uri); - if (uri) { - xmlFree(uri); - } + if (reader != NULL) { #if LIBXML_VERSION >= 20628 ret = xmlTextReaderSetup(reader, NULL, uri, encoding, options); @@ -1108,11 +1106,20 @@ PHP_METHOD(xmlreader, XML) } intern->input = inputbfr; intern->ptr = reader; + + if (uri) { + xmlFree(uri); + } + return; } } } + if (uri) { + xmlFree(uri); + } + if (inputbfr) { xmlFreeParserInputBuffer(inputbfr); }