summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXinchen Hui <laruence@php.net>2013-03-11 15:15:22 +0800
committerXinchen Hui <laruence@php.net>2013-03-11 15:15:22 +0800
commit0444708c5cd665179a936b86369f84b9dad8effe (patch)
treee42cfe487227802b6c845e1a248acd2962290964
parent7197f0ffccea7f195bc28571e30c389eadda874b (diff)
downloadphp-git-0444708c5cd665179a936b86369f84b9dad8effe.tar.gz
Disable zend_always_inline in debug build
it will be much more easier for debuging
-rw-r--r--Zend/zend.h6
1 files changed, 5 insertions, 1 deletions
diff --git a/Zend/zend.h b/Zend/zend.h
index b6c1a5b8a6..e1d1fad427 100644
--- a/Zend/zend.h
+++ b/Zend/zend.h
@@ -350,6 +350,10 @@ struct _zval_struct {
#define Z_UNSET_ISREF(z) Z_UNSET_ISREF_P(&(z))
#define Z_SET_ISREF_TO(z, isref) Z_SET_ISREF_TO_P(&(z), isref)
+#if ZEND_DEBUG
+#define zend_always_inline inline
+#define zend_never_inline
+#else
#if defined(__GNUC__)
#if __GNUC__ >= 3
#define zend_always_inline inline __attribute__((always_inline))
@@ -358,7 +362,6 @@ struct _zval_struct {
#define zend_always_inline inline
#define zend_never_inline
#endif
-
#elif defined(_MSC_VER)
#define zend_always_inline __forceinline
#define zend_never_inline
@@ -366,6 +369,7 @@ struct _zval_struct {
#define zend_always_inline inline
#define zend_never_inline
#endif
+#endif /* ZEND_DEBUG */
#if (defined (__GNUC__) && __GNUC__ > 2 ) && !defined(DARWIN) && !defined(__hpux) && !defined(_AIX)
# define EXPECTED(condition) __builtin_expect(condition, 1)