summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkrakjoe <joe.watkins@live.co.uk>2014-01-01 13:01:06 +0000
committerkrakjoe <joe.watkins@live.co.uk>2014-01-01 13:01:06 +0000
commit8a7e2f8dd2116ff6ada654e301c593accf337250 (patch)
tree584f1654fdb4b03f41416657ce0886f928122fc2
parent37897e258d13016f80c61b7d6e9054994f2e5e0f (diff)
parente9195018dcb19eca3964efb3cc262e63b100ba3e (diff)
downloadphp-git-8a7e2f8dd2116ff6ada654e301c593accf337250.tar.gz
Merge branch 'PHP-5.5' into PHP-5.6
* PHP-5.5: fix #66375 bad logic in sapi header callback routine
-rw-r--r--main/SAPI.c43
1 files changed, 25 insertions, 18 deletions
diff --git a/main/SAPI.c b/main/SAPI.c
index c9ba5d5dce..f18eed7de9 100644
--- a/main/SAPI.c
+++ b/main/SAPI.c
@@ -133,6 +133,7 @@ PHP_FUNCTION(header_register_callback)
efree(callback_name);
RETURN_FALSE;
}
+
efree(callback_name);
if (SG(callback_func)) {
@@ -140,10 +141,10 @@ PHP_FUNCTION(header_register_callback)
SG(fci_cache) = empty_fcall_info_cache;
}
- Z_ADDREF_P(callback_func);
-
SG(callback_func) = callback_func;
-
+
+ Z_ADDREF_P(SG(callback_func));
+
RETURN_TRUE;
}
/* }}} */
@@ -152,24 +153,30 @@ static void sapi_run_header_callback(TSRMLS_D)
{
int error;
zend_fcall_info fci;
+ char *callback_name = NULL;
+ char *callback_error = NULL;
zval *retval_ptr = NULL;
-
- fci.size = sizeof(fci);
- fci.function_table = EG(function_table);
- fci.object_ptr = NULL;
- fci.function_name = SG(callback_func);
- fci.retval_ptr_ptr = &retval_ptr;
- fci.param_count = 0;
- fci.params = NULL;
- fci.no_separation = 0;
- fci.symbol_table = NULL;
-
- error = zend_call_function(&fci, &SG(fci_cache) TSRMLS_CC);
- if (error == FAILURE) {
+
+ if (zend_fcall_info_init(SG(callback_func), 0, &fci, &SG(fci_cache), &callback_name, &callback_error TSRMLS_CC) == SUCCESS) {
+ fci.retval_ptr_ptr = &retval_ptr;
+
+ error = zend_call_function(&fci, &SG(fci_cache) TSRMLS_CC);
+ if (error == FAILURE) {
+ goto callback_failed;
+ } else if (retval_ptr) {
+ zval_ptr_dtor(&retval_ptr);
+ }
+ } else {
+callback_failed:
php_error_docref(NULL TSRMLS_CC, E_WARNING, "Could not call the sapi_header_callback");
- } else if (retval_ptr) {
- zval_ptr_dtor(&retval_ptr);
}
+
+ if (callback_name) {
+ efree(callback_name);
+ }
+ if (callback_error) {
+ efree(callback_error);
+ }
}
SAPI_API void sapi_handle_post(void *arg TSRMLS_DC)