From 4dc79c2e054fe2edd7bf6441f0d4c87bb4e5c5e0 Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Tue, 3 Sep 2019 17:45:02 +0300 Subject: [PATCH] 8227236: assert(singleton != __null && singleton != declared_interface) failed Reviewed-by: dlong --- src/hotspot/share/c1/c1_GraphBuilder.cpp | 9 ++++----- src/hotspot/share/ci/ciInstanceKlass.hpp | 6 ++++++ src/hotspot/share/opto/doCall.cpp | 6 ++++-- 3 files changed, 14 insertions(+), 7 deletions(-) diff --git a/src/hotspot/share/c1/c1_GraphBuilder.cpp b/src/hotspot/share/c1/c1_GraphBuilder.cpp index 8baaff0c764..dc64e15ac18 100644 --- a/src/hotspot/share/c1/c1_GraphBuilder.cpp +++ b/src/hotspot/share/c1/c1_GraphBuilder.cpp @@ -1957,12 +1957,11 @@ void GraphBuilder::invoke(Bytecodes::Code code) { // number of implementors for decl_interface is 0 or 1. If // it's 0 then no class implements decl_interface and there's // no point in inlining. - ciInstanceKlass* singleton = NULL; ciInstanceKlass* declared_interface = callee_holder; - if (declared_interface->nof_implementors() == 1 && - (!target->is_default_method() || target->is_overpass()) /* CHA doesn't support default methods yet. */) { - singleton = declared_interface->implementor(); - assert(singleton != NULL && singleton != declared_interface, ""); + ciInstanceKlass* singleton = declared_interface->unique_implementor(); + if (singleton != NULL && + (!target->is_default_method() || target->is_overpass()) /* CHA doesn't support default methods yet. */ ) { + assert(singleton != declared_interface, "not a unique implementor"); cha_monomorphic_target = target->find_monomorphic_target(calling_klass, declared_interface, singleton); if (cha_monomorphic_target != NULL) { if (cha_monomorphic_target->holder() != compilation()->env()->Object_klass()) { diff --git a/src/hotspot/share/ci/ciInstanceKlass.hpp b/src/hotspot/share/ci/ciInstanceKlass.hpp index 9e0ccd7dab9..6af24c9675c 100644 --- a/src/hotspot/share/ci/ciInstanceKlass.hpp +++ b/src/hotspot/share/ci/ciInstanceKlass.hpp @@ -248,6 +248,12 @@ public: bool is_leaf_type(); ciInstanceKlass* implementor(); + ciInstanceKlass* unique_implementor() { + assert(is_loaded(), "must be loaded"); + ciInstanceKlass* impl = implementor(); + return (impl != this ? impl : NULL); + } + // Is the defining class loader of this class the default loader? bool uses_default_loader() const; diff --git a/src/hotspot/share/opto/doCall.cpp b/src/hotspot/share/opto/doCall.cpp index be108943e59..fe36941af34 100644 --- a/src/hotspot/share/opto/doCall.cpp +++ b/src/hotspot/share/opto/doCall.cpp @@ -310,10 +310,12 @@ CallGenerator* Compile::call_generator(ciMethod* callee, int vtable_index, bool if (call_does_dispatch && bytecode == Bytecodes::_invokeinterface) { ciInstanceKlass* declared_interface = caller->get_declared_method_holder_at_bci(bci)->as_instance_klass(); + ciInstanceKlass* singleton = declared_interface->unique_implementor(); - if (declared_interface->nof_implementors() == 1 && + if (singleton != NULL && (!callee->is_default_method() || callee->is_overpass()) /* CHA doesn't support default methods yet */) { - ciInstanceKlass* singleton = declared_interface->implementor(); + assert(singleton != declared_interface, "not a unique implementor"); + ciMethod* cha_monomorphic_target = callee->find_monomorphic_target(caller->holder(), declared_interface, singleton);