|   | php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login | 
| 
  [2011-05-23 19:33 UTC] erik at datahack dot se
 Description:
------------
If you try to access an undefined variable or constant in an extended SoapClient, it will cause PHP crash due to a Segmentation Fault.
Test script:
---------------
<?php
    class XSoapClient extends SoapClient {
        function __doRequest($request, $location, $action, $version) {
            echo self::$crash;
//          echo parent::$crash;
//          echo self::crash;
//          echo parent::crash;
        }   
    }   
    $client = new XSoapClient(null, array('uri'=>'', 'location'=>''));
    $client->__soapCall('', array());
?>
Expected result:
----------------
An error like, Fatal error: Access to undeclared static property: XSoapClient::$crash...
Actual result:
--------------
$ sapi/cli/php ../crash.php 
Segmentation fault
# gdb backtrace...
Starting program: /home/erik/php-5.3.6/sapi/cli/php ../crash.php
[Thread debugging using libthread_db enabled]
Program received signal SIGSEGV, Segmentation fault.
0x0843c238 in zval_delref_p (zval_ptr=0xbfffcf68, __zend_filename=0x87cc4e8 "/home/erik/php-5.3.6/Zend/zend_vm_execute.h", 
    __zend_lineno=609) at /home/erik/php-5.3.6/Zend/zend.h:385
385		return --pz->refcount__gc;
(gdb) bt
#0  0x0843c238 in zval_delref_p (zval_ptr=0xbfffcf68, __zend_filename=0x87cc4e8 "/home/erik/php-5.3.6/Zend/zend_vm_execute.h", 
    __zend_lineno=609) at /home/erik/php-5.3.6/Zend/zend.h:385
#1  _zval_ptr_dtor (zval_ptr=0xbfffcf68, __zend_filename=0x87cc4e8 "/home/erik/php-5.3.6/Zend/zend_vm_execute.h", __zend_lineno=609)
    at /home/erik/php-5.3.6/Zend/zend_execute_API.c:437
#2  0x08479ff8 in ZEND_HANDLE_EXCEPTION_SPEC_HANDLER (execute_data=0x8920a60) at /home/erik/php-5.3.6/Zend/zend_vm_execute.h:609
#3  0x08478793 in execute (op_array=0x88f2be0) at /home/erik/php-5.3.6/Zend/zend_vm_execute.h:107
#4  0x0844bae6 in zend_execute_scripts (type=8, retval=0x0, file_count=3) at /home/erik/php-5.3.6/Zend/zend.c:1194
#5  0x083e102e in php_execute_script (primary_file=0xbffff324) at /home/erik/php-5.3.6/main/main.c:2268
#6  0x08509d35 in main (argc=2, argv=0xbffff4b4) at /home/erik/php-5.3.6/sapi/cli/php_cli.c:1193
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits             | |||||||||||||||||||||||||||
|  Copyright © 2001-2025 The PHP Group All rights reserved. | Last updated: Fri Oct 31 12:00:01 2025 UTC | 
and I can also reproduce this with svn-trunk and after I undef zend_always_inline, got a more clearly bt: #0 0x00000000009ffe8c in zval_delref_p (pz=0x5a5a5a5a5a5a5a5a) at /home/laruence/opensource/php-src/trunk/Zend/zend.h:391 391 return --pz->refcount__gc; (gdb) bt #0 0x00000000009ffe8c in zval_delref_p (pz=0x5a5a5a5a5a5a5a5a) at /home/laruence/opensource/php-src/trunk/Zend/zend.h:391 #1 0x0000000000a00efc in i_zval_ptr_dtor (zval_ptr=0x5a5a5a5a5a5a5a5a, __zend_filename=0xdb2f28 "/home/laruence/opensource/php- src/trunk/Zend/zend_execute.h", __zend_lineno=339) at /home/laruence/opensource/php-src/trunk/Zend/zend_execute.h:82 #2 0x0000000000a0163e in zend_vm_stack_clear_multiple () at /home/laruence/opensource/php-src/trunk/Zend/zend_execute.h:339 #3 0x0000000000a050f9 in zend_do_fcall_common_helper_SPEC (execute_data=0x2a95fbc0e8) at /home/laruence/opensource/php-src/trunk/Zend/zend_vm_execute.h:736 #4 0x0000000000a054c8 in ZEND_DO_FCALL_BY_NAME_SPEC_HANDLER (execute_data=0x2a95fbc0e8) at /home/laruence/opensource/php-src/trunk/Zend/zend_vm_execute.h:752 #5 0x0000000000a0427c in execute (op_array=0x2a95ff3828) at /home/laruence/opensource/php-src/trunk/Zend/zend_vm_execute.h:410 #6 0x00000000009b0c18 in zend_execute_scripts (type=8, retval=0x0, file_count=3) at /home/laruence/opensource/php-src/trunk/Zend/zend.c:1271 #7 0x00000000008ef5aa in php_execute_script (primary_file=0x7fbffff260) at /home/laruence/opensource/php-src/trunk/main/main.c:2391 #8 0x0000000000a632c8 in do_cli (argc=2, argv=0x7fbffff548) at /home/laruence/opensource/php-src/trunk/sapi/cli/php_cli.c:983 #9 0x0000000000a64169 in main (argc=2, argv=0x7fbffff548) at /home/laruence/opensource/php-src/trunk/sapi/cli/php_cli.c:1356