From:
Operating system: linux
PHP version: 5.4.0
Package: *Compile Issues
Bug Type: Bug
Bug description:insteadof cause memory leak if class is not binded
Description:
------------
when class is not binded, "insteadof" cause a detected memory leak. see the
following script and output
==============
after days tracking, i lock on _destroy_zend_class_traits_info
if (ce->trait_precedences) {
size_t i = 0;
while (ce->trait_precedences[i]) {
efree((char*)ce->trait_precedences[i]->trait_method->method_name);
efree((char*)ce->trait_precedences[i]->trait_method->class_name);
efree(ce->trait_precedences[i]->trait_method);
if (ce->trait_precedences[i]->exclude_from_classes) {
efree(ce->trait_precedences[i]->exclude_from_classes); <-
before this line
}
ce->trait_precedences[i]->exclude_from_classes[0] is string, should but not
efree'ed, this is why it's leaking. however when the class is bind, it is
zend_class_entry and should not efree
Test script:
---------------
<?php
if (0) {
class A {
use b2, b33 {
b2::b444 insteadof b33;
b2::b444 as b5555;
}
}
}
Expected result:
----------------
./php-cgi -c php.ini test.php
X-Powered-By: PHP/5.4.1RC1-dev
Content-type: text/html
Actual result:
--------------
./php-cgi -c php.ini test.php
X-Powered-By: PHP/5.4.1RC1-dev
Content-type: text/html
[Mon Mar 26 13:40:12 2012] Script: 'ZZZZZZZZZZs|ââââ'â]âG'
Zend/zend_language_scanner.l(1889) : Freeing 0x7F4720728688 (4 bytes),
script=ZZZZZZZZZZs|ââââ'â]âG
=== Total 1 memory leaks detected ===
valgrind outputs:
==31399== 4 bytes in 1 blocks are definitely lost in loss record 1 of 84
==31399== at 0x4C2879E: malloc (in
/usr/lib64/valgrind/vgpreload_memcheck-
amd64-linux.so)
==31399== by 0x8E9C41: _emalloc (zend_alloc.c:2423)
==31399== by 0x8EA1A6: _estrndup (zend_alloc.c:2596)
==31399== by 0x8D050E: lex_scan (zend_language_scanner.l:1889)
==31399== by 0x905A52: zendlex (zend_compile.c:6666)
==31399== by 0x8C5F45: zendparse (zend_language_parser.c:3099)
==31399== by 0x8CC630: compile_file (zend_language_scanner.l:579)
==31399== by 0x6F2C45: phar_compile_file (phar.c:3391)
==31399== by 0x91F846: zend_execute_scripts (zend.c:1265)
==31399== by 0x896FEC: php_execute_script (main.c:2473)
==31399== by 0xA6D136: main (cgi_main.c:2422)
--
Edit bug report at https://bugs.php.net/bug.php?id=61506&edit=1
--
Try a snapshot (PHP 5.4):
https://bugs.php.net/fix.php?id=61506&r=trysnapshot54
Try a snapshot (PHP 5.3):
https://bugs.php.net/fix.php?id=61506&r=trysnapshot53
Try a snapshot (trunk):
https://bugs.php.net/fix.php?id=61506&r=trysnapshottrunk
Fixed in SVN:
https://bugs.php.net/fix.php?id=61506&r=fixed
Fixed in SVN and need be documented:
https://bugs.php.net/fix.php?id=61506&r=needdocs
Fixed in release:
https://bugs.php.net/fix.php?id=61506&r=alreadyfixed
Need backtrace:
https://bugs.php.net/fix.php?id=61506&r=needtrace
Need Reproduce Script:
https://bugs.php.net/fix.php?id=61506&r=needscript
Try newer version:
https://bugs.php.net/fix.php?id=61506&r=oldversion
Not developer issue:
https://bugs.php.net/fix.php?id=61506&r=support
Expected behavior:
https://bugs.php.net/fix.php?id=61506&r=notwrong
Not enough info:
https://bugs.php.net/fix.php?id=61506&r=notenoughinfo
Submitted twice:
https://bugs.php.net/fix.php?id=61506&r=submittedtwice
register_globals:
https://bugs.php.net/fix.php?id=61506&r=globals
PHP 4 support discontinued:
https://bugs.php.net/fix.php?id=61506&r=php4
Daylight Savings: https://bugs.php.net/fix.php?id=61506&r=dst
IIS Stability:
https://bugs.php.net/fix.php?id=61506&r=isapi
Install GNU Sed:
https://bugs.php.net/fix.php?id=61506&r=gnused
Floating point limitations:
https://bugs.php.net/fix.php?id=61506&r=float
No Zend Extensions:
https://bugs.php.net/fix.php?id=61506&r=nozend
MySQL Configuration Error:
https://bugs.php.net/fix.php?id=61506&r=mysqlcfg