6826960: C2 Sparc: assert(bb->_nodes(_bb_end)->is_Proj(),"skipping projections after expected call")
Add the check when a Halt node is placed in a separate block. Reviewed-by: twisti
This commit is contained in:
parent
72afcb0285
commit
014e5cdefb
@ -2256,7 +2256,8 @@ void Scheduling::DoScheduling() {
|
|||||||
// bother scheduling them.
|
// bother scheduling them.
|
||||||
Node *last = bb->_nodes[_bb_end];
|
Node *last = bb->_nodes[_bb_end];
|
||||||
if( last->is_Catch() ||
|
if( last->is_Catch() ||
|
||||||
(last->is_Mach() && last->as_Mach()->ideal_Opcode() == Op_Halt) ) {
|
// Exclude unreachable path case when Halt node is in a separate block.
|
||||||
|
(_bb_end > 1 && last->is_Mach() && last->as_Mach()->ideal_Opcode() == Op_Halt) ) {
|
||||||
// There must be a prior call. Skip it.
|
// There must be a prior call. Skip it.
|
||||||
while( !bb->_nodes[--_bb_end]->is_Call() ) {
|
while( !bb->_nodes[--_bb_end]->is_Call() ) {
|
||||||
assert( bb->_nodes[_bb_end]->is_Proj(), "skipping projections after expected call" );
|
assert( bb->_nodes[_bb_end]->is_Proj(), "skipping projections after expected call" );
|
||||||
|
Loading…
Reference in New Issue
Block a user