summaryrefslogtreecommitdiff
path: root/Zend/zend_operators.h
diff options
context:
space:
mode:
authorMichael Orlitzky <michael@orlitzky.com>2016-09-16 21:03:01 +0200
committerNikita Popov <nikic@php.net>2016-09-16 21:06:02 +0200
commit0e76cafaf18dbbb6af609b2e765fe68fd30b8002 (patch)
tree9750aa0ce4ae119c686ac257b87ae22372c2667c /Zend/zend_operators.h
parent0ad82e41f251354517a90b21bb36fef6dc44b2a1 (diff)
downloadphp-git-0e76cafaf18dbbb6af609b2e765fe68fd30b8002.tar.gz
Disable add/sub asm for gcc 4.9 pic/pie builds
Diffstat (limited to 'Zend/zend_operators.h')
-rw-r--r--Zend/zend_operators.h10
1 files changed, 8 insertions, 2 deletions
diff --git a/Zend/zend_operators.h b/Zend/zend_operators.h
index f0ad0300fb..a08b49c30f 100644
--- a/Zend/zend_operators.h
+++ b/Zend/zend_operators.h
@@ -510,7 +510,10 @@ static zend_always_inline void fast_long_decrement_function(zval *op1)
static zend_always_inline void fast_long_add_function(zval *result, zval *op1, zval *op2)
{
-#if defined(__GNUC__) && defined(__i386__) && !(4 == __GNUC__ && 8 == __GNUC_MINOR__)
+#if defined(__GNUC__) && defined(__i386__) \
+ && !(4 == __GNUC__ && 8 == __GNUC_MINOR__) \
+ && !(4 == __GNUC__ && 9 == __GNUC_MINOR__ && (defined(__PIC__) || defined(__PIE__)))
+ /* Position-independent builds fail with gcc-4.9.x */
__asm__(
"movl (%1), %%eax\n\t"
"addl (%2), %%eax\n\t"
@@ -596,7 +599,10 @@ static zend_always_inline int fast_add_function(zval *result, zval *op1, zval *o
static zend_always_inline void fast_long_sub_function(zval *result, zval *op1, zval *op2)
{
-#if defined(__GNUC__) && defined(__i386__) && !(4 == __GNUC__ && 8 == __GNUC_MINOR__)
+#if defined(__GNUC__) && defined(__i386__) && \
+ !(4 == __GNUC__ && 8 == __GNUC_MINOR__) && \
+ !(4 == __GNUC__ && 9 == __GNUC_MINOR__ && (defined(__PIC__) || defined(__PIE__)))
+ /* Position-independent builds fail with gcc-4.9.x */
__asm__(
"movl (%1), %%eax\n\t"
"subl (%2), %%eax\n\t"