summaryrefslogtreecommitdiff
path: root/Zend/zend_alloc.c
diff options
context:
space:
mode:
authorKalle Sommer Nielsen <kalle@php.net>2015-05-28 16:54:02 +0200
committerKalle Sommer Nielsen <kalle@php.net>2015-05-28 16:54:02 +0200
commitc4e9651b587e1ebcf3e2de7a2d3d586c0cc3e0c4 (patch)
tree00190af75735fac40e5b6b6154d629ef84194380 /Zend/zend_alloc.c
parent09b92a3a542455651016afe1bc9854e52b4673c3 (diff)
downloadphp-git-c4e9651b587e1ebcf3e2de7a2d3d586c0cc3e0c4.tar.gz
Merge the fix for #69703 to 5.5 per request from Julien
Diffstat (limited to 'Zend/zend_alloc.c')
-rw-r--r--Zend/zend_alloc.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/Zend/zend_alloc.c b/Zend/zend_alloc.c
index cd422e2d3e..7fe7ffbbd3 100644
--- a/Zend/zend_alloc.c
+++ b/Zend/zend_alloc.c
@@ -678,7 +678,7 @@ static inline unsigned int zend_mm_high_bit(size_t _size)
__asm {
bsr eax, _size
}
-#elif defined(__GNUC__) && (defined(__arm__) || defined(__aarch64__))
+#elif defined(__GNUC__) && (defined(__arm__) || defined(__aarch64__) || defined(__powerpc__))
return (8 * SIZEOF_SIZE_T - 1) - __builtin_clzl(_size);
#else
unsigned int n = 0;
@@ -706,7 +706,7 @@ static inline unsigned int zend_mm_low_bit(size_t _size)
__asm {
bsf eax, _size
}
-#elif defined(__GNUC__) && (defined(__arm__) || defined(__aarch64__))
+#elif defined(__GNUC__) && (defined(__arm__) || defined(__aarch64__) || defined(__powerpc__))
return __builtin_ctzl(_size);
#else
static const int offset[16] = {4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0};