diff options
author | Dmitry Stogov <dmitry@zend.com> | 2020-10-19 23:22:43 +0300 |
---|---|---|
committer | Dmitry Stogov <dmitry@zend.com> | 2020-10-19 23:22:43 +0300 |
commit | fc2d477c5ba678ffc854f35e86a66a84cea23fad (patch) | |
tree | 4555780795f14e860dc9c290c8a90a651c8aad06 | |
parent | bf321f0c141f0ef31c2d8a7c405f050bd77ec3a9 (diff) | |
download | php-git-fc2d477c5ba678ffc854f35e86a66a84cea23fad.tar.gz |
Avoid partial register stall
-rw-r--r-- | ext/opcache/jit/zend_jit_x86.dasc | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/ext/opcache/jit/zend_jit_x86.dasc b/ext/opcache/jit/zend_jit_x86.dasc index bff24c4138..3166d14f3b 100644 --- a/ext/opcache/jit/zend_jit_x86.dasc +++ b/ext/opcache/jit/zend_jit_x86.dasc @@ -602,8 +602,10 @@ static void* dasm_labels[zend_lb_MAX]; | mov r0, lval |.endif || if (JIT_G(opt_flags) & allowed_opt_flags & ZEND_JIT_CPU_AVX) { +| vxorps xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0) | vcvtsi2sd, xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0), r0 || } else { +| xorps xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0) | cvtsi2sd, xmm(reg-ZREG_XMM0), r0 || } || } @@ -614,14 +616,18 @@ static void* dasm_labels[zend_lb_MAX]; | SSE_GET_LONG reg, Z_LVAL_P(Z_ZV(addr)) || } else if (Z_MODE(addr) == IS_MEM_ZVAL) { || if (JIT_G(opt_flags) & allowed_opt_flags & ZEND_JIT_CPU_AVX) { +| vxorps xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0) | vcvtsi2sd xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0), aword [Ra(Z_REG(addr))+Z_OFFSET(addr)] || } else { +| xorps xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0) | cvtsi2sd xmm(reg-ZREG_XMM0), aword [Ra(Z_REG(addr))+Z_OFFSET(addr)] || } || } else if (Z_MODE(addr) == IS_REG) { || if (JIT_G(opt_flags) & allowed_opt_flags & ZEND_JIT_CPU_AVX) { +| vxorps xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0) | vcvtsi2sd xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0), Ra(Z_REG(addr)) || } else { +| xorps xmm(reg-ZREG_XMM0), xmm(reg-ZREG_XMM0) | cvtsi2sd xmm(reg-ZREG_XMM0), Ra(Z_REG(addr)) || } || } else { |