if (ival) {
if ((ival->range.start > last->range.start) ||
(ival->range.start == last->range.start &&
- ((!ival->hint && last->hint) ||
+ ((!ival->hint && last->hint && last->hint != ival) ||
ival->range.end > last->range.end))) {
last->list_next = ival;
last = ival;
break;
} else if ((ival->range.start < (*p)->range.start) ||
(ival->range.start == (*p)->range.start &&
- ((ival->hint && !(*p)->hint) ||
+ ((ival->hint && !(*p)->hint && ival->hint != *p) ||
ival->range.end < (*p)->range.end))) {
ival->list_next = *p;
*p = ival;
intervals[ssa->ops[line].op1_use] &&
ssa->ops[line].op1_use_chain < 0 &&
!ssa->vars[ssa->ops[line].op1_use].phi_use_chain) {
+
+ zend_ssa_phi *phi = ssa->vars[ssa->ops[line].op1_use].definition_phi;
+ if (phi &&
+ intervals[phi->sources[1]] &&
+ intervals[phi->sources[1]]->hint == intervals[ssa->ops[line].op1_use]) {
+ break;
+ }
zend_jit_add_hint(intervals, i, ssa->ops[line].op1_use);
} else if (opline->opcode != ZEND_SUB &&
ssa->ops[line].op2_use >= 0 &&
intervals[ssa->ops[line].op2_use] &&
ssa->ops[line].op2_use_chain < 0 &&
!ssa->vars[ssa->ops[line].op2_use].phi_use_chain) {
+
+ zend_ssa_phi *phi = ssa->vars[ssa->ops[line].op2_use].definition_phi;
+ if (phi &&
+ intervals[phi->sources[1]] &&
+ intervals[phi->sources[1]]->hint == intervals[ssa->ops[line].op2_use]) {
+ break;
+ }
zend_jit_add_hint(intervals, i, ssa->ops[line].op2_use);
}
}