1
0
mirror of https://github.com/php/php-src.git synced 2026-03-24 00:02:20 +01:00

Revert "Fix incorrect trace type inference in a false loop"

This reverts commit 7f06a9daa2.
This commit is contained in:
Dmitry Stogov
2023-11-07 18:29:26 +03:00
parent 7f06a9daa2
commit b88d38787b
2 changed files with 2 additions and 38 deletions

View File

@@ -787,19 +787,6 @@ static int zend_jit_trace_add_ret_phis(zend_jit_trace_rec *trace_buffer, uint32_
return ssa_vars_count;
}
static bool zend_jit_trace_is_false_loop(const zend_op_array *op_array, const zend_ssa *ssa, const zend_op **tssa_opcodes, zend_ssa *tssa)
{
uint32_t b;
zend_basic_block *bb;
ZEND_ASSERT(tssa->cfg.blocks_count == 2);
ZEND_ASSERT(tssa->cfg.blocks[1].len > 0);
b = ssa->cfg.map[tssa_opcodes[0] - op_array->opcodes];
bb = ssa->cfg.blocks + ssa->cfg.map[tssa_opcodes[tssa->cfg.blocks[1].len - 1] - op_array->opcodes];
return bb->loop_header != b;
}
static int zend_jit_trace_copy_ssa_var_info(const zend_op_array *op_array, const zend_ssa *ssa, const zend_op **tssa_opcodes, zend_ssa *tssa, int ssa_var)
{
int var, use, def, src;
@@ -809,8 +796,7 @@ static int zend_jit_trace_copy_ssa_var_info(const zend_op_array *op_array, const
uint32_t b = ssa->cfg.map[tssa_opcodes[0] - op_array->opcodes];
zend_basic_block *bb = ssa->cfg.blocks + b;
if ((bb->flags & ZEND_BB_LOOP_HEADER)
&& !zend_jit_trace_is_false_loop(op_array, ssa, tssa_opcodes, tssa)) {
if (bb->flags & ZEND_BB_LOOP_HEADER) {
zend_ssa_phi *phi = ssa->blocks[b].phis;
zend_ssa_phi *pi = NULL;
@@ -1405,8 +1391,7 @@ static zend_ssa *zend_jit_trace_build_tssa(zend_jit_trace_rec *trace_buffer, uin
tssa->cfg.blocks[0].successors = tssa->cfg.blocks[0].successors_storage;
tssa->cfg.blocks[0].successors[0] = 1;
tssa->cfg.blocks[1].flags = ZEND_BB_FOLLOW|ZEND_BB_TARGET|ZEND_BB_LOOP_HEADER|ZEND_BB_REACHABLE;
tssa->cfg.blocks[1].len = ssa_ops_count;
tssa->cfg.blocks[0].flags = ZEND_BB_FOLLOW|ZEND_BB_TARGET|ZEND_BB_LOOP_HEADER|ZEND_BB_REACHABLE;
tssa->cfg.blocks[1].successors_count = 1;
tssa->cfg.blocks[1].predecessors_count = 2;
tssa->cfg.blocks[1].successors = tssa->cfg.blocks[1].successors_storage;
@@ -1416,7 +1401,6 @@ static zend_ssa *zend_jit_trace_build_tssa(zend_jit_trace_rec *trace_buffer, uin
tssa->cfg.edges_count = 0;
tssa->cfg.blocks[0].flags = ZEND_BB_START|ZEND_BB_EXIT|ZEND_BB_REACHABLE;
tssa->cfg.blocks[0].len = ssa_ops_count;
tssa->cfg.blocks[0].successors_count = 0;
tssa->cfg.blocks[0].predecessors_count = 0;
}

View File

@@ -1,20 +0,0 @@
--TEST--
JIT LOOP: 004 Incorrect trace type inference in a false loop
--INI--
opcache.enable=1
opcache.enable_cli=1
opcache.jit_buffer_size=32M
--FILE--
<?php
function foo() {
for($i = 0; $i < 6; $i++) {
$a ?: $y;
$a = 3;
for(;$y;) $a = $a;
}
}
@foo();
?>
DONE
--EXPECT--
DONE