ID:               17115
 Comment by:       [EMAIL PROTECTED]
 Reported By:      [EMAIL PROTECTED]
 Status:           No Feedback
 Bug Type:         Reproducible crash
 Operating System: Redhat 7.1
 PHP Version:      4.2.0
 New Comment:

I see the same bug in 4.2.3. I haven't tried "latest".  
  
OS: Debian testing/unstable 
Configure Command: '../configure' '--prefix=/usr' 
'--prefix=/usr' '--with-regex=php' 
'--enable-force-cgi-redirect' 
'--with-config-file-path=/etc/php4/cgi' '--disable-rpath' 
'--disable-pear' '--disable-debug' '--enable-memory-limit' 
'--with-layout=GNU' '--enable-calendar' '--enable-sysvsem' 
'--enable-sysvshm' '--enable-track-vars' 
'--enable-trans-sid' '--enable-bcmath' '--with-bz2' 
'--enable-ctype' '--with-db2' '--with-iconv' 
'--enable-exif' '--enable-filepro' '--enable-ftp' 
'--with-gettext' '--enable-mbstring' 
'--with-pcre-regex=/usr' '--enable-shmop' 
'--enable-sockets' '--enable-wddx' '--disable-xml' 
'--with-expat-dir=/usr' '--enable-yp' '--with-zlib' 
'--without-pgsql' '--with-openssl=/usr' '--disable-static' 
'--without-mm' '--without-mysql' '--without-sybase-ct' 
  
$ sudo apt-get install php4/unstable  
Reading Package Lists... Done  
Building Dependency Tree... Done  
Selected version 4:4.2.3-3 (Debian:unstable) for php4  
Sorry, php4 is already the newest version.  
0 packages upgraded, 0 newly installed, 0 to remove and 0   
not upgraded.  
$ php4 -v  
4.2.3  
$ php4  
<?php  
$f = create_function('$s', 'static $foo = 0; echo "\$s is  
$s  
[".$foo++."]\n";');  
    print_r($f("one"));  
    print_r($f("two"));  
    print_r($f("three"));  
?>  
^DSegmentation fault  
$ _ 
 
I get similar results when running php under Apache. 
Error.log says: "child pid 12848 exit signal Segmentation 
fault (11)"


Previous Comments:
------------------------------------------------------------------------

[2002-07-18 01:00:11] [EMAIL PROTECTED]

No feedback was provided for this bug for over a month, so it is
being suspended automatically. If you are able to provide the
information that was originally requested, please do so and change
the status of the bug back to "Open".

------------------------------------------------------------------------

[2002-06-17 21:09:48] [EMAIL PROTECTED]

Neither of those examples crash with this snapshot:
http://snaps.php.net/php4-latest.tar.gz



------------------------------------------------------------------------

[2002-05-09 07:41:59] [EMAIL PROTECTED]

Code is -

<?php
$f = create_function('$s', 'static $foo = 0; echo "\$s is $s
[".$foo++."]\n";');
    print_r($f("one"));
    print_r($f("two"));
    print_r($f("three"));
?>

When run from the command-line this core-dumps under 4.2.0. Running
4.1.1 compiled with --apxs for apache produces incorrect results -

$s is one []
$s is two []
$s is three []

But if used in array_map() different results are produced (still using
4.1.1)

code -
<?php
$f = create_function('$s', 'static $foo = 0; return "\$s is $s
[".$foo++."]\n";');
echo $f("one"), "<br>", $f("two"), "<br>", $f("three"), "<br>";
echo "<p>";
echo join(" | ", array_map($f, array("abc","def","ghi"));
?>

result -
$s is one []
$s is two []
$s is three []

$s is abc [] | $s is def [1] | $s is ghi [2]

But take you the first three calls to $f and the page never returns.
And there are many more bizarre results like 4.1.1 (but there is always
a coredump in 4.2.0).

Details

configure line (4.2.0) -
 './configure' '--enable-cli' '--disable-short-tags'
'--enable-overload' '--enable-sockets' '--with-readline'

configure line (4.1.1) -
'./configure' '--with-apache=../apache_1.3.20' '--with-gd'
'--with-mysql=/usr/local/mysql' '--enable-debug=no'
'--enable-track-vars=yes' '--enable-magic-quotes=yes' '--with-gdbm'
'--with-ndbm' '--with-db' '--with-png-dir=/usr/local'
'--with-zlib-dir=/usr/local' '--with-jpeg-dir=/usr/local'

gdb bt (running 4.2.0 from the commandline) -
#0  0x080e7cd5 in zend_hash_find (ht=0x8183e1c, arKey=0x8183bb4 "foo",
nKeyLength=4, pData=0xbfffdf74) at zend_hash.c:861
#1  0x080fab7a in zend_fetch_var_address (opline=0x8182b1c,
Ts=0xbfffdfa0, type=1) at ./zend_execute.c:560
#2  0x080fc6b8 in execute (op_array=0x8183ee8) at
./zend_execute.c:1239
#3  0x080dcdc3 in call_user_function_ex (function_table=0x8153530,
object_pp=0x0, function_name=0x818199c, retval_ptr_ptr=0xbfffe304,
param_count=1,
    params=0x8184154, no_separation=0, symbol_table=0x0) at
zend_execute_API.c:517
#4  0x080f8118 in zif_array_map (ht=2, return_value=0x8184044,
this_ptr=0x0, return_value_used=1) at array.c:3228
#5  0x080fe283 in execute (op_array=0x8181ac4) at
./zend_execute.c:1598
#6  0x080e3efe in zend_execute_scripts (type=8, retval=0x0,
file_count=3) at zend.c:810
#7  0x08062b71 in php_execute_script (primary_file=0xbffff7f0) at
main.c:1381
#8  0x08060b7c in main (argc=3, argv=0xbffff89c) at cgi_main.c:785
#9  0x40136177 in __libc_start_main (main=0x8060374 <main>, argc=3,
ubp_av=0xbffff89c, init=0x805efc8 <_init>, fini=0x8102db0 <_fini>,
    rtld_fini=0x4000e184 <_dl_fini>, stack_end=0xbffff88c) at
../sysdeps/generic/libc-start.c:129

------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=17115&edit=1

Reply via email to