Merge branch 'PHP-8.1'

* PHP-8.1:
  JIT: Fix register clobbering
This commit is contained in:
Dmitry Stogov 2022-03-21 16:13:13 +03:00
commit 0ba92163a0
3 changed files with 27 additions and 0 deletions

View File

@ -15102,6 +15102,9 @@ static zend_regset zend_jit_get_scratch_regset(const zend_op *opline, const zend
if (op1_info & MAY_BE_DOUBLE) {
regset = ZEND_REGSET(ZREG_FPR0);
}
if (opline->result_type != IS_UNUSED && (op1_info & MAY_BE_LONG)) {
ZEND_REGSET_INCL(regset, ZREG_REG1);
}
}
break;
case ZEND_ADD:

View File

@ -16012,6 +16012,9 @@ static zend_regset zend_jit_get_scratch_regset(const zend_op *opline, const zend
if (op1_info & MAY_BE_DOUBLE) {
regset = ZEND_REGSET(ZREG_XMM0);
}
if (opline->result_type != IS_UNUSED && (op1_info & MAY_BE_LONG)) {
ZEND_REGSET_INCL(regset, ZREG_R1);
}
}
break;
case ZEND_ADD:

View File

@ -0,0 +1,21 @@
--TEST--
Register Alloction 014: Register clobbering
--INI--
opcache.enable=1
opcache.enable_cli=1
opcache.file_update_protection=0
opcache.jit_buffer_size=1M
--FILE--
<?php
function foo() {
for($cnt = 0; $cnt < 6; $cnt++) {
$e = $a-- + $a-- + $a *= $a;
for ($i = 0; $i <= .1; $i++);
}
}
foo();
?>
DONE
--EXPECTF--
Warning: Undefined variable $a in %sreg_alloc_014.php on line 4
DONE