8273165: GraphKit::combine_exception_states fails with "matching stack sizes" assert

Reviewed-by: thartmann, kvn
This commit is contained in:
Vladimir Ivanov 2021-09-02 11:46:19 +00:00
parent c2e015c3c1
commit 632a7e0885

View File

@ -513,6 +513,12 @@ bool LateInlineVirtualCallGenerator::do_late_inline_check(Compile* C, JVMState*
// Method handle linker case is handled in CallDynamicJavaNode::Ideal(). // Method handle linker case is handled in CallDynamicJavaNode::Ideal().
// Unless inlining is performed, _override_symbolic_info bit will be set in DirectCallGenerator::generate(). // Unless inlining is performed, _override_symbolic_info bit will be set in DirectCallGenerator::generate().
// Implicit receiver null checks introduce problems when exception states are combined.
Node* receiver = jvms->map()->argument(jvms, 0);
const Type* recv_type = C->initial_gvn()->type(receiver);
if (recv_type->maybe_null()) {
return false;
}
// Even if inlining is not allowed, a virtual call can be strength-reduced to a direct call. // Even if inlining is not allowed, a virtual call can be strength-reduced to a direct call.
bool allow_inline = C->inlining_incrementally(); bool allow_inline = C->inlining_incrementally();
if (!allow_inline && _callee->holder()->is_interface()) { if (!allow_inline && _callee->holder()->is_interface()) {