From c89a572b3e927c93bf5de79c51fca3a58944cf61 Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Tue, 15 Sep 2009 19:03:39 -0700 Subject: [PATCH] 6879362: assert(!klass_is_exact(),"only non-exact klass") Do nothing for AddP node which has type not related to the type of allocated object. Reviewed-by: never --- hotspot/src/share/vm/opto/escape.cpp | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/hotspot/src/share/vm/opto/escape.cpp b/hotspot/src/share/vm/opto/escape.cpp index bd04a5ae7ac..b22f4814a57 100644 --- a/hotspot/src/share/vm/opto/escape.cpp +++ b/hotspot/src/share/vm/opto/escape.cpp @@ -524,12 +524,15 @@ bool ConnectionGraph::split_AddP(Node *addp, Node *base, PhaseGVN *igvn) { // inlining) which was not eliminated during parsing since the exactness // of the allocation type was not propagated to the subclass type check. // + // Or the type 't' could be not related to 'base_t' at all. + // It could happened when CHA type is different from MDO type on a dead path + // (for example, from instanceof check) which is not collapsed during parsing. + // // Do nothing for such AddP node and don't process its users since // this code branch will go away. // if (!t->is_known_instance() && - !t->klass()->equals(base_t->klass()) && - t->klass()->is_subtype_of(base_t->klass())) { + !base_t->klass()->is_subtype_of(t->klass())) { return false; // bail out }