Edit report at https://bugs.php.net/bug.php?id=48816&edit=1
ID: 48816 Comment by: simon at welsh dot co dot nz Reported by: kim at burgestrand dot se Summary: IteratorIterator seek() causes bus error Status: Assigned Type: Bug Package: SPL related Operating System: Mac OS 10.5.7 PHP Version: 5.3.0 Assigned To: colder Block user comment: N Private report: N New Comment: I am still getting a bus error with PHP 5.4, using a current git version. I am calling count() on the IteratorIterator. Reproduce code: <?php $it = new IteratorIterator(new ArrayIterator(array())); var_dump($it->count()); I would expect a PHP Fatal error: Call to undefined method ArrayIterator::count(), as there is no mention of methods being passed off to the underlying Traversable object. Previous Comments: ------------------------------------------------------------------------ [2010-11-14 14:19:31] fel...@php.net I can reproduce it on 5.3-SVN. ==3389== Invalid read of size 4 ==3389== at 0x8291199: spl_dual_it_free (spl_iterators.c:1460) ==3389== by 0x8291653: spl_dual_it_next (spl_iterators.c:1526) ==3389== by 0x8291619: zim_spl_dual_it_next (spl_iterators.c:1616) ==3389== by 0x84E841C: zend_do_fcall_common_helper_SPEC (zend_vm_execute.h:316) ==3389== by 0x84E95E3: ZEND_DO_FCALL_BY_NAME_SPEC_HANDLER (zend_vm_execute.h:421) ==3389== by 0x84E7101: execute (zend_vm_execute.h:107) ==3389== by 0x84B54ED: zend_execute_scripts (zend.c:1194) ==3389== by 0x8427201: php_execute_script (main.c:2265) ==3389== by 0x8598D70: main (php_cli.c:1193) ==3389== Address 0x6 is not stack'd, malloc'd or (recently) free'd ==3389== ==3389== Process terminating with default action of signal 11 (SIGSEGV) ==3389== Access not within mapped region at address 0x6 ==3389== at 0x8291199: spl_dual_it_free (spl_iterators.c:1460) ==3389== by 0x8291653: spl_dual_it_next (spl_iterators.c:1526) ==3389== by 0x8291619: zim_spl_dual_it_next (spl_iterators.c:1616) ==3389== by 0x84E841C: zend_do_fcall_common_helper_SPEC (zend_vm_execute.h:316) ==3389== by 0x84E95E3: ZEND_DO_FCALL_BY_NAME_SPEC_HANDLER (zend_vm_execute.h:421) ==3389== by 0x84E7101: execute (zend_vm_execute.h:107) ==3389== by 0x84B54ED: zend_execute_scripts (zend.c:1194) ==3389== by 0x8427201: php_execute_script (main.c:2265) ==3389== by 0x8598D70: main (php_cli.c:1193) ------------------------------------------------------------------------ [2010-06-04 16:43:17] jan-phpbug at kantert dot net I can reproduce the problem in stock Ubuntu 10.04 lucid on 86_64/amd64. PHP 5.3.2-1ubuntu4.2. Results in a segmentation fault! We experienced similar problems with iterators at other points in our code. ------------------------------------------------------------------------ [2009-07-06 15:56:27] kim at burgestrand dot se I compiled PHP 5.2.10 (configure command: './configure' '--with-mysql=/usr/local/mysql' '--with-mysqli=/usr/local/mysql/bin/mysql_config' '--enable-mbstring' '--with-curl=/usr' '--enable-sockets' '--with-libxml-dir=/opt/local/include/libxml2/libxml' '--with-pdo-mysql=shared,/usr/local/mysql' '--with-iconv=shared,/opt/local' '--with-apxs2' '--with-config-file-path=/etc/php' '--with-config-file-scan-dir=/etc/php/conf.d') and tested the code. No out of bounds exceptions, and the output was consistent: int(0) int(1) ------------------------------------------------------------------------ [2009-07-06 15:51:24] kim at burgestrand dot se I had the same issue on Debian using PHP 5.2.6-3 with Suhosin-Patch 0.9.6.2 sometimes. I mean, have a peek at this output: http://pastebin.com/f1dd1bc27 (linked to pastebin because the bug system thinks I'm spamming) Same code as submitted, with a shebang added to the top #!/usr/bin/env php. ------------------------------------------------------------------------ [2009-07-06 13:46:34] paj...@php.net I can't reproduce here, I got a out of bounds exception on the seek call. ------------------------------------------------------------------------ The remainder of the comments for this report are too long. To view the rest of the comments, please view the bug report online at https://bugs.php.net/bug.php?id=48816 -- Edit this bug report at https://bugs.php.net/bug.php?id=48816&edit=1