diff options
| author | David Soria Parra <dsp@php.net> | 2010-04-24 13:32:30 +0000 | 
|---|---|---|
| committer | David Soria Parra <dsp@php.net> | 2010-04-24 13:32:30 +0000 | 
| commit | 08b9fdc8a3bf29e27431b7907b5ea4973e9c7042 (patch) | |
| tree | 2b27f135a1cfad5f4d90fd437710aec7777eaff1 /Zend/zend_dtrace.c | |
| parent | fd42b5064c497e500e5745bf36d1b0ddd5bd34bd (diff) | |
| download | php-git-08b9fdc8a3bf29e27431b7907b5ea4973e9c7042.tar.gz | |
Add DTrace probes
Diffstat (limited to 'Zend/zend_dtrace.c')
| -rw-r--r-- | Zend/zend_dtrace.c | 108 | 
1 files changed, 108 insertions, 0 deletions
| diff --git a/Zend/zend_dtrace.c b/Zend/zend_dtrace.c new file mode 100644 index 0000000000..5b2d0d2dfe --- /dev/null +++ b/Zend/zend_dtrace.c @@ -0,0 +1,108 @@ +/* +   +----------------------------------------------------------------------+ +   | Zend Engine                                                          | +   +----------------------------------------------------------------------+ +   | Copyright (c) 1998-2009 Zend Technologies Ltd. (http://www.zend.com) | +   +----------------------------------------------------------------------+ +   | This source file is subject to version 2.00 of the Zend license,     | +   | that is bundled with this package in the file LICENSE, and is        | +   | available through the world-wide-web at the following url:           | +   | http://www.zend.com/license/2_00.txt.                                | +   | If you did not receive a copy of the Zend license and are unable to  | +   | obtain it through the world-wide-web, please send a note to          | +   | license@zend.com so we can mail you a copy immediately.              | +   +----------------------------------------------------------------------+ +   | Authors: David Soria Parra <david.soriaparra@sun.com>                | +   +----------------------------------------------------------------------+ +*/ + +/* $Id: $ */ + +#include "zend.h" +#include "zend_API.h" +#include "zend_dtrace.h" + +#ifdef HAVE_DTRACE +/* PHP DTrace probes {{{ */ +static inline char *dtrace_get_executed_filename(TSRMLS_D) +{ +	if (EG(current_execute_data) && EG(current_execute_data)->op_array) { +		return EG(current_execute_data)->op_array->filename; +	} else { +		return zend_get_executed_filename(TSRMLS_C); +	} +} + +ZEND_API zend_op_array *dtrace_compile_file(zend_file_handle *file_handle, int type TSRMLS_DC) +{ +	zend_op_array *res; +	DTRACE_COMPILE_FILE_ENTRY(file_handle->opened_path, file_handle->filename); +	res = compile_file(file_handle, type TSRMLS_CC); +	DTRACE_COMPILE_FILE_RETURN(file_handle->opened_path, file_handle->filename); + +	return res; +} + +/* We wrap the execute function to have fire the execute-entry/return and function-entry/return probes */ +ZEND_API void dtrace_execute(zend_op_array *op_array TSRMLS_DC) +{ +	int lineno; +	char *scope, *filename, *funcname, *classname; +	scope = filename = funcname = classname = NULL; + +	/* we need filename and lineno for both execute and function probes */ +	if (DTRACE_EXECUTE_ENTRY_ENABLED() || DTRACE_EXECUTE_RETURN_ENABLED() +		|| DTRACE_FUNCTION_ENTRY_ENABLED() || DTRACE_FUNCTION_RETURN_ENABLED()) { +		filename = dtrace_get_executed_filename(TSRMLS_C); +		lineno = zend_get_executed_lineno(TSRMLS_C); +	} + +	if (DTRACE_FUNCTION_ENTRY_ENABLED() || DTRACE_FUNCTION_RETURN_ENABLED()) { +		filename = dtrace_get_executed_filename(TSRMLS_C); +		classname = get_active_class_name(&scope TSRMLS_CC); +		funcname = get_active_function_name(TSRMLS_C); +		lineno = zend_get_executed_lineno(TSRMLS_C); +	} + +	if (DTRACE_EXECUTE_ENTRY_ENABLED()) { +		DTRACE_EXECUTE_ENTRY(filename, lineno); +	} + +	if (DTRACE_FUNCTION_ENTRY_ENABLED() && funcname != NULL) { +		DTRACE_FUNCTION_ENTRY(funcname, filename, lineno, classname, scope); +	} + +	execute(op_array TSRMLS_CC); + +	if (DTRACE_FUNCTION_RETURN_ENABLED() && funcname != NULL) { +		DTRACE_FUNCTION_RETURN(funcname, filename, lineno, classname, scope); +	} + +	if (DTRACE_EXECUTE_RETURN_ENABLED()) { +		DTRACE_EXECUTE_RETURN(filename, lineno); +	} +} + +ZEND_API void dtrace_execute_internal(zend_execute_data *execute_data_ptr, int return_value_used TSRMLS_DC) +{ +	int lineno; +	char *filename; +	if (DTRACE_EXECUTE_ENTRY_ENABLED() || DTRACE_EXECUTE_RETURN_ENABLED()) { +		filename = dtrace_get_executed_filename(TSRMLS_C); +		lineno = zend_get_executed_lineno(TSRMLS_C); +	} + +	if (DTRACE_EXECUTE_ENTRY_ENABLED()) { +		DTRACE_EXECUTE_ENTRY(filename, lineno); +	} + +	execute_internal(execute_data_ptr, return_value_used TSRMLS_CC); + +	if (DTRACE_EXECUTE_RETURN_ENABLED()) { +		DTRACE_EXECUTE_RETURN(filename, lineno); +	} +} + +/* }}} */ +#endif /* HAVE_DTRACE */ + | 
