From 014e5cdefbe87a059a63f99745d8e80515d3f35f Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Tue, 7 Apr 2009 10:05:04 -0700 Subject: [PATCH] 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 --- hotspot/src/share/vm/opto/output.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/opto/output.cpp b/hotspot/src/share/vm/opto/output.cpp index c29274174e0..3c8af599142 100644 --- a/hotspot/src/share/vm/opto/output.cpp +++ b/hotspot/src/share/vm/opto/output.cpp @@ -2256,7 +2256,8 @@ void Scheduling::DoScheduling() { // bother scheduling them. Node *last = bb->_nodes[_bb_end]; 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. while( !bb->_nodes[--_bb_end]->is_Call() ) { assert( bb->_nodes[_bb_end]->is_Proj(), "skipping projections after expected call" );