summaryrefslogtreecommitdiff
path: root/compiler
diff options
context:
space:
mode:
Diffstat (limited to 'compiler')
-rw-r--r--compiler/optimizing/inliner.cc2
-rw-r--r--compiler/optimizing/instruction_builder.cc4
2 files changed, 6 insertions, 0 deletions
diff --git a/compiler/optimizing/inliner.cc b/compiler/optimizing/inliner.cc
index d679261d42..5281346644 100644
--- a/compiler/optimizing/inliner.cc
+++ b/compiler/optimizing/inliner.cc
@@ -1593,6 +1593,8 @@ bool HInliner::TryBuildAndInline(HInvoke* invoke_instruction,
ReferenceTypeInfo receiver_type,
HInstruction** return_replacement,
bool is_speculative) {
+ DCHECK_IMPLIES(method->IsStatic(), !receiver_type.IsValid());
+ DCHECK_IMPLIES(!method->IsStatic(), receiver_type.IsValid());
// If invoke_instruction is devirtualized to a different method, give intrinsics
// another chance before we try to inline it.
if (invoke_instruction->GetResolvedMethod() != method &&
diff --git a/compiler/optimizing/instruction_builder.cc b/compiler/optimizing/instruction_builder.cc
index c66fd3bb26..8226987968 100644
--- a/compiler/optimizing/instruction_builder.cc
+++ b/compiler/optimizing/instruction_builder.cc
@@ -992,6 +992,10 @@ static ArtMethod* ResolveMethod(uint16_t method_idx,
(!resolved_method->IsPublic() && !declaring_class_accessible)) {
return nullptr;
}
+
+ if (UNLIKELY(resolved_method->CheckIncompatibleClassChange(*invoke_type))) {
+ return nullptr;
+ }
}
// We have to special case the invoke-super case, as ClassLinker::ResolveMethod does not.