Hi Derick,

Sorry, but I think mainly about PHP performance, and of course I didn't know that you trace return_values it in xdebug.

After the patch, in case if return value is not used we set EG(return_value_ptr_ptr) to NULL before call to nested execute(). I assume you can just check for (EG(return_value_ptr_ptr)==NULL) before write it. Will it work for you?

Thanks. Dmitry.

Derick Rethans wrote:
On Fri, 11 Apr 2008, Dmitry Stogov wrote:

dmitry          Fri Apr 11 09:43:31 2008 UTC

  Modified files:              (Branch: PHP_5_3)
/php-src NEWS /ZendEngine2 zend.c zend_execute_API.c zend_vm_def.h zend_vm_execute.h Log:
  Optimized ZEND_RETURN opcode to not allocate and copy return value if it is 
not
  used.

Hmm, I'm not too happy with this, as it breaks some functionality in Xdebug. Xdebug allows you to create a function trace, including all return values. For example the following script:

<?php
function foo() { return 42; }
foo();
echo foo();
?>

Gave a function trace like
(with php -d xdebug.auto_trace=1 -dxdebug.collect_return=1 test-ft.php):

TRACE START [2008-04-11 10:29:49]
    0.0002     650528   -> {main}() /tmp/test-ft.php:0
    0.0003     650840     -> foo() /tmp/test-ft.php:8
                           >=> 42
    0.0004     650840     -> foo() /tmp/test-ft.php:9
                           >=> 42
                         >=> 1
    0.0013      54536
TRACE END   [2008-04-11 10:29:49]

However, with this change, I only get:

TRACE START [2008-04-11 10:32:11]
    0.2148     652336   -> {main}() /tmp/test-ft.php:0
    0.2907     652648     -> foo() /tmp/test-ft.php:8
    0.3178     652648     -> foo() /tmp/test-ft.php:9
                           >=> 42
    0.4802      56344
TRACE END   [2008-04-11 10:32:12]


Is it still possible to get the return values of the functions that are *not* used? I currently check if EG(return_value_ptr_ptr) and *EG(return_value_ptr_ptr) are not NULL to see if there is a return value, and now (of course) they are empty (null pointer).

regards,
Derick


--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to