diff options
author | Dmitry Stogov <dmitry@php.net> | 2008-06-25 12:18:36 +0000 |
---|---|---|
committer | Dmitry Stogov <dmitry@php.net> | 2008-06-25 12:18:36 +0000 |
commit | 531b31ca0809ff9d356a24d7c49fc9ed2302dc1b (patch) | |
tree | 943dbf9858a1854b1d7cb3bb248f67b4820b4502 | |
parent | c5ec48e858800afd14d59e2b32dc94a3e29cc5c3 (diff) | |
download | php-git-531b31ca0809ff9d356a24d7c49fc9ed2302dc1b.tar.gz |
Fixed bug #45352 (Segmentation fault because of tick function on second request)
-rw-r--r-- | main/main.c | 2 | ||||
-rw-r--r-- | main/php_ticks.c | 5 | ||||
-rw-r--r-- | main/php_ticks.h | 1 |
3 files changed, 8 insertions, 0 deletions
diff --git a/main/main.c b/main/main.c index 1f656eda57..2e083712a5 100644 --- a/main/main.c +++ b/main/main.c @@ -1472,6 +1472,8 @@ void php_request_shutdown(void *dummy) EG(opline_ptr) = NULL; EG(active_op_array) = NULL; + php_deactivate_ticks(TSRMLS_C); + /* 1. Call all possible shutdown functions registered with register_shutdown_function() */ if (PG(modules_activated)) zend_try { php_call_shutdown_functions(TSRMLS_C); diff --git a/main/php_ticks.c b/main/php_ticks.c index c9fa5e4e9b..ffc1dabf59 100644 --- a/main/php_ticks.c +++ b/main/php_ticks.c @@ -27,6 +27,11 @@ int php_startup_ticks(TSRMLS_D) return SUCCESS; } +void php_deactivate_ticks(TSRMLS_D) +{ + zend_llist_clean(&PG(tick_functions)); +} + void php_shutdown_ticks(TSRMLS_D) { zend_llist_destroy(&PG(tick_functions)); diff --git a/main/php_ticks.h b/main/php_ticks.h index d3d0ae1509..9dc930746f 100644 --- a/main/php_ticks.h +++ b/main/php_ticks.h @@ -22,6 +22,7 @@ #define PHP_TICKS_H int php_startup_ticks(TSRMLS_D); +void php_deactivate_ticks(TSRMLS_D); void php_shutdown_ticks(TSRMLS_D); void php_run_ticks(int count); |