mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-16 09:04:41 +02:00
8136421: JEP 243: Java-Level JVM Compiler Interface
Reviewed-by: ihse, alanb, roland, coleenp, iveresov, kvn, kbarrett
This commit is contained in:
parent
f5b4bb46f5
commit
16526e000e
505 changed files with 50394 additions and 915 deletions
|
@ -280,11 +280,13 @@ bool CompiledIC::is_call_to_compiled() const {
|
|||
bool is_monomorphic = (cb != NULL && cb->is_nmethod());
|
||||
// Check that the cached_value is a klass for non-optimized monomorphic calls
|
||||
// This assertion is invalid for compiler1: a call that does not look optimized (no static stub) can be used
|
||||
// for calling directly to vep without using the inline cache (i.e., cached_value == NULL)
|
||||
// for calling directly to vep without using the inline cache (i.e., cached_value == NULL).
|
||||
// For JVMCI this occurs because CHA is only used to improve inlining so call sites which could be optimized
|
||||
// virtuals because there are no currently loaded subclasses of a type are left as virtual call sites.
|
||||
#ifdef ASSERT
|
||||
CodeBlob* caller = CodeCache::find_blob_unsafe(instruction_address());
|
||||
bool is_c1_method = caller->is_compiled_by_c1();
|
||||
assert( is_c1_method ||
|
||||
bool is_c1_or_jvmci_method = caller->is_compiled_by_c1() || caller->is_compiled_by_jvmci();
|
||||
assert( is_c1_or_jvmci_method ||
|
||||
!is_monomorphic ||
|
||||
is_optimized() ||
|
||||
!caller->is_alive() ||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue