From: Dmitry Stogov Date: Mon, 17 Jul 2017 10:35:47 +0000 (+0300) Subject: Fixed CFG/SSA construction (avoid multiple identical predecessors) X-Git-Tag: php-7.2.0beta1~13 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d9d3b2c20641b61b4d02258cd1363aa713de37b8;p=php Fixed CFG/SSA construction (avoid multiple identical predecessors) --- diff --git a/ext/opcache/Optimizer/zend_cfg.c b/ext/opcache/Optimizer/zend_cfg.c index 9a7529aeee..25d0acb6ce 100644 --- a/ext/opcache/Optimizer/zend_cfg.c +++ b/ext/opcache/Optimizer/zend_cfg.c @@ -649,9 +649,18 @@ int zend_cfg_build_predecessors(zend_arena **arena, zend_cfg *cfg) /* {{{ */ for (j = 0; j < cfg->blocks_count; j++) { if (blocks[j].flags & ZEND_BB_REACHABLE) { + /* SWITCH_STRING/LONG may have few identical successors */ for (s = 0; s < blocks[j].successors_count; s++) { - /* SWITCH_STRING/LONG may have few following identical successors */ - if (s == 0 || blocks[j].successors[s-1] != blocks[j].successors[s]) { + int duplicate = 0; + int p; + + for (p = 0; p < s; p++) { + if (blocks[j].successors[p] == blocks[j].successors[s]) { + duplicate = 1; + break; + } + } + if (!duplicate) { zend_basic_block *b = blocks + blocks[j].successors[s]; predecessors[b->predecessor_offset + b->predecessors_count] = j;