From: hairmare at gmail dot com
Operating system: Linux
PHP version: 6CVS-2006-11-18 (snap)
PHP Bug Type: Streams related
Bug description: Segfault with stream_bucket_new in user filter
Description:
------------
Using stream_bucket_new on a php://temp stream in a user filter leads to a
segfault.
'./configure' '--disable-cgi' '--enable-cli'
'--prefix=/usr/local/php6.0-200611181130' '--with-mysql' '--with-openssl'
'--with-pdo-mysql' '--enable-soap' '--with-xsl' '--enable-debug'
Reproduce code:
---------------
<?php
class bucketFilter {
public function filter($in, $out, &$consumed, $closing ){
$bucket = stream_bucket_new(fopen('php://temp', 'w+'), '');
stream_bucket_append($out, $bucket);
return PSFS_PASS_ON;
}
}
stream_filter_register('bucketfault', 'bucketFilter');
stream_filter_append($s = fopen('php://temp', 'r+'), 'bucketfault');
stream_get_contents($s);
?>
Expected result:
----------------
this should either output nothing or an error. it shouldn't crash.
Actual result:
--------------
Segmentation fault
Backtrace:
#0 0x08307d36 in php_stream_bucket_unlink (bucket=0xb6be7c78) at
/usr/local/src/php-6/php6.0-200611181130/main/streams/filter.c:285
#1 0x083075d8 in php_stream_bucket_make_writeable (bucket=0xb6be7c78) at
/usr/local/src/php-6/php6.0-200611181130/main/streams/filter.c:158
#2 0x082c114e in php_stream_bucket_attach (append=1, ht=2,
return_value=0xb6be5f9c, return_value_ptr=0x0, this_ptr=0x0,
return_value_used=0)
at
/usr/local/src/php-6/php6.0-200611181130/ext/standard/user_filters.c:430
#3 0x082c158a in zif_stream_bucket_append (ht=2, return_value=0xb6be5f9c,
return_value_ptr=0x0, this_ptr=0x0, return_value_used=0)
at
/usr/local/src/php-6/php6.0-200611181130/ext/standard/user_filters.c:484
#4 0x0836a654 in zend_do_fcall_common_helper_SPEC
(execute_data=0xbfa02020) at zend_vm_execute.h:209
#5 0x0836f1ba in ZEND_DO_FCALL_SPEC_CONST_HANDLER
(execute_data=0xbfa02020) at zend_vm_execute.h:1648
#6 0x0836a21c in execute (op_array=0xb6be7770) at zend_vm_execute.h:92
#7 0x083312e6 in zend_call_function (fci=0xbfa021a0, fci_cache=0x0) at
/usr/local/src/php-6/php6.0-200611181130/Zend/zend_execute_API.c:1036
#8 0x0832fd1d in call_user_function_ex (function_table=0x0,
object_pp=0xbfa02268, function_name=0xbfa02250, retval_ptr_ptr=0xbfa0224c,
param_count=4,
params=0xbfa02230, no_separation=0, symbol_table=0x0) at
/usr/local/src/php-6/php6.0-200611181130/Zend/zend_execute_API.c:636
#9 0x082c08bf in userfilter_filter (stream=0xb6be7034,
thisfilter=0xb6be7320, buckets_in=0xbfa022f0, buckets_out=0xbfa022e8,
consumed=0x0, flags=2)
at
/usr/local/src/php-6/php6.0-200611181130/ext/standard/user_filters.c:205
#10 0x0830047e in php_stream_fill_read_buffer (stream=0xb6be7034,
size=8192) at
/usr/local/src/php-6/php6.0-200611181130/main/streams/streams.c:465
#11 0x08300976 in _php_stream_read (stream=0xb6be7034, buf=0xb6be7f0c "",
size=8192) at
/usr/local/src/php-6/php6.0-200611181130/main/streams/streams.c:600
#12 0x08302fa4 in _php_stream_copy_to_mem_ex (src=0xb6be7034, rettype=6
'\006', buf=0xbfa02488, maxlen=0, maxchars=4294967295, persistent=0,
__php_stream_call_depth=0,
__zend_filename=0x844b110
"/usr/local/src/php-6/php6.0-200611181130/ext/standard/streamsfuncs.c",
__zend_lineno=422, __zend_orig_filename=0x0, __zend_orig_lineno=0)
at
/usr/local/src/php-6/php6.0-200611181130/main/streams/streams.c:1705
#13 0x082c9795 in zif_stream_get_contents (ht=1, return_value=0xb6be6d08,
return_value_ptr=0x0, this_ptr=0x0, return_value_used=0)
at
/usr/local/src/php-6/php6.0-200611181130/ext/standard/streamsfuncs.c:422
#14 0x0836a654 in zend_do_fcall_common_helper_SPEC
(execute_data=0xbfa02600) at zend_vm_execute.h:209
#15 0x0836f1ba in ZEND_DO_FCALL_SPEC_CONST_HANDLER
(execute_data=0xbfa02600) at zend_vm_execute.h:1648
#16 0x0836a21c in execute (op_array=0xb6be4af0) at zend_vm_execute.h:92
#17 0x08342a86 in zend_execute_scripts (type=8, retval=0x0, file_count=3)
at /usr/local/src/php-6/php6.0-200611181130/Zend/zend.c:1587
#18 0x082ec330 in php_execute_script (primary_file=0xbfa04a50) at
/usr/local/src/php-6/php6.0-200611181130/main/main.c:1933
#19 0x083b3318 in main (argc=2, argv=0xbfa04ae4) at
/usr/local/src/php-6/php6.0-200611181130/sapi/cli/php_cli.c:1119
--
Edit bug report at http://bugs.php.net/?id=39551&edit=1
--
Try a CVS snapshot (PHP 4.4):
http://bugs.php.net/fix.php?id=39551&r=trysnapshot44
Try a CVS snapshot (PHP 5.2):
http://bugs.php.net/fix.php?id=39551&r=trysnapshot52
Try a CVS snapshot (PHP 6.0):
http://bugs.php.net/fix.php?id=39551&r=trysnapshot60
Fixed in CVS: http://bugs.php.net/fix.php?id=39551&r=fixedcvs
Fixed in release:
http://bugs.php.net/fix.php?id=39551&r=alreadyfixed
Need backtrace: http://bugs.php.net/fix.php?id=39551&r=needtrace
Need Reproduce Script: http://bugs.php.net/fix.php?id=39551&r=needscript
Try newer version: http://bugs.php.net/fix.php?id=39551&r=oldversion
Not developer issue: http://bugs.php.net/fix.php?id=39551&r=support
Expected behavior: http://bugs.php.net/fix.php?id=39551&r=notwrong
Not enough info:
http://bugs.php.net/fix.php?id=39551&r=notenoughinfo
Submitted twice:
http://bugs.php.net/fix.php?id=39551&r=submittedtwice
register_globals: http://bugs.php.net/fix.php?id=39551&r=globals
PHP 3 support discontinued: http://bugs.php.net/fix.php?id=39551&r=php3
Daylight Savings: http://bugs.php.net/fix.php?id=39551&r=dst
IIS Stability: http://bugs.php.net/fix.php?id=39551&r=isapi
Install GNU Sed: http://bugs.php.net/fix.php?id=39551&r=gnused
Floating point limitations: http://bugs.php.net/fix.php?id=39551&r=float
No Zend Extensions: http://bugs.php.net/fix.php?id=39551&r=nozend
MySQL Configuration Error: http://bugs.php.net/fix.php?id=39551&r=mysqlcfg