ID: 36515 Updated by: [EMAIL PROTECTED] Reported By: mark at vectrex dot org dot uk -Status: Open +Status: Assigned Bug Type: Streams related Operating System: Linux PHP Version: 5.1.2 -Assigned To: +Assigned To: mike New Comment:
Doesn't happen with the http.inflate filter. I might have alook at it another day. Previous Comments: ------------------------------------------------------------------------ [2006-02-24 20:15:41] mark at vectrex dot org dot uk I've tried this again on snapshot php5.1-200602241730, it crashes in the same place. The gdb stack trace is almost identical so I haven't posted it. Mark ------------------------------------------------------------------------ [2006-02-24 17:49:11] [EMAIL PROTECTED] Please try using this CVS snapshot: http://snaps.php.net/php5.1-latest.tar.gz For Windows: http://snaps.php.net/win32/php5.1-win32-latest.zip ------------------------------------------------------------------------ [2006-02-24 17:27:42] mark at vectrex dot org dot uk Description: ------------ I'm trying to fetch a gzipped item from a web server and inflate it using the zlib inflate filter. This causes a segfault. Reproduce code: --------------- <?php echo "Registered filters: --- \n\n"; print_r(stream_get_filters()); $opts = array( 'http'=>array( 'method'=>"GET", 'header' => "Accept-Encoding:gzip" ) ); $ctx = stream_context_create($opts); $url = "http://www.vectrex.org.uk/mark/web/test.txt.gz"; $f = fopen($url, "r", false, $ctx); echo "appending filter...\n"; stream_filter_append($f, 'zlib.inflate', STREAM_FILTER_READ); echo "filter appended, getting data....\n"; $data = stream_get_contents($f); $metadata = stream_get_meta_data($f); fclose($f); echo "METADATA: ----- \n\n"; print_r($metadata); echo "DATA: ----- \n\n"; print $data ; ?> Expected result: ---------------- The file will be printed uncompressed. This is intended to use the CLI SAPI. Actual result: -------------- Registered filters: --- Array ( [0] => string.rot13 [1] => string.toupper [2] => string.tolower [3] => string.strip_tags [4] => convert.* [5] => convert.iconv.* [6] => zlib.* ) appending filter... Then it crashes with a segfault, stack trace is: #0 0x0828efb8 in php_stream_bucket_unlink (bucket=0x86bac94, tsrm_ls=0x859b018) at /home/mark/unpack/php-5.1.2/main/streams/filter.c:228 #1 0x0828f46d in _php_stream_filter_append (chain=0x86bad74, filter=0x86b9934, tsrm_ls=0x859b018) at /home/mark/unpack/php-5.1.2/main/streams/filter.c:370 #2 0x0826729a in apply_filter_to_stream (append=1, ht=0, return_value=0x86b8894, return_value_ptr=0x0, this_ptr=0x0, return_value_used=0, tsrm_ls=0x859b018) at /home/mark/unpack/php-5.1.2/ext/standard/streamsfuncs.c:1085 #3 0x0826739c in zif_stream_filter_append (ht=0, return_value=0x0, return_value_ptr=0x0, this_ptr=0x0, return_value_used=0, tsrm_ls=0x0) at /home/mark/unpack/php-5.1.2/ext/standard/streamsfuncs.c:1123 #4 0x082d5fee in zend_do_fcall_common_helper_SPEC (execute_data=0xbfaa9910, tsrm_ls=0x859b018) at zend_vm_execute.h:192 #5 0x082d56ec in execute (op_array=0x86b5994, tsrm_ls=0x859b018) at zend_vm_execute.h:92 #6 0x082bb1fc in zend_execute_scripts (type=8, tsrm_ls=0x859b018, retval=0x0, file_count=3) at /home/mark/unpack/php-5.1.2/Zend/zend.c:1101 #7 0x0827a064 in php_execute_script (primary_file=0xbfaabd90, tsrm_ls=0x859b018) at /home/mark/unpack/php-5.1.2/main/main.c:1720 #8 0x0832cf73 in main (argc=2, argv=0xbfaabe54) at /home/mark/unpack/php-5.1.2/sapi/cli/php_cli.c:1077 ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=36515&edit=1