--- old/src/share/vm/c1/c1_Optimizer.cpp 2011-12-20 17:58:22.093448029 +0100 +++ new/src/share/vm/c1/c1_Optimizer.cpp 2011-12-20 17:58:21.658580912 +0100 @@ -125,9 +125,16 @@ // inlining depths must match ValueStack* if_state = if_->state(); ValueStack* sux_state = sux->state(); - while (sux_state->scope() != if_state->scope()) { - if_state = if_state->caller_state(); - assert(if_state != NULL, "states do not match up"); + if (if_state->scope()->level() > sux_state->scope()->level()) { + while (sux_state->scope() != if_state->scope()) { + if_state = if_state->caller_state(); + assert(if_state != NULL, "states do not match up"); + } + } else if (if_state->scope()->level() < sux_state->scope()->level()) { + while (sux_state->scope() != if_state->scope()) { + sux_state = sux_state->caller_state(); + assert(sux_state != NULL, "states do not match up"); + } } if (sux_state->stack_size() <= if_state->stack_size()) return;