8300240: Replace NULL with nullptr in share/ci/
Reviewed-by: kvn, coleenp
This commit is contained in:
parent
5c1ec82656
commit
f52d35c84b
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -200,7 +200,7 @@ void BCEscapeAnalyzer::set_modified(ArgumentMap vars, int offs, int size) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool BCEscapeAnalyzer::is_recursive_call(ciMethod* callee) {
|
bool BCEscapeAnalyzer::is_recursive_call(ciMethod* callee) {
|
||||||
for (BCEscapeAnalyzer* scope = this; scope != NULL; scope = scope->_parent) {
|
for (BCEscapeAnalyzer* scope = this; scope != nullptr; scope = scope->_parent) {
|
||||||
if (scope->method() == callee) {
|
if (scope->method() == callee) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -296,7 +296,7 @@ void BCEscapeAnalyzer::invoke(StateInfo &state, Bytecodes::Code code, ciMethod*
|
|||||||
}
|
}
|
||||||
|
|
||||||
// determine actual method (use CHA if necessary)
|
// determine actual method (use CHA if necessary)
|
||||||
ciMethod* inline_target = NULL;
|
ciMethod* inline_target = nullptr;
|
||||||
if (target->is_loaded() && klass->is_loaded()
|
if (target->is_loaded() && klass->is_loaded()
|
||||||
&& (klass->is_initialized() || (klass->is_interface() && target->holder()->is_initialized()))) {
|
&& (klass->is_initialized() || (klass->is_interface() && target->holder()->is_initialized()))) {
|
||||||
if (code == Bytecodes::_invokestatic
|
if (code == Bytecodes::_invokestatic
|
||||||
@ -308,7 +308,7 @@ void BCEscapeAnalyzer::invoke(StateInfo &state, Bytecodes::Code code, ciMethod*
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inline_target != NULL && !is_recursive_call(inline_target)) {
|
if (inline_target != nullptr && !is_recursive_call(inline_target)) {
|
||||||
// analyze callee
|
// analyze callee
|
||||||
BCEscapeAnalyzer analyzer(inline_target, this);
|
BCEscapeAnalyzer analyzer(inline_target, this);
|
||||||
|
|
||||||
@ -891,10 +891,10 @@ void BCEscapeAnalyzer::iterate_one_block(ciBlock *blk, StateInfo &state, Growabl
|
|||||||
case Bytecodes::_invokedynamic:
|
case Bytecodes::_invokedynamic:
|
||||||
case Bytecodes::_invokeinterface:
|
case Bytecodes::_invokeinterface:
|
||||||
{ bool ignored_will_link;
|
{ bool ignored_will_link;
|
||||||
ciSignature* declared_signature = NULL;
|
ciSignature* declared_signature = nullptr;
|
||||||
ciMethod* target = s.get_method(ignored_will_link, &declared_signature);
|
ciMethod* target = s.get_method(ignored_will_link, &declared_signature);
|
||||||
ciKlass* holder = s.get_declared_method_holder();
|
ciKlass* holder = s.get_declared_method_holder();
|
||||||
assert(declared_signature != NULL, "cannot be null");
|
assert(declared_signature != nullptr, "cannot be null");
|
||||||
// If the current bytecode has an attached appendix argument,
|
// If the current bytecode has an attached appendix argument,
|
||||||
// push an unknown object to represent that argument. (Analysis
|
// push an unknown object to represent that argument. (Analysis
|
||||||
// of dynamic call sites, especially invokehandle calls, needs
|
// of dynamic call sites, especially invokehandle calls, needs
|
||||||
@ -1105,8 +1105,8 @@ void BCEscapeAnalyzer::iterate_blocks(Arena *arena) {
|
|||||||
blockstates[i]._stack_height = 0;
|
blockstates[i]._stack_height = 0;
|
||||||
blockstates[i]._max_stack = stkSize;
|
blockstates[i]._max_stack = stkSize;
|
||||||
}
|
}
|
||||||
GrowableArray<ciBlock *> worklist(arena, numblocks / 4, 0, NULL);
|
GrowableArray<ciBlock *> worklist(arena, numblocks / 4, 0, nullptr);
|
||||||
GrowableArray<ciBlock *> successors(arena, 4, 0, NULL);
|
GrowableArray<ciBlock *> successors(arena, 4, 0, nullptr);
|
||||||
|
|
||||||
_methodBlocks->clear_processed();
|
_methodBlocks->clear_processed();
|
||||||
|
|
||||||
@ -1439,9 +1439,9 @@ void BCEscapeAnalyzer::dump() {
|
|||||||
|
|
||||||
BCEscapeAnalyzer::BCEscapeAnalyzer(ciMethod* method, BCEscapeAnalyzer* parent)
|
BCEscapeAnalyzer::BCEscapeAnalyzer(ciMethod* method, BCEscapeAnalyzer* parent)
|
||||||
: _arena(CURRENT_ENV->arena())
|
: _arena(CURRENT_ENV->arena())
|
||||||
, _conservative(method == NULL || !EstimateArgEscape)
|
, _conservative(method == nullptr || !EstimateArgEscape)
|
||||||
, _method(method)
|
, _method(method)
|
||||||
, _methodData(method ? method->method_data() : NULL)
|
, _methodData(method ? method->method_data() : nullptr)
|
||||||
, _arg_size(method ? method->arg_size() : 0)
|
, _arg_size(method ? method->arg_size() : 0)
|
||||||
, _arg_local(_arena)
|
, _arg_local(_arena)
|
||||||
, _arg_stack(_arena)
|
, _arg_stack(_arena)
|
||||||
@ -1450,9 +1450,9 @@ BCEscapeAnalyzer::BCEscapeAnalyzer(ciMethod* method, BCEscapeAnalyzer* parent)
|
|||||||
, _return_allocated(false)
|
, _return_allocated(false)
|
||||||
, _allocated_escapes(false)
|
, _allocated_escapes(false)
|
||||||
, _unknown_modified(false)
|
, _unknown_modified(false)
|
||||||
, _dependencies(_arena, 4, 0, NULL)
|
, _dependencies(_arena, 4, 0, nullptr)
|
||||||
, _parent(parent)
|
, _parent(parent)
|
||||||
, _level(parent == NULL ? 0 : parent->level() + 1) {
|
, _level(parent == nullptr ? 0 : parent->level() + 1) {
|
||||||
if (!_conservative) {
|
if (!_conservative) {
|
||||||
_arg_local.clear();
|
_arg_local.clear();
|
||||||
_arg_stack.clear();
|
_arg_stack.clear();
|
||||||
@ -1461,7 +1461,7 @@ BCEscapeAnalyzer::BCEscapeAnalyzer(ciMethod* method, BCEscapeAnalyzer* parent)
|
|||||||
_arg_modified = (uint *) arena->Amalloc(_arg_size * sizeof(uint));
|
_arg_modified = (uint *) arena->Amalloc(_arg_size * sizeof(uint));
|
||||||
Copy::zero_to_bytes(_arg_modified, _arg_size * sizeof(uint));
|
Copy::zero_to_bytes(_arg_modified, _arg_size * sizeof(uint));
|
||||||
|
|
||||||
if (methodData() == NULL)
|
if (methodData() == nullptr)
|
||||||
return;
|
return;
|
||||||
if (methodData()->has_escape_info()) {
|
if (methodData()->has_escape_info()) {
|
||||||
TRACE_BCEA(2, tty->print_cr("[EA] Reading previous results for %s.%s",
|
TRACE_BCEA(2, tty->print_cr("[EA] Reading previous results for %s.%s",
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -105,7 +105,7 @@ class BCEscapeAnalyzer : public ArenaObj {
|
|||||||
bool contains(uint arg_set1, uint arg_set2);
|
bool contains(uint arg_set1, uint arg_set2);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
BCEscapeAnalyzer(ciMethod* method, BCEscapeAnalyzer* parent = NULL);
|
BCEscapeAnalyzer(ciMethod* method, BCEscapeAnalyzer* parent = nullptr);
|
||||||
|
|
||||||
// accessors
|
// accessors
|
||||||
ciMethod* method() const { return _method; }
|
ciMethod* method() const { return _method; }
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -46,7 +46,7 @@ static BasicType fixup_element_type(BasicType bt) {
|
|||||||
ciConstant ciArray::element_value_impl(BasicType elembt,
|
ciConstant ciArray::element_value_impl(BasicType elembt,
|
||||||
arrayOop ary,
|
arrayOop ary,
|
||||||
int index) {
|
int index) {
|
||||||
if (ary == NULL)
|
if (ary == nullptr)
|
||||||
return ciConstant();
|
return ciConstant();
|
||||||
assert(ary->is_array(), "");
|
assert(ary->is_array(), "");
|
||||||
if (index < 0 || index >= ary->length())
|
if (index < 0 || index >= ary->length())
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -50,7 +50,7 @@ private:
|
|||||||
_morphism = 0;
|
_morphism = 0;
|
||||||
_count = -1;
|
_count = -1;
|
||||||
_receiver_count[0] = -1;
|
_receiver_count[0] = -1;
|
||||||
_receiver[0] = NULL;
|
_receiver[0] = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_receiver(ciKlass* receiver, int receiver_count);
|
void add_receiver(ciKlass* receiver, int receiver_count);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -57,7 +57,7 @@ void* ciConstantPoolCache::get(int index) {
|
|||||||
int pos = _keys->find_sorted<int, ciConstantPoolCache::key_compare>(index, found);
|
int pos = _keys->find_sorted<int, ciConstantPoolCache::key_compare>(index, found);
|
||||||
if (!found) {
|
if (!found) {
|
||||||
// This element is not present in the cache.
|
// This element is not present in the cache.
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return _elements->at(pos);
|
return _elements->at(pos);
|
||||||
}
|
}
|
||||||
|
@ -91,17 +91,17 @@
|
|||||||
|
|
||||||
ciObject* ciEnv::_null_object_instance;
|
ciObject* ciEnv::_null_object_instance;
|
||||||
|
|
||||||
#define VM_CLASS_DEFN(name, ignore_s) ciInstanceKlass* ciEnv::_##name = NULL;
|
#define VM_CLASS_DEFN(name, ignore_s) ciInstanceKlass* ciEnv::_##name = nullptr;
|
||||||
VM_CLASSES_DO(VM_CLASS_DEFN)
|
VM_CLASSES_DO(VM_CLASS_DEFN)
|
||||||
#undef VM_CLASS_DEFN
|
#undef VM_CLASS_DEFN
|
||||||
|
|
||||||
ciSymbol* ciEnv::_unloaded_cisymbol = NULL;
|
ciSymbol* ciEnv::_unloaded_cisymbol = nullptr;
|
||||||
ciInstanceKlass* ciEnv::_unloaded_ciinstance_klass = NULL;
|
ciInstanceKlass* ciEnv::_unloaded_ciinstance_klass = nullptr;
|
||||||
ciObjArrayKlass* ciEnv::_unloaded_ciobjarrayklass = NULL;
|
ciObjArrayKlass* ciEnv::_unloaded_ciobjarrayklass = nullptr;
|
||||||
|
|
||||||
jobject ciEnv::_ArrayIndexOutOfBoundsException_handle = NULL;
|
jobject ciEnv::_ArrayIndexOutOfBoundsException_handle = nullptr;
|
||||||
jobject ciEnv::_ArrayStoreException_handle = NULL;
|
jobject ciEnv::_ArrayStoreException_handle = nullptr;
|
||||||
jobject ciEnv::_ClassCastException_handle = NULL;
|
jobject ciEnv::_ClassCastException_handle = nullptr;
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
static bool firstEnv = true;
|
static bool firstEnv = true;
|
||||||
@ -117,28 +117,28 @@ ciEnv::ciEnv(CompileTask* task)
|
|||||||
thread->set_env(this);
|
thread->set_env(this);
|
||||||
assert(ciEnv::current() == this, "sanity");
|
assert(ciEnv::current() == this, "sanity");
|
||||||
|
|
||||||
_oop_recorder = NULL;
|
_oop_recorder = nullptr;
|
||||||
_debug_info = NULL;
|
_debug_info = nullptr;
|
||||||
_dependencies = NULL;
|
_dependencies = nullptr;
|
||||||
_failure_reason = NULL;
|
_failure_reason = nullptr;
|
||||||
_inc_decompile_count_on_failure = true;
|
_inc_decompile_count_on_failure = true;
|
||||||
_compilable = MethodCompilable;
|
_compilable = MethodCompilable;
|
||||||
_break_at_compile = false;
|
_break_at_compile = false;
|
||||||
_compiler_data = NULL;
|
_compiler_data = nullptr;
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
assert(!firstEnv, "not initialized properly");
|
assert(!firstEnv, "not initialized properly");
|
||||||
#endif /* !PRODUCT */
|
#endif /* !PRODUCT */
|
||||||
|
|
||||||
_num_inlined_bytecodes = 0;
|
_num_inlined_bytecodes = 0;
|
||||||
assert(task == NULL || thread->task() == task, "sanity");
|
assert(task == nullptr || thread->task() == task, "sanity");
|
||||||
if (task != NULL) {
|
if (task != nullptr) {
|
||||||
task->mark_started(os::elapsed_counter());
|
task->mark_started(os::elapsed_counter());
|
||||||
}
|
}
|
||||||
_task = task;
|
_task = task;
|
||||||
_log = NULL;
|
_log = nullptr;
|
||||||
|
|
||||||
// Temporary buffer for creating symbols and such.
|
// Temporary buffer for creating symbols and such.
|
||||||
_name_buffer = NULL;
|
_name_buffer = nullptr;
|
||||||
_name_buffer_len = 0;
|
_name_buffer_len = 0;
|
||||||
|
|
||||||
_arena = &_ciEnv_arena;
|
_arena = &_ciEnv_arena;
|
||||||
@ -153,17 +153,17 @@ ciEnv::ciEnv(CompileTask* task)
|
|||||||
assert(Universe::is_fully_initialized(), "should be complete");
|
assert(Universe::is_fully_initialized(), "should be complete");
|
||||||
|
|
||||||
oop o = Universe::null_ptr_exception_instance();
|
oop o = Universe::null_ptr_exception_instance();
|
||||||
assert(o != NULL, "should have been initialized");
|
assert(o != nullptr, "should have been initialized");
|
||||||
_NullPointerException_instance = get_object(o)->as_instance();
|
_NullPointerException_instance = get_object(o)->as_instance();
|
||||||
o = Universe::arithmetic_exception_instance();
|
o = Universe::arithmetic_exception_instance();
|
||||||
assert(o != NULL, "should have been initialized");
|
assert(o != nullptr, "should have been initialized");
|
||||||
_ArithmeticException_instance = get_object(o)->as_instance();
|
_ArithmeticException_instance = get_object(o)->as_instance();
|
||||||
|
|
||||||
_ArrayIndexOutOfBoundsException_instance = NULL;
|
_ArrayIndexOutOfBoundsException_instance = nullptr;
|
||||||
_ArrayStoreException_instance = NULL;
|
_ArrayStoreException_instance = nullptr;
|
||||||
_ClassCastException_instance = NULL;
|
_ClassCastException_instance = nullptr;
|
||||||
_the_null_string = NULL;
|
_the_null_string = nullptr;
|
||||||
_the_min_jint_string = NULL;
|
_the_min_jint_string = nullptr;
|
||||||
|
|
||||||
_jvmti_redefinition_count = 0;
|
_jvmti_redefinition_count = 0;
|
||||||
_jvmti_can_hotswap_or_post_breakpoint = false;
|
_jvmti_can_hotswap_or_post_breakpoint = false;
|
||||||
@ -171,8 +171,8 @@ ciEnv::ciEnv(CompileTask* task)
|
|||||||
_jvmti_can_post_on_exceptions = false;
|
_jvmti_can_post_on_exceptions = false;
|
||||||
_jvmti_can_pop_frame = false;
|
_jvmti_can_pop_frame = false;
|
||||||
|
|
||||||
_dyno_klasses = NULL;
|
_dyno_klasses = nullptr;
|
||||||
_dyno_locs = NULL;
|
_dyno_locs = nullptr;
|
||||||
_dyno_name[0] = '\0';
|
_dyno_name[0] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -242,29 +242,29 @@ ciEnv::ciEnv(Arena* arena) : _ciEnv_arena(mtCompiler) {
|
|||||||
|
|
||||||
// Set up ciEnv::current immediately, for the sake of ciObjectFactory, etc.
|
// Set up ciEnv::current immediately, for the sake of ciObjectFactory, etc.
|
||||||
CompilerThread* current_thread = CompilerThread::current();
|
CompilerThread* current_thread = CompilerThread::current();
|
||||||
assert(current_thread->env() == NULL, "must be");
|
assert(current_thread->env() == nullptr, "must be");
|
||||||
current_thread->set_env(this);
|
current_thread->set_env(this);
|
||||||
assert(ciEnv::current() == this, "sanity");
|
assert(ciEnv::current() == this, "sanity");
|
||||||
|
|
||||||
_oop_recorder = NULL;
|
_oop_recorder = nullptr;
|
||||||
_debug_info = NULL;
|
_debug_info = nullptr;
|
||||||
_dependencies = NULL;
|
_dependencies = nullptr;
|
||||||
_failure_reason = NULL;
|
_failure_reason = nullptr;
|
||||||
_inc_decompile_count_on_failure = true;
|
_inc_decompile_count_on_failure = true;
|
||||||
_compilable = MethodCompilable_never;
|
_compilable = MethodCompilable_never;
|
||||||
_break_at_compile = false;
|
_break_at_compile = false;
|
||||||
_compiler_data = NULL;
|
_compiler_data = nullptr;
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
assert(firstEnv, "must be first");
|
assert(firstEnv, "must be first");
|
||||||
firstEnv = false;
|
firstEnv = false;
|
||||||
#endif /* !PRODUCT */
|
#endif /* !PRODUCT */
|
||||||
|
|
||||||
_num_inlined_bytecodes = 0;
|
_num_inlined_bytecodes = 0;
|
||||||
_task = NULL;
|
_task = nullptr;
|
||||||
_log = NULL;
|
_log = nullptr;
|
||||||
|
|
||||||
// Temporary buffer for creating symbols and such.
|
// Temporary buffer for creating symbols and such.
|
||||||
_name_buffer = NULL;
|
_name_buffer = nullptr;
|
||||||
_name_buffer_len = 0;
|
_name_buffer_len = 0;
|
||||||
|
|
||||||
_arena = arena;
|
_arena = arena;
|
||||||
@ -278,13 +278,13 @@ ciEnv::ciEnv(Arena* arena) : _ciEnv_arena(mtCompiler) {
|
|||||||
|
|
||||||
assert(Universe::is_fully_initialized(), "must be");
|
assert(Universe::is_fully_initialized(), "must be");
|
||||||
|
|
||||||
_NullPointerException_instance = NULL;
|
_NullPointerException_instance = nullptr;
|
||||||
_ArithmeticException_instance = NULL;
|
_ArithmeticException_instance = nullptr;
|
||||||
_ArrayIndexOutOfBoundsException_instance = NULL;
|
_ArrayIndexOutOfBoundsException_instance = nullptr;
|
||||||
_ArrayStoreException_instance = NULL;
|
_ArrayStoreException_instance = nullptr;
|
||||||
_ClassCastException_instance = NULL;
|
_ClassCastException_instance = nullptr;
|
||||||
_the_null_string = NULL;
|
_the_null_string = nullptr;
|
||||||
_the_min_jint_string = NULL;
|
_the_min_jint_string = nullptr;
|
||||||
|
|
||||||
_jvmti_redefinition_count = 0;
|
_jvmti_redefinition_count = 0;
|
||||||
_jvmti_can_hotswap_or_post_breakpoint = false;
|
_jvmti_can_hotswap_or_post_breakpoint = false;
|
||||||
@ -292,8 +292,8 @@ ciEnv::ciEnv(Arena* arena) : _ciEnv_arena(mtCompiler) {
|
|||||||
_jvmti_can_post_on_exceptions = false;
|
_jvmti_can_post_on_exceptions = false;
|
||||||
_jvmti_can_pop_frame = false;
|
_jvmti_can_pop_frame = false;
|
||||||
|
|
||||||
_dyno_klasses = NULL;
|
_dyno_klasses = nullptr;
|
||||||
_dyno_locs = NULL;
|
_dyno_locs = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
ciEnv::~ciEnv() {
|
ciEnv::~ciEnv() {
|
||||||
@ -302,7 +302,7 @@ ciEnv::~ciEnv() {
|
|||||||
_factory->remove_symbols();
|
_factory->remove_symbols();
|
||||||
// Need safepoint to clear the env on the thread. RedefineClasses might
|
// Need safepoint to clear the env on the thread. RedefineClasses might
|
||||||
// be reading it.
|
// be reading it.
|
||||||
current_thread->set_env(NULL);
|
current_thread->set_env(nullptr);
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -319,7 +319,7 @@ bool ciEnv::cache_jvmti_state() {
|
|||||||
_jvmti_can_pop_frame = JvmtiExport::can_pop_frame();
|
_jvmti_can_pop_frame = JvmtiExport::can_pop_frame();
|
||||||
_jvmti_can_get_owned_monitor_info = JvmtiExport::can_get_owned_monitor_info();
|
_jvmti_can_get_owned_monitor_info = JvmtiExport::can_get_owned_monitor_info();
|
||||||
_jvmti_can_walk_any_space = JvmtiExport::can_walk_any_space();
|
_jvmti_can_walk_any_space = JvmtiExport::can_walk_any_space();
|
||||||
return _task != NULL && _task->method()->is_old();
|
return _task != nullptr && _task->method()->is_old();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ciEnv::jvmti_state_changed() const {
|
bool ciEnv::jvmti_state_changed() const {
|
||||||
@ -368,11 +368,11 @@ void ciEnv::cache_dtrace_flags() {
|
|||||||
// helper for lazy exception creation
|
// helper for lazy exception creation
|
||||||
ciInstance* ciEnv::get_or_create_exception(jobject& handle, Symbol* name) {
|
ciInstance* ciEnv::get_or_create_exception(jobject& handle, Symbol* name) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
if (handle == NULL) {
|
if (handle == nullptr) {
|
||||||
// Cf. universe.cpp, creation of Universe::_null_ptr_exception_instance.
|
// Cf. universe.cpp, creation of Universe::_null_ptr_exception_instance.
|
||||||
InstanceKlass* ik = SystemDictionary::find_instance_klass(THREAD, name, Handle(), Handle());
|
InstanceKlass* ik = SystemDictionary::find_instance_klass(THREAD, name, Handle(), Handle());
|
||||||
jobject objh = NULL;
|
jobject objh = nullptr;
|
||||||
if (ik != NULL) {
|
if (ik != nullptr) {
|
||||||
oop obj = ik->allocate_instance(THREAD);
|
oop obj = ik->allocate_instance(THREAD);
|
||||||
if (!HAS_PENDING_EXCEPTION)
|
if (!HAS_PENDING_EXCEPTION)
|
||||||
objh = JNIHandles::make_global(Handle(THREAD, obj));
|
objh = JNIHandles::make_global(Handle(THREAD, obj));
|
||||||
@ -384,7 +384,7 @@ ciInstance* ciEnv::get_or_create_exception(jobject& handle, Symbol* name) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
oop obj = JNIHandles::resolve(handle);
|
oop obj = JNIHandles::resolve(handle);
|
||||||
return obj == NULL? NULL: get_object(obj)->as_instance();
|
return obj == nullptr? nullptr: get_object(obj)->as_instance();
|
||||||
}
|
}
|
||||||
|
|
||||||
ciInstanceKlass* ciEnv::get_box_klass_for_primitive_type(BasicType type) {
|
ciInstanceKlass* ciEnv::get_box_klass_for_primitive_type(BasicType type) {
|
||||||
@ -400,12 +400,12 @@ ciInstanceKlass* ciEnv::get_box_klass_for_primitive_type(BasicType type) {
|
|||||||
|
|
||||||
default:
|
default:
|
||||||
assert(false, "not a primitive: %s", type2name(type));
|
assert(false, "not a primitive: %s", type2name(type));
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ciInstance* ciEnv::ArrayIndexOutOfBoundsException_instance() {
|
ciInstance* ciEnv::ArrayIndexOutOfBoundsException_instance() {
|
||||||
if (_ArrayIndexOutOfBoundsException_instance == NULL) {
|
if (_ArrayIndexOutOfBoundsException_instance == nullptr) {
|
||||||
_ArrayIndexOutOfBoundsException_instance
|
_ArrayIndexOutOfBoundsException_instance
|
||||||
= get_or_create_exception(_ArrayIndexOutOfBoundsException_handle,
|
= get_or_create_exception(_ArrayIndexOutOfBoundsException_handle,
|
||||||
vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
|
vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
|
||||||
@ -413,7 +413,7 @@ ciInstance* ciEnv::ArrayIndexOutOfBoundsException_instance() {
|
|||||||
return _ArrayIndexOutOfBoundsException_instance;
|
return _ArrayIndexOutOfBoundsException_instance;
|
||||||
}
|
}
|
||||||
ciInstance* ciEnv::ArrayStoreException_instance() {
|
ciInstance* ciEnv::ArrayStoreException_instance() {
|
||||||
if (_ArrayStoreException_instance == NULL) {
|
if (_ArrayStoreException_instance == nullptr) {
|
||||||
_ArrayStoreException_instance
|
_ArrayStoreException_instance
|
||||||
= get_or_create_exception(_ArrayStoreException_handle,
|
= get_or_create_exception(_ArrayStoreException_handle,
|
||||||
vmSymbols::java_lang_ArrayStoreException());
|
vmSymbols::java_lang_ArrayStoreException());
|
||||||
@ -421,7 +421,7 @@ ciInstance* ciEnv::ArrayStoreException_instance() {
|
|||||||
return _ArrayStoreException_instance;
|
return _ArrayStoreException_instance;
|
||||||
}
|
}
|
||||||
ciInstance* ciEnv::ClassCastException_instance() {
|
ciInstance* ciEnv::ClassCastException_instance() {
|
||||||
if (_ClassCastException_instance == NULL) {
|
if (_ClassCastException_instance == nullptr) {
|
||||||
_ClassCastException_instance
|
_ClassCastException_instance
|
||||||
= get_or_create_exception(_ClassCastException_handle,
|
= get_or_create_exception(_ClassCastException_handle,
|
||||||
vmSymbols::java_lang_ClassCastException());
|
vmSymbols::java_lang_ClassCastException());
|
||||||
@ -430,7 +430,7 @@ ciInstance* ciEnv::ClassCastException_instance() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ciInstance* ciEnv::the_null_string() {
|
ciInstance* ciEnv::the_null_string() {
|
||||||
if (_the_null_string == NULL) {
|
if (_the_null_string == nullptr) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
_the_null_string = get_object(Universe::the_null_string())->as_instance();
|
_the_null_string = get_object(Universe::the_null_string())->as_instance();
|
||||||
}
|
}
|
||||||
@ -438,7 +438,7 @@ ciInstance* ciEnv::the_null_string() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ciInstance* ciEnv::the_min_jint_string() {
|
ciInstance* ciEnv::the_min_jint_string() {
|
||||||
if (_the_min_jint_string == NULL) {
|
if (_the_min_jint_string == nullptr) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
_the_min_jint_string = get_object(Universe::the_min_jint_string())->as_instance();
|
_the_min_jint_string = get_object(Universe::the_min_jint_string())->as_instance();
|
||||||
}
|
}
|
||||||
@ -459,7 +459,7 @@ ciMethod* ciEnv::get_method_from_handle(Method* method) {
|
|||||||
// ConstantPool::verify_constant_pool_resolve.
|
// ConstantPool::verify_constant_pool_resolve.
|
||||||
bool ciEnv::check_klass_accessibility(ciKlass* accessing_klass,
|
bool ciEnv::check_klass_accessibility(ciKlass* accessing_klass,
|
||||||
Klass* resolved_klass) {
|
Klass* resolved_klass) {
|
||||||
if (accessing_klass == NULL || !accessing_klass->is_loaded()) {
|
if (accessing_klass == nullptr || !accessing_klass->is_loaded()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (accessing_klass->is_obj_array_klass()) {
|
if (accessing_klass->is_obj_array_klass()) {
|
||||||
@ -503,14 +503,14 @@ ciKlass* ciEnv::get_klass_by_name_impl(ciKlass* accessing_klass,
|
|||||||
// Check for prior unloaded klass. The SystemDictionary's answers
|
// Check for prior unloaded klass. The SystemDictionary's answers
|
||||||
// can vary over time but the compiler needs consistency.
|
// can vary over time but the compiler needs consistency.
|
||||||
ciKlass* unloaded_klass = check_get_unloaded_klass(accessing_klass, name);
|
ciKlass* unloaded_klass = check_get_unloaded_klass(accessing_klass, name);
|
||||||
if (unloaded_klass != NULL) {
|
if (unloaded_klass != nullptr) {
|
||||||
if (require_local) return NULL;
|
if (require_local) return nullptr;
|
||||||
return unloaded_klass;
|
return unloaded_klass;
|
||||||
}
|
}
|
||||||
|
|
||||||
Handle loader;
|
Handle loader;
|
||||||
Handle domain;
|
Handle domain;
|
||||||
if (accessing_klass != NULL) {
|
if (accessing_klass != nullptr) {
|
||||||
loader = Handle(current, accessing_klass->loader());
|
loader = Handle(current, accessing_klass->loader());
|
||||||
domain = Handle(current, accessing_klass->protection_domain());
|
domain = Handle(current, accessing_klass->protection_domain());
|
||||||
}
|
}
|
||||||
@ -546,13 +546,13 @@ ciKlass* ciEnv::get_klass_by_name_impl(ciKlass* accessing_klass,
|
|||||||
cpool,
|
cpool,
|
||||||
get_symbol(ss.as_symbol()),
|
get_symbol(ss.as_symbol()),
|
||||||
require_local);
|
require_local);
|
||||||
if (elem_klass != NULL && elem_klass->is_loaded()) {
|
if (elem_klass != nullptr && elem_klass->is_loaded()) {
|
||||||
// Now make an array for it
|
// Now make an array for it
|
||||||
return ciObjArrayKlass::make_impl(elem_klass);
|
return ciObjArrayKlass::make_impl(elem_klass);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (found_klass == NULL && !cpool.is_null() && cpool->has_preresolution()) {
|
if (found_klass == nullptr && !cpool.is_null() && cpool->has_preresolution()) {
|
||||||
// Look inside the constant pool for pre-resolved class entries.
|
// Look inside the constant pool for pre-resolved class entries.
|
||||||
for (int i = cpool->length() - 1; i >= 1; i--) {
|
for (int i = cpool->length() - 1; i >= 1; i--) {
|
||||||
if (cpool->tag_at(i).is_klass()) {
|
if (cpool->tag_at(i).is_klass()) {
|
||||||
@ -565,12 +565,12 @@ ciKlass* ciEnv::get_klass_by_name_impl(ciKlass* accessing_klass,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (found_klass != NULL) {
|
if (found_klass != nullptr) {
|
||||||
// Found it. Build a CI handle.
|
// Found it. Build a CI handle.
|
||||||
return get_klass(found_klass);
|
return get_klass(found_klass);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (require_local) return NULL;
|
if (require_local) return nullptr;
|
||||||
|
|
||||||
// Not yet loaded into the VM, or not governed by loader constraints.
|
// Not yet loaded into the VM, or not governed by loader constraints.
|
||||||
// Make a CI representative for it.
|
// Make a CI representative for it.
|
||||||
@ -596,8 +596,8 @@ ciKlass* ciEnv::get_klass_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
int index,
|
int index,
|
||||||
bool& is_accessible,
|
bool& is_accessible,
|
||||||
ciInstanceKlass* accessor) {
|
ciInstanceKlass* accessor) {
|
||||||
Klass* klass = NULL;
|
Klass* klass = nullptr;
|
||||||
Symbol* klass_name = NULL;
|
Symbol* klass_name = nullptr;
|
||||||
|
|
||||||
if (cpool->tag_at(index).is_symbol()) {
|
if (cpool->tag_at(index).is_symbol()) {
|
||||||
klass_name = cpool->symbol_at(index);
|
klass_name = cpool->symbol_at(index);
|
||||||
@ -605,12 +605,12 @@ ciKlass* ciEnv::get_klass_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
// Check if it's resolved if it's not a symbol constant pool entry.
|
// Check if it's resolved if it's not a symbol constant pool entry.
|
||||||
klass = ConstantPool::klass_at_if_loaded(cpool, index);
|
klass = ConstantPool::klass_at_if_loaded(cpool, index);
|
||||||
// Try to look it up by name.
|
// Try to look it up by name.
|
||||||
if (klass == NULL) {
|
if (klass == nullptr) {
|
||||||
klass_name = cpool->klass_name_at(index);
|
klass_name = cpool->klass_name_at(index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (klass == NULL) {
|
if (klass == nullptr) {
|
||||||
// Not found in constant pool. Use the name to do the lookup.
|
// Not found in constant pool. Use the name to do the lookup.
|
||||||
ciKlass* k = get_klass_by_name_impl(accessor,
|
ciKlass* k = get_klass_by_name_impl(accessor,
|
||||||
cpool,
|
cpool,
|
||||||
@ -620,7 +620,7 @@ ciKlass* ciEnv::get_klass_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
if (!k->is_loaded()) {
|
if (!k->is_loaded()) {
|
||||||
is_accessible = false;
|
is_accessible = false;
|
||||||
} else if (k->loader() != accessor->loader() &&
|
} else if (k->loader() != accessor->loader() &&
|
||||||
get_klass_by_name_impl(accessor, cpool, k->name(), true) == NULL) {
|
get_klass_by_name_impl(accessor, cpool, k->name(), true) == nullptr) {
|
||||||
// Loaded only remotely. Not linked yet.
|
// Loaded only remotely. Not linked yet.
|
||||||
is_accessible = false;
|
is_accessible = false;
|
||||||
} else {
|
} else {
|
||||||
@ -634,7 +634,7 @@ ciKlass* ciEnv::get_klass_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
// can vary over time but the compiler needs consistency.
|
// can vary over time but the compiler needs consistency.
|
||||||
ciSymbol* name = get_symbol(klass->name());
|
ciSymbol* name = get_symbol(klass->name());
|
||||||
ciKlass* unloaded_klass = check_get_unloaded_klass(accessor, name);
|
ciKlass* unloaded_klass = check_get_unloaded_klass(accessor, name);
|
||||||
if (unloaded_klass != NULL) {
|
if (unloaded_klass != nullptr) {
|
||||||
is_accessible = false;
|
is_accessible = false;
|
||||||
return unloaded_klass;
|
return unloaded_klass;
|
||||||
}
|
}
|
||||||
@ -693,12 +693,12 @@ ciConstant ciEnv::unbox_primitive_value(ciObject* cibox, BasicType expected_bt)
|
|||||||
ciConstant ciEnv::get_resolved_constant(const constantPoolHandle& cpool, int obj_index) {
|
ciConstant ciEnv::get_resolved_constant(const constantPoolHandle& cpool, int obj_index) {
|
||||||
assert(obj_index >= 0, "");
|
assert(obj_index >= 0, "");
|
||||||
oop obj = cpool->resolved_reference_at(obj_index);
|
oop obj = cpool->resolved_reference_at(obj_index);
|
||||||
if (obj == NULL) {
|
if (obj == nullptr) {
|
||||||
// Unresolved constant. It is resolved when the corresponding slot contains a non-null reference.
|
// Unresolved constant. It is resolved when the corresponding slot contains a non-null reference.
|
||||||
// Null constant is represented as a sentinel (non-null) value.
|
// Null constant is represented as a sentinel (non-null) value.
|
||||||
return ciConstant();
|
return ciConstant();
|
||||||
} else if (obj == Universe::the_null_sentinel()) {
|
} else if (obj == Universe::the_null_sentinel()) {
|
||||||
return ciConstant(T_OBJECT, get_object(NULL));
|
return ciConstant(T_OBJECT, get_object(nullptr));
|
||||||
} else {
|
} else {
|
||||||
ciObject* ciobj = get_object(obj);
|
ciObject* ciobj = get_object(obj);
|
||||||
if (ciobj->is_array()) {
|
if (ciobj->is_array()) {
|
||||||
@ -751,7 +751,7 @@ ciConstant ciEnv::get_constant_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
ciInstance* constant = get_object(string)->as_instance();
|
ciInstance* constant = get_object(string)->as_instance();
|
||||||
return ciConstant(T_OBJECT, constant);
|
return ciConstant(T_OBJECT, constant);
|
||||||
} else if (tag.is_unresolved_klass_in_error()) {
|
} else if (tag.is_unresolved_klass_in_error()) {
|
||||||
return ciConstant(T_OBJECT, get_unloaded_klass_mirror(NULL));
|
return ciConstant(T_OBJECT, get_unloaded_klass_mirror(nullptr));
|
||||||
} else if (tag.is_klass() || tag.is_unresolved_klass()) {
|
} else if (tag.is_klass() || tag.is_unresolved_klass()) {
|
||||||
bool will_link;
|
bool will_link;
|
||||||
ciKlass* klass = get_klass_by_index_impl(cpool, index, will_link, accessor);
|
ciKlass* klass = get_klass_by_index_impl(cpool, index, will_link, accessor);
|
||||||
@ -805,12 +805,12 @@ ciConstant ciEnv::get_constant_by_index(const constantPoolHandle& cpool,
|
|||||||
ciField* ciEnv::get_field_by_index_impl(ciInstanceKlass* accessor,
|
ciField* ciEnv::get_field_by_index_impl(ciInstanceKlass* accessor,
|
||||||
int index) {
|
int index) {
|
||||||
ciConstantPoolCache* cache = accessor->field_cache();
|
ciConstantPoolCache* cache = accessor->field_cache();
|
||||||
if (cache == NULL) {
|
if (cache == nullptr) {
|
||||||
ciField* field = new (arena()) ciField(accessor, index);
|
ciField* field = new (arena()) ciField(accessor, index);
|
||||||
return field;
|
return field;
|
||||||
} else {
|
} else {
|
||||||
ciField* field = (ciField*)cache->get(index);
|
ciField* field = (ciField*)cache->get(index);
|
||||||
if (field == NULL) {
|
if (field == nullptr) {
|
||||||
field = new (arena()) ciField(accessor, index);
|
field = new (arena()) ciField(accessor, index);
|
||||||
cache->insert(index, field);
|
cache->insert(index, field);
|
||||||
}
|
}
|
||||||
@ -859,7 +859,7 @@ Method* ciEnv::lookup_method(ciInstanceKlass* accessor,
|
|||||||
return LinkResolver::linktime_resolve_virtual_method_or_null(link_info);
|
return LinkResolver::linktime_resolve_virtual_method_or_null(link_info);
|
||||||
default:
|
default:
|
||||||
fatal("Unhandled bytecode: %s", Bytecodes::name(bc));
|
fatal("Unhandled bytecode: %s", Bytecodes::name(bc));
|
||||||
return NULL; // silence compiler warnings
|
return nullptr; // silence compiler warnings
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -870,7 +870,7 @@ ciMethod* ciEnv::get_method_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
int index, Bytecodes::Code bc,
|
int index, Bytecodes::Code bc,
|
||||||
ciInstanceKlass* accessor) {
|
ciInstanceKlass* accessor) {
|
||||||
assert(cpool.not_null(), "need constant pool");
|
assert(cpool.not_null(), "need constant pool");
|
||||||
assert(accessor != NULL, "need origin of access");
|
assert(accessor != nullptr, "need origin of access");
|
||||||
if (bc == Bytecodes::_invokedynamic) {
|
if (bc == Bytecodes::_invokedynamic) {
|
||||||
ConstantPoolCacheEntry* cpce = cpool->invokedynamic_cp_cache_entry_at(index);
|
ConstantPoolCacheEntry* cpce = cpool->invokedynamic_cp_cache_entry_at(index);
|
||||||
bool is_resolved = !cpce->is_f1_null();
|
bool is_resolved = !cpce->is_f1_null();
|
||||||
@ -916,7 +916,7 @@ ciMethod* ciEnv::get_method_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
case Bytecodes::_invokestatic:
|
case Bytecodes::_invokestatic:
|
||||||
{
|
{
|
||||||
Method* m = ConstantPool::method_at_if_loaded(cpool, index);
|
Method* m = ConstantPool::method_at_if_loaded(cpool, index);
|
||||||
if (m != NULL) {
|
if (m != nullptr) {
|
||||||
return get_method(m);
|
return get_method(m);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -930,16 +930,16 @@ ciMethod* ciEnv::get_method_by_index_impl(const constantPoolHandle& cpool,
|
|||||||
constantTag tag = cpool->tag_ref_at(index);
|
constantTag tag = cpool->tag_ref_at(index);
|
||||||
assert(accessor->get_instanceKlass() == cpool->pool_holder(), "not the pool holder?");
|
assert(accessor->get_instanceKlass() == cpool->pool_holder(), "not the pool holder?");
|
||||||
Method* m = lookup_method(accessor, holder, name_sym, sig_sym, bc, tag);
|
Method* m = lookup_method(accessor, holder, name_sym, sig_sym, bc, tag);
|
||||||
if (m != NULL &&
|
if (m != nullptr &&
|
||||||
(bc == Bytecodes::_invokestatic
|
(bc == Bytecodes::_invokestatic
|
||||||
? m->method_holder()->is_not_initialized()
|
? m->method_holder()->is_not_initialized()
|
||||||
: !m->method_holder()->is_loaded())) {
|
: !m->method_holder()->is_loaded())) {
|
||||||
m = NULL;
|
m = nullptr;
|
||||||
}
|
}
|
||||||
if (m != NULL && ReplayCompiles && !ciReplay::is_loaded(m)) {
|
if (m != nullptr && ReplayCompiles && !ciReplay::is_loaded(m)) {
|
||||||
m = NULL;
|
m = nullptr;
|
||||||
}
|
}
|
||||||
if (m != NULL) {
|
if (m != nullptr) {
|
||||||
// We found the method.
|
// We found the method.
|
||||||
return get_method(m);
|
return get_method(m);
|
||||||
}
|
}
|
||||||
@ -966,7 +966,7 @@ ciInstanceKlass* ciEnv::get_instance_klass_for_declared_method_holder(ciKlass* m
|
|||||||
// require checks to make sure the expected type was found. Given that this
|
// require checks to make sure the expected type was found. Given that this
|
||||||
// only occurs for clone() the more extensive fix seems like overkill so
|
// only occurs for clone() the more extensive fix seems like overkill so
|
||||||
// instead we simply smear the array type into Object.
|
// instead we simply smear the array type into Object.
|
||||||
guarantee(method_holder != NULL, "no method holder");
|
guarantee(method_holder != nullptr, "no method holder");
|
||||||
if (method_holder->is_instance_klass()) {
|
if (method_holder->is_instance_klass()) {
|
||||||
return method_holder->as_instance_klass();
|
return method_holder->as_instance_klass();
|
||||||
} else if (method_holder->is_array_klass()) {
|
} else if (method_holder->is_array_klass()) {
|
||||||
@ -974,7 +974,7 @@ ciInstanceKlass* ciEnv::get_instance_klass_for_declared_method_holder(ciKlass* m
|
|||||||
} else {
|
} else {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -991,7 +991,7 @@ ciMethod* ciEnv::get_method_by_index(const constantPoolHandle& cpool,
|
|||||||
// ciEnv::name_buffer
|
// ciEnv::name_buffer
|
||||||
char *ciEnv::name_buffer(int req_len) {
|
char *ciEnv::name_buffer(int req_len) {
|
||||||
if (_name_buffer_len < req_len) {
|
if (_name_buffer_len < req_len) {
|
||||||
if (_name_buffer == NULL) {
|
if (_name_buffer == nullptr) {
|
||||||
_name_buffer = (char*)arena()->Amalloc(sizeof(char)*req_len);
|
_name_buffer = (char*)arena()->Amalloc(sizeof(char)*req_len);
|
||||||
_name_buffer_len = req_len;
|
_name_buffer_len = req_len;
|
||||||
} else {
|
} else {
|
||||||
@ -1048,12 +1048,12 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
int immediate_oops_patched,
|
int immediate_oops_patched,
|
||||||
RTMState rtm_state) {
|
RTMState rtm_state) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
nmethod* nm = NULL;
|
nmethod* nm = nullptr;
|
||||||
{
|
{
|
||||||
methodHandle method(THREAD, target->get_Method());
|
methodHandle method(THREAD, target->get_Method());
|
||||||
|
|
||||||
// We require method counters to store some method state (max compilation levels) required by the compilation policy.
|
// We require method counters to store some method state (max compilation levels) required by the compilation policy.
|
||||||
if (method->get_method_counters(THREAD) == NULL) {
|
if (method->get_method_counters(THREAD) == nullptr) {
|
||||||
record_failure("can't create method counters");
|
record_failure("can't create method counters");
|
||||||
// All buffers in the CodeBuffer are allocated in the CodeCache.
|
// All buffers in the CodeBuffer are allocated in the CodeCache.
|
||||||
// If the code buffer is created on each compile attempt
|
// If the code buffer is created on each compile attempt
|
||||||
@ -1092,7 +1092,7 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!failing()) {
|
if (!failing()) {
|
||||||
if (log() != NULL) {
|
if (log() != nullptr) {
|
||||||
// Log the dependencies which this compilation declares.
|
// Log the dependencies which this compilation declares.
|
||||||
dependencies()->log_all_dependencies();
|
dependencies()->log_all_dependencies();
|
||||||
}
|
}
|
||||||
@ -1105,7 +1105,7 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
}
|
}
|
||||||
#if INCLUDE_RTM_OPT
|
#if INCLUDE_RTM_OPT
|
||||||
if (!failing() && (rtm_state != NoRTM) &&
|
if (!failing() && (rtm_state != NoRTM) &&
|
||||||
(method()->method_data() != NULL) &&
|
(method()->method_data() != nullptr) &&
|
||||||
(method()->method_data()->rtm_state() != rtm_state)) {
|
(method()->method_data()->rtm_state() != rtm_state)) {
|
||||||
// Preemptive decompile if rtm state was changed.
|
// Preemptive decompile if rtm state was changed.
|
||||||
record_failure("RTM state change invalidated rtm code");
|
record_failure("RTM state change invalidated rtm code");
|
||||||
@ -1119,7 +1119,7 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
if (failing()) {
|
if (failing()) {
|
||||||
// While not a true deoptimization, it is a preemptive decompile.
|
// While not a true deoptimization, it is a preemptive decompile.
|
||||||
MethodData* mdo = method()->method_data();
|
MethodData* mdo = method()->method_data();
|
||||||
if (mdo != NULL && _inc_decompile_count_on_failure) {
|
if (mdo != nullptr && _inc_decompile_count_on_failure) {
|
||||||
mdo->inc_decompile_count();
|
mdo->inc_decompile_count();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1146,7 +1146,7 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
// Free codeBlobs
|
// Free codeBlobs
|
||||||
code_buffer->free_blob();
|
code_buffer->free_blob();
|
||||||
|
|
||||||
if (nm != NULL) {
|
if (nm != nullptr) {
|
||||||
nm->set_has_unsafe_access(has_unsafe_access);
|
nm->set_has_unsafe_access(has_unsafe_access);
|
||||||
nm->set_has_wide_vectors(has_wide_vectors);
|
nm->set_has_wide_vectors(has_wide_vectors);
|
||||||
nm->set_has_monitors(has_monitors);
|
nm->set_has_monitors(has_monitors);
|
||||||
@ -1159,12 +1159,12 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
if (TieredCompilation) {
|
if (TieredCompilation) {
|
||||||
// If there is an old version we're done with it
|
// If there is an old version we're done with it
|
||||||
CompiledMethod* old = method->code();
|
CompiledMethod* old = method->code();
|
||||||
if (TraceMethodReplacement && old != NULL) {
|
if (TraceMethodReplacement && old != nullptr) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
char *method_name = method->name_and_sig_as_C_string();
|
char *method_name = method->name_and_sig_as_C_string();
|
||||||
tty->print_cr("Replacing method %s", method_name);
|
tty->print_cr("Replacing method %s", method_name);
|
||||||
}
|
}
|
||||||
if (old != NULL) {
|
if (old != nullptr) {
|
||||||
old->make_not_used();
|
old->make_not_used();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1198,7 +1198,7 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
}
|
}
|
||||||
|
|
||||||
NoSafepointVerifier nsv;
|
NoSafepointVerifier nsv;
|
||||||
if (nm != NULL) {
|
if (nm != nullptr) {
|
||||||
// Compilation succeeded, post what we know about it
|
// Compilation succeeded, post what we know about it
|
||||||
nm->post_compiled_method(task());
|
nm->post_compiled_method(task());
|
||||||
task()->set_num_inlined_bytecodes(num_inlined_bytecodes());
|
task()->set_num_inlined_bytecodes(num_inlined_bytecodes());
|
||||||
@ -1214,20 +1214,20 @@ void ciEnv::register_method(ciMethod* target,
|
|||||||
// ciEnv::find_system_klass
|
// ciEnv::find_system_klass
|
||||||
ciKlass* ciEnv::find_system_klass(ciSymbol* klass_name) {
|
ciKlass* ciEnv::find_system_klass(ciSymbol* klass_name) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
return get_klass_by_name_impl(NULL, constantPoolHandle(), klass_name, false);
|
return get_klass_by_name_impl(nullptr, constantPoolHandle(), klass_name, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciEnv::comp_level
|
// ciEnv::comp_level
|
||||||
int ciEnv::comp_level() {
|
int ciEnv::comp_level() {
|
||||||
if (task() == NULL) return CompilationPolicy::highest_compile_level();
|
if (task() == nullptr) return CompilationPolicy::highest_compile_level();
|
||||||
return task()->comp_level();
|
return task()->comp_level();
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciEnv::compile_id
|
// ciEnv::compile_id
|
||||||
int ciEnv::compile_id() {
|
int ciEnv::compile_id() {
|
||||||
if (task() == NULL) return 0;
|
if (task() == nullptr) return 0;
|
||||||
return task()->compile_id();
|
return task()->compile_id();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1246,7 +1246,7 @@ int ciEnv::num_inlined_bytecodes() const {
|
|||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciEnv::record_failure()
|
// ciEnv::record_failure()
|
||||||
void ciEnv::record_failure(const char* reason) {
|
void ciEnv::record_failure(const char* reason) {
|
||||||
if (_failure_reason == NULL) {
|
if (_failure_reason == nullptr) {
|
||||||
// Record the first failure reason.
|
// Record the first failure reason.
|
||||||
_failure_reason = reason;
|
_failure_reason = reason;
|
||||||
}
|
}
|
||||||
@ -1267,7 +1267,7 @@ void ciEnv::record_method_not_compilable(const char* reason, bool all_tiers) {
|
|||||||
|
|
||||||
// Only note transitions to a worse state
|
// Only note transitions to a worse state
|
||||||
if (new_compilable > _compilable) {
|
if (new_compilable > _compilable) {
|
||||||
if (log() != NULL) {
|
if (log() != nullptr) {
|
||||||
if (all_tiers) {
|
if (all_tiers) {
|
||||||
log()->elem("method_not_compilable");
|
log()->elem("method_not_compilable");
|
||||||
} else {
|
} else {
|
||||||
@ -1278,7 +1278,7 @@ void ciEnv::record_method_not_compilable(const char* reason, bool all_tiers) {
|
|||||||
_compilable = new_compilable;
|
_compilable = new_compilable;
|
||||||
|
|
||||||
// Reset failure reason; this one is more important.
|
// Reset failure reason; this one is more important.
|
||||||
_failure_reason = NULL;
|
_failure_reason = nullptr;
|
||||||
record_failure(reason);
|
record_failure(reason);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1354,7 +1354,7 @@ bool ciEnv::print_dyno_loc(outputStream* out, const InstanceKlass* ik) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Look up the location descriptor for the given class and return it as a string.
|
// Look up the location descriptor for the given class and return it as a string.
|
||||||
// Returns NULL if no location is found.
|
// Returns null if no location is found.
|
||||||
const char *ciEnv::dyno_name(const InstanceKlass* ik) const {
|
const char *ciEnv::dyno_name(const InstanceKlass* ik) const {
|
||||||
if (ik->is_hidden()) {
|
if (ik->is_hidden()) {
|
||||||
stringStream ss;
|
stringStream ss;
|
||||||
@ -1364,7 +1364,7 @@ const char *ciEnv::dyno_name(const InstanceKlass* ik) const {
|
|||||||
return call_site;
|
return call_site;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Look up the location descriptor for the given class and return it as a string.
|
// Look up the location descriptor for the given class and return it as a string.
|
||||||
@ -1380,7 +1380,7 @@ const char *ciEnv::replay_name(ciKlass* k) const {
|
|||||||
// Returns the class name as a fallback if no location is found.
|
// Returns the class name as a fallback if no location is found.
|
||||||
const char *ciEnv::replay_name(const InstanceKlass* ik) const {
|
const char *ciEnv::replay_name(const InstanceKlass* ik) const {
|
||||||
const char* name = dyno_name(ik);
|
const char* name = dyno_name(ik);
|
||||||
if (name != NULL) {
|
if (name != nullptr) {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
return ik->name()->as_quoted_ascii();
|
return ik->name()->as_quoted_ascii();
|
||||||
@ -1398,7 +1398,7 @@ void ciEnv::record_member(Thread* thread, oop member) {
|
|||||||
}
|
}
|
||||||
// Check MemberName.method.vmtarget field
|
// Check MemberName.method.vmtarget field
|
||||||
Method* vmtarget = java_lang_invoke_MemberName::vmtarget(member);
|
Method* vmtarget = java_lang_invoke_MemberName::vmtarget(member);
|
||||||
if (vmtarget != NULL) {
|
if (vmtarget != nullptr) {
|
||||||
RecordLocation fp2(this, "<vmtarget>");
|
RecordLocation fp2(this, "<vmtarget>");
|
||||||
InstanceKlass* ik = vmtarget->method_holder();
|
InstanceKlass* ik = vmtarget->method_holder();
|
||||||
record_best_dyno_loc(ik);
|
record_best_dyno_loc(ik);
|
||||||
@ -1423,7 +1423,7 @@ void ciEnv::record_lambdaform(Thread* thread, oop form) {
|
|||||||
|
|
||||||
// Check LambdaForm.names array
|
// Check LambdaForm.names array
|
||||||
objArrayOop names = (objArrayOop)obj_field(form, "names");
|
objArrayOop names = (objArrayOop)obj_field(form, "names");
|
||||||
if (names != NULL) {
|
if (names != nullptr) {
|
||||||
RecordLocation lp0(this, "names");
|
RecordLocation lp0(this, "names");
|
||||||
int len = names->length();
|
int len = names->length();
|
||||||
for (int i = 0; i < len; ++i) {
|
for (int i = 0; i < len; ++i) {
|
||||||
@ -1432,22 +1432,22 @@ void ciEnv::record_lambdaform(Thread* thread, oop form) {
|
|||||||
// Check LambdaForm.names[i].function field
|
// Check LambdaForm.names[i].function field
|
||||||
RecordLocation lp2(this, "function");
|
RecordLocation lp2(this, "function");
|
||||||
oop function = obj_field(name, "function");
|
oop function = obj_field(name, "function");
|
||||||
if (function != NULL) {
|
if (function != nullptr) {
|
||||||
// Check LambdaForm.names[i].function.member field
|
// Check LambdaForm.names[i].function.member field
|
||||||
oop member = obj_field(function, "member");
|
oop member = obj_field(function, "member");
|
||||||
if (member != NULL) {
|
if (member != nullptr) {
|
||||||
RecordLocation lp3(this, "member");
|
RecordLocation lp3(this, "member");
|
||||||
record_member(thread, member);
|
record_member(thread, member);
|
||||||
}
|
}
|
||||||
// Check LambdaForm.names[i].function.resolvedHandle field
|
// Check LambdaForm.names[i].function.resolvedHandle field
|
||||||
oop mh = obj_field(function, "resolvedHandle");
|
oop mh = obj_field(function, "resolvedHandle");
|
||||||
if (mh != NULL) {
|
if (mh != nullptr) {
|
||||||
RecordLocation lp3(this, "resolvedHandle");
|
RecordLocation lp3(this, "resolvedHandle");
|
||||||
record_mh(thread, mh);
|
record_mh(thread, mh);
|
||||||
}
|
}
|
||||||
// Check LambdaForm.names[i].function.invoker field
|
// Check LambdaForm.names[i].function.invoker field
|
||||||
oop invoker = obj_field(function, "invoker");
|
oop invoker = obj_field(function, "invoker");
|
||||||
if (invoker != NULL) {
|
if (invoker != nullptr) {
|
||||||
RecordLocation lp3(this, "invoker");
|
RecordLocation lp3(this, "invoker");
|
||||||
record_mh(thread, invoker);
|
record_mh(thread, invoker);
|
||||||
}
|
}
|
||||||
@ -1477,7 +1477,7 @@ void ciEnv::record_mh(Thread* thread, oop mh) {
|
|||||||
for (int index = 0; index <= max_arg; ++index) {
|
for (int index = 0; index <= max_arg; ++index) {
|
||||||
jio_snprintf(arg_name, sizeof (arg_name), "argL%d", index);
|
jio_snprintf(arg_name, sizeof (arg_name), "argL%d", index);
|
||||||
oop arg = obj_field(mh, arg_name);
|
oop arg = obj_field(mh, arg_name);
|
||||||
if (arg != NULL) {
|
if (arg != nullptr) {
|
||||||
RecordLocation fp(this, "%s", arg_name);
|
RecordLocation fp(this, "%s", arg_name);
|
||||||
if (arg->klass()->is_instance_klass()) {
|
if (arg->klass()->is_instance_klass()) {
|
||||||
InstanceKlass* ik2 = InstanceKlass::cast(arg->klass());
|
InstanceKlass* ik2 = InstanceKlass::cast(arg->klass());
|
||||||
@ -1496,7 +1496,7 @@ void ciEnv::record_mh(Thread* thread, oop mh) {
|
|||||||
// The object is typically the "appendix" object, or Bootstrap Method (BSM) object.
|
// The object is typically the "appendix" object, or Bootstrap Method (BSM) object.
|
||||||
void ciEnv::record_call_site_obj(Thread* thread, oop obj)
|
void ciEnv::record_call_site_obj(Thread* thread, oop obj)
|
||||||
{
|
{
|
||||||
if (obj != NULL) {
|
if (obj != nullptr) {
|
||||||
if (java_lang_invoke_MethodHandle::is_instance(obj)) {
|
if (java_lang_invoke_MethodHandle::is_instance(obj)) {
|
||||||
record_mh(thread, obj);
|
record_mh(thread, obj);
|
||||||
} else if (java_lang_invoke_ConstantCallSite::is_instance(obj)) {
|
} else if (java_lang_invoke_ConstantCallSite::is_instance(obj)) {
|
||||||
@ -1571,8 +1571,8 @@ void ciEnv::process_invokehandle(const constantPoolHandle &cp, int index, JavaTh
|
|||||||
// Search the class hierarchy for dynamic classes reachable through dynamic call sites or
|
// Search the class hierarchy for dynamic classes reachable through dynamic call sites or
|
||||||
// constant pool entries and record for future lookup.
|
// constant pool entries and record for future lookup.
|
||||||
void ciEnv::find_dynamic_call_sites() {
|
void ciEnv::find_dynamic_call_sites() {
|
||||||
_dyno_klasses = new (arena()) GrowableArray<const InstanceKlass*>(arena(), 100, 0, NULL);
|
_dyno_klasses = new (arena()) GrowableArray<const InstanceKlass*>(arena(), 100, 0, nullptr);
|
||||||
_dyno_locs = new (arena()) GrowableArray<const char *>(arena(), 100, 0, NULL);
|
_dyno_locs = new (arena()) GrowableArray<const char *>(arena(), 100, 0, nullptr);
|
||||||
|
|
||||||
// Iterate over the class hierarchy
|
// Iterate over the class hierarchy
|
||||||
for (ClassHierarchyIterator iter(vmClasses::Object_klass()); !iter.done(); iter.next()) {
|
for (ClassHierarchyIterator iter(vmClasses::Object_klass()); !iter.done(); iter.next()) {
|
||||||
@ -1627,7 +1627,7 @@ void ciEnv::find_dynamic_call_sites() {
|
|||||||
if (pool->tag_at(i).is_method_handle()) {
|
if (pool->tag_at(i).is_method_handle()) {
|
||||||
bool found_it;
|
bool found_it;
|
||||||
oop mh = pool->find_cached_constant_at(i, found_it, thread);
|
oop mh = pool->find_cached_constant_at(i, found_it, thread);
|
||||||
if (mh != NULL) {
|
if (mh != nullptr) {
|
||||||
RecordLocation fp(this, "%d", i);
|
RecordLocation fp(this, "%d", i);
|
||||||
record_mh(thread, mh);
|
record_mh(thread, mh);
|
||||||
}
|
}
|
||||||
@ -1641,7 +1641,7 @@ void ciEnv::dump_compile_data(outputStream* out) {
|
|||||||
CompileTask* task = this->task();
|
CompileTask* task = this->task();
|
||||||
if (task) {
|
if (task) {
|
||||||
#ifdef COMPILER2
|
#ifdef COMPILER2
|
||||||
if (ReplayReduce && compiler_data() != NULL) {
|
if (ReplayReduce && compiler_data() != nullptr) {
|
||||||
// Dump C2 "reduced" inlining data.
|
// Dump C2 "reduced" inlining data.
|
||||||
((Compile*)compiler_data())->dump_inline_data_reduced(out);
|
((Compile*)compiler_data())->dump_inline_data_reduced(out);
|
||||||
}
|
}
|
||||||
@ -1652,7 +1652,7 @@ void ciEnv::dump_compile_data(outputStream* out) {
|
|||||||
out->print("compile ");
|
out->print("compile ");
|
||||||
get_method(method)->dump_name_as_ascii(out);
|
get_method(method)->dump_name_as_ascii(out);
|
||||||
out->print(" %d %d", entry_bci, comp_level);
|
out->print(" %d %d", entry_bci, comp_level);
|
||||||
if (compiler_data() != NULL) {
|
if (compiler_data() != nullptr) {
|
||||||
if (is_c2_compile(comp_level)) {
|
if (is_c2_compile(comp_level)) {
|
||||||
#ifdef COMPILER2
|
#ifdef COMPILER2
|
||||||
// Dump C2 inlining data.
|
// Dump C2 inlining data.
|
||||||
@ -1722,7 +1722,7 @@ void ciEnv::dump_replay_data(int compile_id) {
|
|||||||
int fd = os::open(buffer, O_RDWR | O_CREAT | O_TRUNC, 0666);
|
int fd = os::open(buffer, O_RDWR | O_CREAT | O_TRUNC, 0666);
|
||||||
if (fd != -1) {
|
if (fd != -1) {
|
||||||
FILE* replay_data_file = os::fdopen(fd, "w");
|
FILE* replay_data_file = os::fdopen(fd, "w");
|
||||||
if (replay_data_file != NULL) {
|
if (replay_data_file != nullptr) {
|
||||||
fileStream replay_data_stream(replay_data_file, /*need_close=*/true);
|
fileStream replay_data_stream(replay_data_file, /*need_close=*/true);
|
||||||
dump_replay_data(&replay_data_stream);
|
dump_replay_data(&replay_data_stream);
|
||||||
tty->print_cr("# Compiler replay data is saved as: %s", buffer);
|
tty->print_cr("# Compiler replay data is saved as: %s", buffer);
|
||||||
@ -1740,7 +1740,7 @@ void ciEnv::dump_inline_data(int compile_id) {
|
|||||||
int fd = os::open(buffer, O_RDWR | O_CREAT | O_TRUNC, 0666);
|
int fd = os::open(buffer, O_RDWR | O_CREAT | O_TRUNC, 0666);
|
||||||
if (fd != -1) {
|
if (fd != -1) {
|
||||||
FILE* inline_data_file = os::fdopen(fd, "w");
|
FILE* inline_data_file = os::fdopen(fd, "w");
|
||||||
if (inline_data_file != NULL) {
|
if (inline_data_file != nullptr) {
|
||||||
fileStream replay_data_stream(inline_data_file, /*need_close=*/true);
|
fileStream replay_data_stream(inline_data_file, /*need_close=*/true);
|
||||||
GUARDED_VM_ENTRY(
|
GUARDED_VM_ENTRY(
|
||||||
MutexLocker ml(Compile_lock);
|
MutexLocker ml(Compile_lock);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -107,7 +107,7 @@ private:
|
|||||||
ciInstance* _the_min_jint_string; // The Java string "-2147483648"
|
ciInstance* _the_min_jint_string; // The Java string "-2147483648"
|
||||||
|
|
||||||
// Look up a klass by name from a particular class loader (the accessor's).
|
// Look up a klass by name from a particular class loader (the accessor's).
|
||||||
// If require_local, result must be defined in that class loader, or NULL.
|
// If require_local, result must be defined in that class loader, or null.
|
||||||
// If !require_local, a result from remote class loader may be reported,
|
// If !require_local, a result from remote class loader may be reported,
|
||||||
// if sufficient class loader constraints exist such that initiating
|
// if sufficient class loader constraints exist such that initiating
|
||||||
// a class loading request from the given loader is bound to return
|
// a class loading request from the given loader is bound to return
|
||||||
@ -170,7 +170,7 @@ private:
|
|||||||
// Get a ciObject from the object factory. Ensures uniqueness
|
// Get a ciObject from the object factory. Ensures uniqueness
|
||||||
// of ciObjects.
|
// of ciObjects.
|
||||||
ciObject* get_object(oop o) {
|
ciObject* get_object(oop o) {
|
||||||
if (o == NULL) {
|
if (o == nullptr) {
|
||||||
return _null_object_instance;
|
return _null_object_instance;
|
||||||
} else {
|
} else {
|
||||||
return _factory->get(o);
|
return _factory->get(o);
|
||||||
@ -178,17 +178,17 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
ciSymbol* get_symbol(Symbol* o) {
|
ciSymbol* get_symbol(Symbol* o) {
|
||||||
if (o == NULL) {
|
if (o == nullptr) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
} else {
|
} else {
|
||||||
return _factory->get_symbol(o);
|
return _factory->get_symbol(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ciMetadata* get_metadata(Metadata* o) {
|
ciMetadata* get_metadata(Metadata* o) {
|
||||||
if (o == NULL) {
|
if (o == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
} else {
|
} else {
|
||||||
return _factory->get_metadata(o);
|
return _factory->get_metadata(o);
|
||||||
}
|
}
|
||||||
@ -199,31 +199,31 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
ciInstance* get_instance(oop o) {
|
ciInstance* get_instance(oop o) {
|
||||||
if (o == NULL) return NULL;
|
if (o == nullptr) return nullptr;
|
||||||
return get_object(o)->as_instance();
|
return get_object(o)->as_instance();
|
||||||
}
|
}
|
||||||
ciObjArrayKlass* get_obj_array_klass(Klass* o) {
|
ciObjArrayKlass* get_obj_array_klass(Klass* o) {
|
||||||
if (o == NULL) return NULL;
|
if (o == nullptr) return nullptr;
|
||||||
return get_metadata(o)->as_obj_array_klass();
|
return get_metadata(o)->as_obj_array_klass();
|
||||||
}
|
}
|
||||||
ciTypeArrayKlass* get_type_array_klass(Klass* o) {
|
ciTypeArrayKlass* get_type_array_klass(Klass* o) {
|
||||||
if (o == NULL) return NULL;
|
if (o == nullptr) return nullptr;
|
||||||
return get_metadata(o)->as_type_array_klass();
|
return get_metadata(o)->as_type_array_klass();
|
||||||
}
|
}
|
||||||
ciKlass* get_klass(Klass* o) {
|
ciKlass* get_klass(Klass* o) {
|
||||||
if (o == NULL) return NULL;
|
if (o == nullptr) return nullptr;
|
||||||
return get_metadata(o)->as_klass();
|
return get_metadata(o)->as_klass();
|
||||||
}
|
}
|
||||||
ciInstanceKlass* get_instance_klass(Klass* o) {
|
ciInstanceKlass* get_instance_klass(Klass* o) {
|
||||||
if (o == NULL) return NULL;
|
if (o == nullptr) return nullptr;
|
||||||
return get_metadata(o)->as_instance_klass();
|
return get_metadata(o)->as_instance_klass();
|
||||||
}
|
}
|
||||||
ciMethod* get_method(Method* o) {
|
ciMethod* get_method(Method* o) {
|
||||||
if (o == NULL) return NULL;
|
if (o == nullptr) return nullptr;
|
||||||
return get_metadata(o)->as_method();
|
return get_metadata(o)->as_method();
|
||||||
}
|
}
|
||||||
ciMethodData* get_method_data(MethodData* o) {
|
ciMethodData* get_method_data(MethodData* o) {
|
||||||
if (o == NULL) return NULL;
|
if (o == nullptr) return nullptr;
|
||||||
return get_metadata(o)->as_method_data();
|
return get_metadata(o)->as_method_data();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -269,7 +269,7 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
// See if we already have an unloaded klass for the given name
|
// See if we already have an unloaded klass for the given name
|
||||||
// or return NULL if not.
|
// or return null if not.
|
||||||
ciKlass *check_get_unloaded_klass(ciKlass* accessing_klass, ciSymbol* name) {
|
ciKlass *check_get_unloaded_klass(ciKlass* accessing_klass, ciSymbol* name) {
|
||||||
return _factory->get_unloaded_klass(accessing_klass, name, false);
|
return _factory->get_unloaded_klass(accessing_klass, name, false);
|
||||||
}
|
}
|
||||||
@ -319,7 +319,7 @@ public:
|
|||||||
|
|
||||||
// This is true if the compilation is not going to produce code.
|
// This is true if the compilation is not going to produce code.
|
||||||
// (It is reasonable to retry failed compilations.)
|
// (It is reasonable to retry failed compilations.)
|
||||||
bool failing() { return _failure_reason != NULL; }
|
bool failing() { return _failure_reason != nullptr; }
|
||||||
|
|
||||||
// Reason this compilation is failing, such as "too many basic blocks".
|
// Reason this compilation is failing, such as "too many basic blocks".
|
||||||
const char* failure_reason() { return _failure_reason; }
|
const char* failure_reason() { return _failure_reason; }
|
||||||
@ -334,10 +334,10 @@ public:
|
|||||||
case ciEnv::MethodCompilable_never:
|
case ciEnv::MethodCompilable_never:
|
||||||
return "not retryable";
|
return "not retryable";
|
||||||
case ciEnv::MethodCompilable:
|
case ciEnv::MethodCompilable:
|
||||||
return NULL;
|
return nullptr;
|
||||||
default:
|
default:
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -394,11 +394,11 @@ public:
|
|||||||
#undef VM_CLASS_FUNC
|
#undef VM_CLASS_FUNC
|
||||||
|
|
||||||
ciInstance* NullPointerException_instance() {
|
ciInstance* NullPointerException_instance() {
|
||||||
assert(_NullPointerException_instance != NULL, "initialization problem");
|
assert(_NullPointerException_instance != nullptr, "initialization problem");
|
||||||
return _NullPointerException_instance;
|
return _NullPointerException_instance;
|
||||||
}
|
}
|
||||||
ciInstance* ArithmeticException_instance() {
|
ciInstance* ArithmeticException_instance() {
|
||||||
assert(_ArithmeticException_instance != NULL, "initialization problem");
|
assert(_ArithmeticException_instance != nullptr, "initialization problem");
|
||||||
return _ArithmeticException_instance;
|
return _ArithmeticException_instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -38,7 +38,7 @@
|
|||||||
ciInstanceKlass* ciExceptionHandler::catch_klass() {
|
ciInstanceKlass* ciExceptionHandler::catch_klass() {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
assert(!is_catch_all(), "bad index");
|
assert(!is_catch_all(), "bad index");
|
||||||
if (_catch_klass == NULL) {
|
if (_catch_klass == nullptr) {
|
||||||
bool will_link;
|
bool will_link;
|
||||||
assert(_loading_klass->get_instanceKlass()->is_linked(), "must be linked before accessing constant pool");
|
assert(_loading_klass->get_instanceKlass()->is_linked(), "must be linked before accessing constant pool");
|
||||||
constantPoolHandle cpool(THREAD, _loading_klass->get_instanceKlass()->constants());
|
constantPoolHandle cpool(THREAD, _loading_klass->get_instanceKlass()->constants());
|
||||||
@ -62,7 +62,7 @@ void ciExceptionHandler::print() {
|
|||||||
tty->print("<ciExceptionHandler start=%d limit=%d"
|
tty->print("<ciExceptionHandler start=%d limit=%d"
|
||||||
" handler_bci=%d ex_klass_index=%d",
|
" handler_bci=%d ex_klass_index=%d",
|
||||||
start(), limit(), handler_bci(), catch_klass_index());
|
start(), limit(), handler_bci(), catch_klass_index());
|
||||||
if (_catch_klass != NULL) {
|
if (_catch_klass != nullptr) {
|
||||||
tty->print(" ex_klass=");
|
tty->print(" ex_klass=");
|
||||||
_catch_klass->print();
|
_catch_klass->print();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -57,7 +57,7 @@ public:
|
|||||||
_limit = limit;
|
_limit = limit;
|
||||||
_handler_bci = handler_bci;
|
_handler_bci = handler_bci;
|
||||||
_catch_klass_index = klass_index;
|
_catch_klass_index = klass_index;
|
||||||
_catch_klass = NULL;
|
_catch_klass = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
int start() { return _start; }
|
int start() { return _start; }
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -44,7 +44,7 @@
|
|||||||
// the ciField will be incomplete.
|
// the ciField will be incomplete.
|
||||||
|
|
||||||
// The ciObjectFactory cannot create circular data structures in one query.
|
// The ciObjectFactory cannot create circular data structures in one query.
|
||||||
// To avoid vicious circularities, we initialize ciField::_type to NULL
|
// To avoid vicious circularities, we initialize ciField::_type to null
|
||||||
// for reference types and derive it lazily from the ciField::_signature.
|
// for reference types and derive it lazily from the ciField::_signature.
|
||||||
// Primitive types are eagerly initialized, and basic layout queries
|
// Primitive types are eagerly initialized, and basic layout queries
|
||||||
// can succeed without initialization, using only the BasicType of the field.
|
// can succeed without initialization, using only the BasicType of the field.
|
||||||
@ -71,7 +71,7 @@
|
|||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciField::ciField
|
// ciField::ciField
|
||||||
ciField::ciField(ciInstanceKlass* klass, int index) :
|
ciField::ciField(ciInstanceKlass* klass, int index) :
|
||||||
_known_to_link_with_put(NULL), _known_to_link_with_get(NULL) {
|
_known_to_link_with_put(nullptr), _known_to_link_with_get(nullptr) {
|
||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
CompilerThread *THREAD = CompilerThread::current();
|
CompilerThread *THREAD = CompilerThread::current();
|
||||||
|
|
||||||
@ -155,7 +155,7 @@ ciField::ciField(ciInstanceKlass* klass, int index) :
|
|||||||
fieldDescriptor field_desc;
|
fieldDescriptor field_desc;
|
||||||
Klass* canonical_holder =
|
Klass* canonical_holder =
|
||||||
loaded_decl_holder->find_field(name, signature, &field_desc);
|
loaded_decl_holder->find_field(name, signature, &field_desc);
|
||||||
if (canonical_holder == NULL) {
|
if (canonical_holder == nullptr) {
|
||||||
// Field lookup failed. Will be detected by will_link.
|
// Field lookup failed. Will be detected by will_link.
|
||||||
_holder = declared_holder;
|
_holder = declared_holder;
|
||||||
_offset = -1;
|
_offset = -1;
|
||||||
@ -191,7 +191,7 @@ ciField::ciField(ciInstanceKlass* klass, int index) :
|
|||||||
}
|
}
|
||||||
|
|
||||||
ciField::ciField(fieldDescriptor *fd) :
|
ciField::ciField(fieldDescriptor *fd) :
|
||||||
_known_to_link_with_put(NULL), _known_to_link_with_get(NULL) {
|
_known_to_link_with_put(nullptr), _known_to_link_with_get(nullptr) {
|
||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
|
|
||||||
// Get the field's name, signature, and type.
|
// Get the field's name, signature, and type.
|
||||||
@ -204,7 +204,7 @@ ciField::ciField(fieldDescriptor *fd) :
|
|||||||
// If the field is a pointer type, get the klass of the
|
// If the field is a pointer type, get the klass of the
|
||||||
// field.
|
// field.
|
||||||
if (is_reference_type(field_type)) {
|
if (is_reference_type(field_type)) {
|
||||||
_type = NULL; // must call compute_type on first access
|
_type = nullptr; // must call compute_type on first access
|
||||||
} else {
|
} else {
|
||||||
_type = ciType::make(field_type);
|
_type = ciType::make(field_type);
|
||||||
}
|
}
|
||||||
@ -217,7 +217,7 @@ ciField::ciField(fieldDescriptor *fd) :
|
|||||||
}
|
}
|
||||||
|
|
||||||
static bool trust_final_non_static_fields(ciInstanceKlass* holder) {
|
static bool trust_final_non_static_fields(ciInstanceKlass* holder) {
|
||||||
if (holder == NULL)
|
if (holder == nullptr)
|
||||||
return false;
|
return false;
|
||||||
if (holder->name() == ciSymbols::java_lang_System())
|
if (holder->name() == ciSymbols::java_lang_System())
|
||||||
// Never trust strangely unstable finals: System.out, etc.
|
// Never trust strangely unstable finals: System.out, etc.
|
||||||
@ -258,7 +258,7 @@ void ciField::initialize_from(fieldDescriptor* fd) {
|
|||||||
_flags = ciFlags(fd->access_flags());
|
_flags = ciFlags(fd->access_flags());
|
||||||
_offset = fd->offset();
|
_offset = fd->offset();
|
||||||
Klass* field_holder = fd->field_holder();
|
Klass* field_holder = fd->field_holder();
|
||||||
assert(field_holder != NULL, "null field_holder");
|
assert(field_holder != nullptr, "null field_holder");
|
||||||
_holder = CURRENT_ENV->get_instance_klass(field_holder);
|
_holder = CURRENT_ENV->get_instance_klass(field_holder);
|
||||||
|
|
||||||
// Check to see if the field is constant.
|
// Check to see if the field is constant.
|
||||||
@ -270,7 +270,7 @@ void ciField::initialize_from(fieldDescriptor* fd) {
|
|||||||
// not be constant is when the field is a *special* static & final field
|
// not be constant is when the field is a *special* static & final field
|
||||||
// whose value may change. The three examples are java.lang.System.in,
|
// whose value may change. The three examples are java.lang.System.in,
|
||||||
// java.lang.System.out, and java.lang.System.err.
|
// java.lang.System.out, and java.lang.System.err.
|
||||||
assert(vmClasses::System_klass() != NULL, "Check once per vm");
|
assert(vmClasses::System_klass() != nullptr, "Check once per vm");
|
||||||
if (k == vmClasses::System_klass()) {
|
if (k == vmClasses::System_klass()) {
|
||||||
// Check offsets for case 2: System.in, System.out, or System.err
|
// Check offsets for case 2: System.in, System.out, or System.err
|
||||||
if (_offset == java_lang_System::in_offset() ||
|
if (_offset == java_lang_System::in_offset() ||
|
||||||
@ -289,7 +289,7 @@ void ciField::initialize_from(fieldDescriptor* fd) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// For CallSite objects treat the target field as a compile time constant.
|
// For CallSite objects treat the target field as a compile time constant.
|
||||||
assert(vmClasses::CallSite_klass() != NULL, "should be already initialized");
|
assert(vmClasses::CallSite_klass() != nullptr, "should be already initialized");
|
||||||
if (k == vmClasses::CallSite_klass() &&
|
if (k == vmClasses::CallSite_klass() &&
|
||||||
_offset == java_lang_invoke_CallSite::target_offset()) {
|
_offset == java_lang_invoke_CallSite::target_offset()) {
|
||||||
assert(!has_initialized_final_update(), "CallSite is not supposed to have writes to final fields outside initializers");
|
assert(!has_initialized_final_update(), "CallSite is not supposed to have writes to final fields outside initializers");
|
||||||
@ -420,7 +420,7 @@ bool ciField::will_link(ciMethod* accessing_method,
|
|||||||
|
|
||||||
bool ciField::is_call_site_target() {
|
bool ciField::is_call_site_target() {
|
||||||
ciInstanceKlass* callsite_klass = CURRENT_ENV->CallSite_klass();
|
ciInstanceKlass* callsite_klass = CURRENT_ENV->CallSite_klass();
|
||||||
if (callsite_klass == NULL)
|
if (callsite_klass == nullptr)
|
||||||
return false;
|
return false;
|
||||||
return (holder()->is_subclass_of(callsite_klass) && (name() == ciSymbols::target_name()));
|
return (holder()->is_subclass_of(callsite_klass) && (name() == ciSymbols::target_name()));
|
||||||
}
|
}
|
||||||
@ -446,7 +446,7 @@ void ciField::print() {
|
|||||||
tty->print(" signature=");
|
tty->print(" signature=");
|
||||||
_signature->print_symbol();
|
_signature->print_symbol();
|
||||||
tty->print(" offset=%d type=", _offset);
|
tty->print(" offset=%d type=", _offset);
|
||||||
if (_type != NULL)
|
if (_type != nullptr)
|
||||||
_type->print_name();
|
_type->print_name();
|
||||||
else
|
else
|
||||||
tty->print("(reference)");
|
tty->print("(reference)");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -99,10 +99,10 @@ public:
|
|||||||
ciSymbol* signature() const { return _signature; }
|
ciSymbol* signature() const { return _signature; }
|
||||||
|
|
||||||
// Of what type is this field?
|
// Of what type is this field?
|
||||||
ciType* type() { return (_type == NULL) ? compute_type() : _type; }
|
ciType* type() { return (_type == nullptr) ? compute_type() : _type; }
|
||||||
|
|
||||||
// How is this field actually stored in memory?
|
// How is this field actually stored in memory?
|
||||||
BasicType layout_type() { return type2field[(_type == NULL) ? T_OBJECT : _type->basic_type()]; }
|
BasicType layout_type() { return type2field[(_type == nullptr) ? T_OBJECT : _type->basic_type()]; }
|
||||||
|
|
||||||
// How big is this field in memory?
|
// How big is this field in memory?
|
||||||
int size_in_bytes() { return type2aelembytes(layout_type()); }
|
int size_in_bytes() { return type2aelembytes(layout_type()); }
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,16 +42,16 @@
|
|||||||
ciType* ciInstance::java_mirror_type() {
|
ciType* ciInstance::java_mirror_type() {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
oop m = get_oop();
|
oop m = get_oop();
|
||||||
// Return NULL if it is not java.lang.Class.
|
// Return null if it is not java.lang.Class.
|
||||||
if (m == NULL || m->klass() != vmClasses::Class_klass()) {
|
if (m == nullptr || m->klass() != vmClasses::Class_klass()) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
// Return either a primitive type or a klass.
|
// Return either a primitive type or a klass.
|
||||||
if (java_lang_Class::is_primitive(m)) {
|
if (java_lang_Class::is_primitive(m)) {
|
||||||
return ciType::make(java_lang_Class::primitive_type(m));
|
return ciType::make(java_lang_Class::primitive_type(m));
|
||||||
} else {
|
} else {
|
||||||
Klass* k = java_lang_Class::as_Klass(m);
|
Klass* k = java_lang_Class::as_Klass(m);
|
||||||
assert(k != NULL, "");
|
assert(k != nullptr, "");
|
||||||
return CURRENT_THREAD_ENV->get_klass(k);
|
return CURRENT_THREAD_ENV->get_klass(k);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -60,7 +60,7 @@ ciType* ciInstance::java_mirror_type() {
|
|||||||
// ciInstance::field_value_impl
|
// ciInstance::field_value_impl
|
||||||
ciConstant ciInstance::field_value_impl(BasicType field_btype, int offset) {
|
ciConstant ciInstance::field_value_impl(BasicType field_btype, int offset) {
|
||||||
oop obj = get_oop();
|
oop obj = get_oop();
|
||||||
assert(obj != NULL, "bad oop");
|
assert(obj != nullptr, "bad oop");
|
||||||
switch(field_btype) {
|
switch(field_btype) {
|
||||||
case T_BYTE: return ciConstant(field_btype, obj->byte_field(offset));
|
case T_BYTE: return ciConstant(field_btype, obj->byte_field(offset));
|
||||||
case T_CHAR: return ciConstant(field_btype, obj->char_field(offset));
|
case T_CHAR: return ciConstant(field_btype, obj->char_field(offset));
|
||||||
@ -81,7 +81,7 @@ ciConstant ciInstance::field_value_impl(BasicType field_btype, int offset) {
|
|||||||
// or ciInstance is created. The compiler may be able to use
|
// or ciInstance is created. The compiler may be able to use
|
||||||
// information about the object's class (which is exact) or length.
|
// information about the object's class (which is exact) or length.
|
||||||
|
|
||||||
if (o == NULL) {
|
if (o == nullptr) {
|
||||||
return ciConstant(field_btype, ciNullObject::make());
|
return ciConstant(field_btype, ciNullObject::make());
|
||||||
} else {
|
} else {
|
||||||
return ciConstant(field_btype, CURRENT_ENV->get_object(o));
|
return ciConstant(field_btype, CURRENT_ENV->get_object(o));
|
||||||
@ -112,7 +112,7 @@ ciConstant ciInstance::field_value(ciField* field) {
|
|||||||
ciConstant ciInstance::field_value_by_offset(int field_offset) {
|
ciConstant ciInstance::field_value_by_offset(int field_offset) {
|
||||||
ciInstanceKlass* ik = klass()->as_instance_klass();
|
ciInstanceKlass* ik = klass()->as_instance_klass();
|
||||||
ciField* field = ik->get_field_by_offset(field_offset, false);
|
ciField* field = ik->get_field_by_offset(field_offset, false);
|
||||||
if (field == NULL)
|
if (field == nullptr)
|
||||||
return ciConstant(); // T_ILLEGAL
|
return ciConstant(); // T_ILLEGAL
|
||||||
return field_value(field);
|
return field_value(field);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -53,7 +53,7 @@ protected:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
// If this object is a java mirror, return the corresponding type.
|
// If this object is a java mirror, return the corresponding type.
|
||||||
// Otherwise, return NULL.
|
// Otherwise, return null.
|
||||||
// (Remember that a java mirror is an instance of java.lang.Class.)
|
// (Remember that a java mirror is an instance of java.lang.Class.)
|
||||||
ciType* java_mirror_type();
|
ciType* java_mirror_type();
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -66,10 +66,10 @@ ciInstanceKlass::ciInstanceKlass(Klass* k) :
|
|||||||
_has_nonstatic_concrete_methods = ik->has_nonstatic_concrete_methods();
|
_has_nonstatic_concrete_methods = ik->has_nonstatic_concrete_methods();
|
||||||
_is_hidden = ik->is_hidden();
|
_is_hidden = ik->is_hidden();
|
||||||
_is_record = ik->is_record();
|
_is_record = ik->is_record();
|
||||||
_nonstatic_fields = NULL; // initialized lazily by compute_nonstatic_fields:
|
_nonstatic_fields = nullptr; // initialized lazily by compute_nonstatic_fields:
|
||||||
_has_injected_fields = -1;
|
_has_injected_fields = -1;
|
||||||
_implementor = NULL; // we will fill these lazily
|
_implementor = nullptr; // we will fill these lazily
|
||||||
_transitive_interfaces = NULL;
|
_transitive_interfaces = nullptr;
|
||||||
|
|
||||||
// Ensure that the metadata wrapped by the ciMetadata is kept alive by GC.
|
// Ensure that the metadata wrapped by the ciMetadata is kept alive by GC.
|
||||||
// This is primarily useful for metadata which is considered as weak roots
|
// This is primarily useful for metadata which is considered as weak roots
|
||||||
@ -79,11 +79,11 @@ ciInstanceKlass::ciInstanceKlass(Klass* k) :
|
|||||||
oop holder = ik->klass_holder();
|
oop holder = ik->klass_holder();
|
||||||
if (ik->class_loader_data()->has_class_mirror_holder()) {
|
if (ik->class_loader_data()->has_class_mirror_holder()) {
|
||||||
// Though ciInstanceKlass records class loader oop, it's not enough to keep
|
// Though ciInstanceKlass records class loader oop, it's not enough to keep
|
||||||
// non-strong hidden classes alive (loader == NULL). Klass holder should
|
// non-strong hidden classes alive (loader == nullptr). Klass holder should
|
||||||
// be used instead. It is enough to record a ciObject, since cached elements are never removed
|
// be used instead. It is enough to record a ciObject, since cached elements are never removed
|
||||||
// during ciObjectFactory lifetime. ciObjectFactory itself is created for
|
// during ciObjectFactory lifetime. ciObjectFactory itself is created for
|
||||||
// every compilation and lives for the whole duration of the compilation.
|
// every compilation and lives for the whole duration of the compilation.
|
||||||
assert(holder != NULL, "holder of hidden class is the mirror which is never null");
|
assert(holder != nullptr, "holder of hidden class is the mirror which is never null");
|
||||||
(void)CURRENT_ENV->get_object(holder);
|
(void)CURRENT_ENV->get_object(holder);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,8 +104,8 @@ ciInstanceKlass::ciInstanceKlass(Klass* k) :
|
|||||||
_has_trusted_loader = compute_has_trusted_loader();
|
_has_trusted_loader = compute_has_trusted_loader();
|
||||||
|
|
||||||
// Lazy fields get filled in only upon request.
|
// Lazy fields get filled in only upon request.
|
||||||
_super = NULL;
|
_super = nullptr;
|
||||||
_java_mirror = NULL;
|
_java_mirror = nullptr;
|
||||||
|
|
||||||
if (is_shared()) {
|
if (is_shared()) {
|
||||||
if (k != vmClasses::Object_klass()) {
|
if (k != vmClasses::Object_klass()) {
|
||||||
@ -114,7 +114,7 @@ ciInstanceKlass::ciInstanceKlass(Klass* k) :
|
|||||||
//compute_nonstatic_fields(); // done outside of constructor
|
//compute_nonstatic_fields(); // done outside of constructor
|
||||||
}
|
}
|
||||||
|
|
||||||
_field_cache = NULL;
|
_field_cache = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Version for unloaded classes:
|
// Version for unloaded classes:
|
||||||
@ -125,16 +125,16 @@ ciInstanceKlass::ciInstanceKlass(ciSymbol* name,
|
|||||||
assert(name->char_at(0) != JVM_SIGNATURE_ARRAY, "not an instance klass");
|
assert(name->char_at(0) != JVM_SIGNATURE_ARRAY, "not an instance klass");
|
||||||
_init_state = (InstanceKlass::ClassState)0;
|
_init_state = (InstanceKlass::ClassState)0;
|
||||||
_has_nonstatic_fields = false;
|
_has_nonstatic_fields = false;
|
||||||
_nonstatic_fields = NULL;
|
_nonstatic_fields = nullptr;
|
||||||
_has_injected_fields = -1;
|
_has_injected_fields = -1;
|
||||||
_is_hidden = false;
|
_is_hidden = false;
|
||||||
_is_record = false;
|
_is_record = false;
|
||||||
_loader = loader;
|
_loader = loader;
|
||||||
_protection_domain = protection_domain;
|
_protection_domain = protection_domain;
|
||||||
_is_shared = false;
|
_is_shared = false;
|
||||||
_super = NULL;
|
_super = nullptr;
|
||||||
_java_mirror = NULL;
|
_java_mirror = nullptr;
|
||||||
_field_cache = NULL;
|
_field_cache = nullptr;
|
||||||
_has_trusted_loader = compute_has_trusted_loader();
|
_has_trusted_loader = compute_has_trusted_loader();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,7 +154,7 @@ void ciInstanceKlass::compute_shared_init_state() {
|
|||||||
bool ciInstanceKlass::compute_shared_has_subklass() {
|
bool ciInstanceKlass::compute_shared_has_subklass() {
|
||||||
GUARDED_VM_ENTRY(
|
GUARDED_VM_ENTRY(
|
||||||
InstanceKlass* ik = get_instanceKlass();
|
InstanceKlass* ik = get_instanceKlass();
|
||||||
_has_subklass = ik->subklass() != NULL ? subklass_true : subklass_false;
|
_has_subklass = ik->subklass() != nullptr ? subklass_true : subklass_false;
|
||||||
return _has_subklass == subklass_true;
|
return _has_subklass == subklass_true;
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
@ -191,9 +191,9 @@ jobject ciInstanceKlass::protection_domain_handle() {
|
|||||||
// Get the field cache associated with this klass.
|
// Get the field cache associated with this klass.
|
||||||
ciConstantPoolCache* ciInstanceKlass::field_cache() {
|
ciConstantPoolCache* ciInstanceKlass::field_cache() {
|
||||||
if (is_shared()) {
|
if (is_shared()) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (_field_cache == NULL) {
|
if (_field_cache == nullptr) {
|
||||||
assert(!is_java_lang_Object(), "Object has no fields");
|
assert(!is_java_lang_Object(), "Object has no fields");
|
||||||
Arena* arena = CURRENT_ENV->arena();
|
Arena* arena = CURRENT_ENV->arena();
|
||||||
_field_cache = new (arena) ciConstantPoolCache(arena, 5);
|
_field_cache = new (arena) ciConstantPoolCache(arena, 5);
|
||||||
@ -222,13 +222,13 @@ ciInstanceKlass* ciInstanceKlass::get_canonical_holder(int offset) {
|
|||||||
ciInstanceKlass* self = this;
|
ciInstanceKlass* self = this;
|
||||||
assert(self->is_loaded(), "must be loaded to access field info");
|
assert(self->is_loaded(), "must be loaded to access field info");
|
||||||
ciField* field = self->get_field_by_offset(offset, false);
|
ciField* field = self->get_field_by_offset(offset, false);
|
||||||
if (field != NULL) {
|
if (field != nullptr) {
|
||||||
return field->holder();
|
return field->holder();
|
||||||
} else {
|
} else {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
assert(self->is_loaded(), "must be loaded to have size");
|
assert(self->is_loaded(), "must be loaded to have size");
|
||||||
ciInstanceKlass* super = self->super();
|
ciInstanceKlass* super = self->super();
|
||||||
if (super == NULL ||
|
if (super == nullptr ||
|
||||||
super->nof_nonstatic_fields() == 0 ||
|
super->nof_nonstatic_fields() == 0 ||
|
||||||
super->layout_helper_size_in_bytes() <= offset) {
|
super->layout_helper_size_in_bytes() <= offset) {
|
||||||
return self;
|
return self;
|
||||||
@ -252,7 +252,7 @@ bool ciInstanceKlass::is_java_lang_Object() const {
|
|||||||
bool ciInstanceKlass::uses_default_loader() const {
|
bool ciInstanceKlass::uses_default_loader() const {
|
||||||
// Note: We do not need to resolve the handle or enter the VM
|
// Note: We do not need to resolve the handle or enter the VM
|
||||||
// in order to test null-ness.
|
// in order to test null-ness.
|
||||||
return _loader == NULL;
|
return _loader == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -355,7 +355,7 @@ void ciInstanceKlass::print_impl(outputStream* st) {
|
|||||||
// Get the superklass of this klass.
|
// Get the superklass of this klass.
|
||||||
ciInstanceKlass* ciInstanceKlass::super() {
|
ciInstanceKlass* ciInstanceKlass::super() {
|
||||||
assert(is_loaded(), "must be loaded");
|
assert(is_loaded(), "must be loaded");
|
||||||
if (_super == NULL && !is_java_lang_Object()) {
|
if (_super == nullptr && !is_java_lang_Object()) {
|
||||||
GUARDED_VM_ENTRY(
|
GUARDED_VM_ENTRY(
|
||||||
Klass* super_klass = get_instanceKlass()->super();
|
Klass* super_klass = get_instanceKlass()->super();
|
||||||
_super = CURRENT_ENV->get_instance_klass(super_klass);
|
_super = CURRENT_ENV->get_instance_klass(super_klass);
|
||||||
@ -373,7 +373,7 @@ ciInstance* ciInstanceKlass::java_mirror() {
|
|||||||
if (is_shared()) {
|
if (is_shared()) {
|
||||||
return ciKlass::java_mirror();
|
return ciKlass::java_mirror();
|
||||||
}
|
}
|
||||||
if (_java_mirror == NULL) {
|
if (_java_mirror == nullptr) {
|
||||||
_java_mirror = ciKlass::java_mirror();
|
_java_mirror = ciKlass::java_mirror();
|
||||||
}
|
}
|
||||||
return _java_mirror;
|
return _java_mirror;
|
||||||
@ -382,15 +382,15 @@ ciInstance* ciInstanceKlass::java_mirror() {
|
|||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciInstanceKlass::unique_concrete_subklass
|
// ciInstanceKlass::unique_concrete_subklass
|
||||||
ciInstanceKlass* ciInstanceKlass::unique_concrete_subklass() {
|
ciInstanceKlass* ciInstanceKlass::unique_concrete_subklass() {
|
||||||
if (!is_loaded()) return NULL; // No change if class is not loaded
|
if (!is_loaded()) return nullptr; // No change if class is not loaded
|
||||||
if (!is_abstract()) return NULL; // Only applies to abstract classes.
|
if (!is_abstract()) return nullptr; // Only applies to abstract classes.
|
||||||
if (!has_subklass()) return NULL; // Must have at least one subklass.
|
if (!has_subklass()) return nullptr; // Must have at least one subklass.
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
InstanceKlass* ik = get_instanceKlass();
|
InstanceKlass* ik = get_instanceKlass();
|
||||||
Klass* up = ik->up_cast_abstract();
|
Klass* up = ik->up_cast_abstract();
|
||||||
assert(up->is_instance_klass(), "must be InstanceKlass");
|
assert(up->is_instance_klass(), "must be InstanceKlass");
|
||||||
if (ik == up) {
|
if (ik == up) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return CURRENT_THREAD_ENV->get_instance_klass(up);
|
return CURRENT_THREAD_ENV->get_instance_klass(up);
|
||||||
}
|
}
|
||||||
@ -400,7 +400,7 @@ ciInstanceKlass* ciInstanceKlass::unique_concrete_subklass() {
|
|||||||
bool ciInstanceKlass::has_finalizable_subclass() {
|
bool ciInstanceKlass::has_finalizable_subclass() {
|
||||||
if (!is_loaded()) return true;
|
if (!is_loaded()) return true;
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
return Dependencies::find_finalizable_subclass(get_instanceKlass()) != NULL;
|
return Dependencies::find_finalizable_subclass(get_instanceKlass()) != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -423,13 +423,13 @@ ciField* ciInstanceKlass::get_field_by_offset(int field_offset, bool is_static)
|
|||||||
break;
|
break;
|
||||||
// could do binary search or check bins, but probably not worth it
|
// could do binary search or check bins, but probably not worth it
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
InstanceKlass* k = get_instanceKlass();
|
InstanceKlass* k = get_instanceKlass();
|
||||||
fieldDescriptor fd;
|
fieldDescriptor fd;
|
||||||
if (!k->find_field_from_offset(field_offset, is_static, &fd)) {
|
if (!k->find_field_from_offset(field_offset, is_static, &fd)) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
ciField* field = new (CURRENT_THREAD_ENV->arena()) ciField(&fd);
|
ciField* field = new (CURRENT_THREAD_ENV->arena()) ciField(&fd);
|
||||||
return field;
|
return field;
|
||||||
@ -442,8 +442,8 @@ ciField* ciInstanceKlass::get_field_by_name(ciSymbol* name, ciSymbol* signature,
|
|||||||
InstanceKlass* k = get_instanceKlass();
|
InstanceKlass* k = get_instanceKlass();
|
||||||
fieldDescriptor fd;
|
fieldDescriptor fd;
|
||||||
Klass* def = k->find_field(name->get_symbol(), signature->get_symbol(), is_static, &fd);
|
Klass* def = k->find_field(name->get_symbol(), signature->get_symbol(), is_static, &fd);
|
||||||
if (def == NULL) {
|
if (def == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
ciField* field = new (CURRENT_THREAD_ENV->arena()) ciField(&fd);
|
ciField* field = new (CURRENT_THREAD_ENV->arena()) ciField(&fd);
|
||||||
return field;
|
return field;
|
||||||
@ -460,32 +460,32 @@ static int sort_field_by_offset(ciField** a, ciField** b) {
|
|||||||
int ciInstanceKlass::compute_nonstatic_fields() {
|
int ciInstanceKlass::compute_nonstatic_fields() {
|
||||||
assert(is_loaded(), "must be loaded");
|
assert(is_loaded(), "must be loaded");
|
||||||
|
|
||||||
if (_nonstatic_fields != NULL)
|
if (_nonstatic_fields != nullptr)
|
||||||
return _nonstatic_fields->length();
|
return _nonstatic_fields->length();
|
||||||
|
|
||||||
if (!has_nonstatic_fields()) {
|
if (!has_nonstatic_fields()) {
|
||||||
Arena* arena = CURRENT_ENV->arena();
|
Arena* arena = CURRENT_ENV->arena();
|
||||||
_nonstatic_fields = new (arena) GrowableArray<ciField*>(arena, 0, 0, NULL);
|
_nonstatic_fields = new (arena) GrowableArray<ciField*>(arena, 0, 0, nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
assert(!is_java_lang_Object(), "bootstrap OK");
|
assert(!is_java_lang_Object(), "bootstrap OK");
|
||||||
|
|
||||||
ciInstanceKlass* super = this->super();
|
ciInstanceKlass* super = this->super();
|
||||||
GrowableArray<ciField*>* super_fields = NULL;
|
GrowableArray<ciField*>* super_fields = nullptr;
|
||||||
if (super != NULL && super->has_nonstatic_fields()) {
|
if (super != nullptr && super->has_nonstatic_fields()) {
|
||||||
int super_flen = super->nof_nonstatic_fields();
|
int super_flen = super->nof_nonstatic_fields();
|
||||||
super_fields = super->_nonstatic_fields;
|
super_fields = super->_nonstatic_fields;
|
||||||
assert(super_flen == 0 || super_fields != NULL, "first get nof_fields");
|
assert(super_flen == 0 || super_fields != nullptr, "first get nof_fields");
|
||||||
}
|
}
|
||||||
|
|
||||||
GrowableArray<ciField*>* fields = NULL;
|
GrowableArray<ciField*>* fields = nullptr;
|
||||||
GUARDED_VM_ENTRY({
|
GUARDED_VM_ENTRY({
|
||||||
fields = compute_nonstatic_fields_impl(super_fields);
|
fields = compute_nonstatic_fields_impl(super_fields);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (fields == NULL) {
|
if (fields == nullptr) {
|
||||||
// This can happen if this class (java.lang.Class) has invisible fields.
|
// This can happen if this class (java.lang.Class) has invisible fields.
|
||||||
if (super_fields != NULL) {
|
if (super_fields != nullptr) {
|
||||||
_nonstatic_fields = super_fields;
|
_nonstatic_fields = super_fields;
|
||||||
return super_fields->length();
|
return super_fields->length();
|
||||||
} else {
|
} else {
|
||||||
@ -508,7 +508,7 @@ ciInstanceKlass::compute_nonstatic_fields_impl(GrowableArray<ciField*>*
|
|||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
Arena* arena = CURRENT_ENV->arena();
|
Arena* arena = CURRENT_ENV->arena();
|
||||||
int flen = 0;
|
int flen = 0;
|
||||||
GrowableArray<ciField*>* fields = NULL;
|
GrowableArray<ciField*>* fields = nullptr;
|
||||||
InstanceKlass* k = get_instanceKlass();
|
InstanceKlass* k = get_instanceKlass();
|
||||||
for (JavaFieldStream fs(k); !fs.done(); fs.next()) {
|
for (JavaFieldStream fs(k); !fs.done(); fs.next()) {
|
||||||
if (fs.access_flags().is_static()) continue;
|
if (fs.access_flags().is_static()) continue;
|
||||||
@ -517,13 +517,13 @@ ciInstanceKlass::compute_nonstatic_fields_impl(GrowableArray<ciField*>*
|
|||||||
|
|
||||||
// allocate the array:
|
// allocate the array:
|
||||||
if (flen == 0) {
|
if (flen == 0) {
|
||||||
return NULL; // return nothing if none are locally declared
|
return nullptr; // return nothing if none are locally declared
|
||||||
}
|
}
|
||||||
if (super_fields != NULL) {
|
if (super_fields != nullptr) {
|
||||||
flen += super_fields->length();
|
flen += super_fields->length();
|
||||||
}
|
}
|
||||||
fields = new (arena) GrowableArray<ciField*>(arena, flen, 0, NULL);
|
fields = new (arena) GrowableArray<ciField*>(arena, flen, 0, nullptr);
|
||||||
if (super_fields != NULL) {
|
if (super_fields != nullptr) {
|
||||||
fields->appendAll(super_fields);
|
fields->appendAll(super_fields);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -552,7 +552,7 @@ void ciInstanceKlass::compute_injected_fields() {
|
|||||||
assert(is_loaded(), "must be loaded");
|
assert(is_loaded(), "must be loaded");
|
||||||
|
|
||||||
int has_injected_fields = 0;
|
int has_injected_fields = 0;
|
||||||
if (super() != NULL && super()->has_injected_fields()) {
|
if (super() != nullptr && super()->has_injected_fields()) {
|
||||||
has_injected_fields = 1;
|
has_injected_fields = 1;
|
||||||
} else {
|
} else {
|
||||||
GUARDED_VM_ENTRY({
|
GUARDED_VM_ENTRY({
|
||||||
@ -573,7 +573,7 @@ bool ciInstanceKlass::has_object_fields() const {
|
|||||||
bool ciInstanceKlass::compute_has_trusted_loader() {
|
bool ciInstanceKlass::compute_has_trusted_loader() {
|
||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
oop loader_oop = loader();
|
oop loader_oop = loader();
|
||||||
if (loader_oop == NULL) {
|
if (loader_oop == nullptr) {
|
||||||
return true; // bootstrap class loader
|
return true; // bootstrap class loader
|
||||||
}
|
}
|
||||||
return java_lang_ClassLoader::is_trusted_loader(loader_oop);
|
return java_lang_ClassLoader::is_trusted_loader(loader_oop);
|
||||||
@ -590,7 +590,7 @@ ciMethod* ciInstanceKlass::find_method(ciSymbol* name, ciSymbol* signature) {
|
|||||||
Symbol* sig_sym= signature->get_symbol();
|
Symbol* sig_sym= signature->get_symbol();
|
||||||
|
|
||||||
Method* m = k->find_method(name_sym, sig_sym);
|
Method* m = k->find_method(name_sym, sig_sym);
|
||||||
if (m == NULL) return NULL;
|
if (m == nullptr) return nullptr;
|
||||||
|
|
||||||
return CURRENT_THREAD_ENV->get_method(m);
|
return CURRENT_THREAD_ENV->get_method(m);
|
||||||
}
|
}
|
||||||
@ -617,7 +617,7 @@ bool ciInstanceKlass::is_leaf_type() {
|
|||||||
// will be checked later under the Compile_lock.
|
// will be checked later under the Compile_lock.
|
||||||
ciInstanceKlass* ciInstanceKlass::implementor() {
|
ciInstanceKlass* ciInstanceKlass::implementor() {
|
||||||
ciInstanceKlass* impl = _implementor;
|
ciInstanceKlass* impl = _implementor;
|
||||||
if (impl == NULL) {
|
if (impl == nullptr) {
|
||||||
if (is_shared()) {
|
if (is_shared()) {
|
||||||
impl = this; // assume a well-known interface never has a unique implementor
|
impl = this; // assume a well-known interface never has a unique implementor
|
||||||
} else {
|
} else {
|
||||||
@ -625,7 +625,7 @@ ciInstanceKlass* ciInstanceKlass::implementor() {
|
|||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MutexLocker ml(Compile_lock);
|
MutexLocker ml(Compile_lock);
|
||||||
Klass* k = get_instanceKlass()->implementor();
|
Klass* k = get_instanceKlass()->implementor();
|
||||||
if (k != NULL) {
|
if (k != nullptr) {
|
||||||
if (k == get_instanceKlass()) {
|
if (k == get_instanceKlass()) {
|
||||||
// More than one implementors. Use 'this' in this case.
|
// More than one implementors. Use 'this' in this case.
|
||||||
impl = this;
|
impl = this;
|
||||||
@ -681,13 +681,13 @@ class StaticFinalFieldPrinter : public FieldClosure {
|
|||||||
case T_ARRAY: // fall-through
|
case T_ARRAY: // fall-through
|
||||||
case T_OBJECT: {
|
case T_OBJECT: {
|
||||||
oop value = mirror->obj_field_acquire(fd->offset());
|
oop value = mirror->obj_field_acquire(fd->offset());
|
||||||
if (value == NULL) {
|
if (value == nullptr) {
|
||||||
_out->print_cr("null");
|
_out->print_cr("null");
|
||||||
} else if (value->is_instance()) {
|
} else if (value->is_instance()) {
|
||||||
assert(fd->field_type() == T_OBJECT, "");
|
assert(fd->field_type() == T_OBJECT, "");
|
||||||
if (value->is_a(vmClasses::String_klass())) {
|
if (value->is_a(vmClasses::String_klass())) {
|
||||||
const char* ascii_value = java_lang_String::as_quoted_ascii(value);
|
const char* ascii_value = java_lang_String::as_quoted_ascii(value);
|
||||||
_out->print_cr("\"%s\"", (ascii_value != NULL) ? ascii_value : "");
|
_out->print_cr("\"%s\"", (ascii_value != nullptr) ? ascii_value : "");
|
||||||
} else {
|
} else {
|
||||||
const char* klass_name = value->klass()->name()->as_quoted_ascii();
|
const char* klass_name = value->klass()->name()->as_quoted_ascii();
|
||||||
_out->print_cr("%s", klass_name);
|
_out->print_cr("%s", klass_name);
|
||||||
@ -720,7 +720,7 @@ const char *ciInstanceKlass::replay_name() const {
|
|||||||
void ciInstanceKlass::dump_replay_instanceKlass(outputStream* out, InstanceKlass* ik) {
|
void ciInstanceKlass::dump_replay_instanceKlass(outputStream* out, InstanceKlass* ik) {
|
||||||
if (ik->is_hidden()) {
|
if (ik->is_hidden()) {
|
||||||
const char *name = CURRENT_ENV->dyno_name(ik);
|
const char *name = CURRENT_ENV->dyno_name(ik);
|
||||||
if (name != NULL) {
|
if (name != nullptr) {
|
||||||
out->print_cr("instanceKlass %s # %s", name, ik->name()->as_quoted_ascii());
|
out->print_cr("instanceKlass %s # %s", name, ik->name()->as_quoted_ascii());
|
||||||
} else {
|
} else {
|
||||||
out->print_cr("# instanceKlass %s", ik->name()->as_quoted_ascii());
|
out->print_cr("# instanceKlass %s", ik->name()->as_quoted_ascii());
|
||||||
@ -764,7 +764,7 @@ void ciInstanceKlass::dump_replay_data(outputStream* out) {
|
|||||||
|
|
||||||
// Try to record related loaded classes
|
// Try to record related loaded classes
|
||||||
Klass* sub = ik->subklass();
|
Klass* sub = ik->subklass();
|
||||||
while (sub != NULL) {
|
while (sub != nullptr) {
|
||||||
if (sub->is_instance_klass()) {
|
if (sub->is_instance_klass()) {
|
||||||
InstanceKlass *isub = InstanceKlass::cast(sub);
|
InstanceKlass *isub = InstanceKlass::cast(sub);
|
||||||
dump_replay_instanceKlass(out, isub);
|
dump_replay_instanceKlass(out, isub);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -72,7 +72,7 @@ private:
|
|||||||
int _has_injected_fields; // any non static injected fields? lazily initialized.
|
int _has_injected_fields; // any non static injected fields? lazily initialized.
|
||||||
|
|
||||||
// The possible values of the _implementor fall into following three cases:
|
// The possible values of the _implementor fall into following three cases:
|
||||||
// NULL: no implementor.
|
// null: no implementor.
|
||||||
// A ciInstanceKlass that's not itself: one implementor.
|
// A ciInstanceKlass that's not itself: one implementor.
|
||||||
// Itself: more than one implementor.
|
// Itself: more than one implementor.
|
||||||
ciInstanceKlass* _implementor;
|
ciInstanceKlass* _implementor;
|
||||||
@ -183,7 +183,7 @@ public:
|
|||||||
ciInstanceKlass* impl;
|
ciInstanceKlass* impl;
|
||||||
assert(is_loaded(), "must be loaded");
|
assert(is_loaded(), "must be loaded");
|
||||||
impl = implementor();
|
impl = implementor();
|
||||||
if (impl == NULL) {
|
if (impl == nullptr) {
|
||||||
return 0;
|
return 0;
|
||||||
} else if (impl != this) {
|
} else if (impl != this) {
|
||||||
return 1;
|
return 1;
|
||||||
@ -210,7 +210,7 @@ public:
|
|||||||
|
|
||||||
// total number of nonstatic fields (including inherited):
|
// total number of nonstatic fields (including inherited):
|
||||||
int nof_nonstatic_fields() {
|
int nof_nonstatic_fields() {
|
||||||
if (_nonstatic_fields == NULL)
|
if (_nonstatic_fields == nullptr)
|
||||||
return compute_nonstatic_fields();
|
return compute_nonstatic_fields();
|
||||||
else
|
else
|
||||||
return _nonstatic_fields->length();
|
return _nonstatic_fields->length();
|
||||||
@ -227,7 +227,7 @@ public:
|
|||||||
|
|
||||||
// nth nonstatic field (presented by ascending address)
|
// nth nonstatic field (presented by ascending address)
|
||||||
ciField* nonstatic_field_at(int i) {
|
ciField* nonstatic_field_at(int i) {
|
||||||
assert(_nonstatic_fields != NULL, "");
|
assert(_nonstatic_fields != nullptr, "");
|
||||||
return _nonstatic_fields->at(i);
|
return _nonstatic_fields->at(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -258,7 +258,7 @@ public:
|
|||||||
ciInstanceKlass* unique_implementor() {
|
ciInstanceKlass* unique_implementor() {
|
||||||
assert(is_loaded(), "must be loaded");
|
assert(is_loaded(), "must be loaded");
|
||||||
ciInstanceKlass* impl = implementor();
|
ciInstanceKlass* impl = implementor();
|
||||||
return (impl != this ? impl : NULL);
|
return (impl != this ? impl : nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is the defining class loader of this class the default loader?
|
// Is the defining class loader of this class the default loader?
|
||||||
@ -283,7 +283,7 @@ public:
|
|||||||
if (is_loaded() && is_final() && !is_interface()) {
|
if (is_loaded() && is_final() && !is_interface()) {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool can_be_instantiated() {
|
bool can_be_instantiated() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,7 +41,7 @@ ciKlass::ciKlass(Klass* k) : ciType(k) {
|
|||||||
Klass* klass = get_Klass();
|
Klass* klass = get_Klass();
|
||||||
_layout_helper = klass->layout_helper();
|
_layout_helper = klass->layout_helper();
|
||||||
Symbol* klass_name = klass->name();
|
Symbol* klass_name = klass->name();
|
||||||
assert(klass_name != NULL, "wrong ciKlass constructor");
|
assert(klass_name != nullptr, "wrong ciKlass constructor");
|
||||||
_name = CURRENT_ENV->get_symbol(klass_name);
|
_name = CURRENT_ENV->get_symbol(klass_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -136,7 +136,7 @@ ciKlass* ciKlass::super_of_depth(juint i) {
|
|||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
Klass* this_klass = get_Klass();
|
Klass* this_klass = get_Klass();
|
||||||
Klass* super = this_klass->primary_super_of_depth(i);
|
Klass* super = this_klass->primary_super_of_depth(i);
|
||||||
return (super != NULL) ? CURRENT_THREAD_ENV->get_klass(super) : NULL;
|
return (super != nullptr) ? CURRENT_THREAD_ENV->get_klass(super) : nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -57,16 +57,16 @@ protected:
|
|||||||
|
|
||||||
Klass* get_Klass() const {
|
Klass* get_Klass() const {
|
||||||
Klass* k = (Klass*)_metadata;
|
Klass* k = (Klass*)_metadata;
|
||||||
assert(k != NULL, "illegal use of unloaded klass");
|
assert(k != nullptr, "illegal use of unloaded klass");
|
||||||
return k;
|
return k;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Certain subklasses have an associated class loader.
|
// Certain subklasses have an associated class loader.
|
||||||
virtual oop loader() { return NULL; }
|
virtual oop loader() { return nullptr; }
|
||||||
virtual jobject loader_handle() { return NULL; }
|
virtual jobject loader_handle() { return nullptr; }
|
||||||
|
|
||||||
virtual oop protection_domain() { return NULL; }
|
virtual oop protection_domain() { return nullptr; }
|
||||||
virtual jobject protection_domain_handle() { return NULL; }
|
virtual jobject protection_domain_handle() { return nullptr; }
|
||||||
|
|
||||||
const char* type_string() { return "ciKlass"; }
|
const char* type_string() { return "ciKlass"; }
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -40,12 +40,12 @@ class ciMetadata: public ciBaseObject {
|
|||||||
protected:
|
protected:
|
||||||
Metadata* _metadata;
|
Metadata* _metadata;
|
||||||
|
|
||||||
ciMetadata(): _metadata(NULL) {}
|
ciMetadata(): _metadata(nullptr) {}
|
||||||
ciMetadata(Metadata* o): _metadata(o) {}
|
ciMetadata(Metadata* o): _metadata(o) {}
|
||||||
|
|
||||||
virtual bool is_classless() const;
|
virtual bool is_classless() const;
|
||||||
public:
|
public:
|
||||||
bool is_loaded() const { return _metadata != NULL || is_classless(); }
|
bool is_loaded() const { return _metadata != nullptr || is_classless(); }
|
||||||
|
|
||||||
virtual bool is_metadata() const { return true; }
|
virtual bool is_metadata() const { return true; }
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -70,7 +70,7 @@ ciMethod::ciMethod(const methodHandle& h_m, ciInstanceKlass* holder) :
|
|||||||
ciMetadata(h_m()),
|
ciMetadata(h_m()),
|
||||||
_holder(holder)
|
_holder(holder)
|
||||||
{
|
{
|
||||||
assert(h_m() != NULL, "no null method");
|
assert(h_m() != nullptr, "no null method");
|
||||||
assert(_holder->get_instanceKlass() == h_m->method_holder(), "");
|
assert(_holder->get_instanceKlass() == h_m->method_holder(), "");
|
||||||
|
|
||||||
// These fields are always filled in in loaded methods.
|
// These fields are always filled in in loaded methods.
|
||||||
@ -90,13 +90,13 @@ ciMethod::ciMethod(const methodHandle& h_m, ciInstanceKlass* holder) :
|
|||||||
_has_reserved_stack_access = h_m->has_reserved_stack_access();
|
_has_reserved_stack_access = h_m->has_reserved_stack_access();
|
||||||
_is_overpass = h_m->is_overpass();
|
_is_overpass = h_m->is_overpass();
|
||||||
// Lazy fields, filled in on demand. Require allocation.
|
// Lazy fields, filled in on demand. Require allocation.
|
||||||
_code = NULL;
|
_code = nullptr;
|
||||||
_exception_handlers = NULL;
|
_exception_handlers = nullptr;
|
||||||
_liveness = NULL;
|
_liveness = nullptr;
|
||||||
_method_blocks = NULL;
|
_method_blocks = nullptr;
|
||||||
#if defined(COMPILER2)
|
#if defined(COMPILER2)
|
||||||
_flow = NULL;
|
_flow = nullptr;
|
||||||
_bcea = NULL;
|
_bcea = nullptr;
|
||||||
#endif // COMPILER2
|
#endif // COMPILER2
|
||||||
|
|
||||||
// Check for blackhole intrinsic and then populate the intrinsic ID.
|
// Check for blackhole intrinsic and then populate the intrinsic ID.
|
||||||
@ -107,7 +107,7 @@ ciMethod::ciMethod(const methodHandle& h_m, ciInstanceKlass* holder) :
|
|||||||
if (env->jvmti_can_hotswap_or_post_breakpoint()) {
|
if (env->jvmti_can_hotswap_or_post_breakpoint()) {
|
||||||
// 6328518 check hotswap conditions under the right lock.
|
// 6328518 check hotswap conditions under the right lock.
|
||||||
MutexLocker locker(Compile_lock);
|
MutexLocker locker(Compile_lock);
|
||||||
if (Dependencies::check_evol_method(h_m()) != NULL) {
|
if (Dependencies::check_evol_method(h_m()) != nullptr) {
|
||||||
_is_c1_compilable = false;
|
_is_c1_compilable = false;
|
||||||
_is_c2_compilable = false;
|
_is_c2_compilable = false;
|
||||||
_can_be_parsed = false;
|
_can_be_parsed = false;
|
||||||
@ -138,7 +138,7 @@ ciMethod::ciMethod(const methodHandle& h_m, ciInstanceKlass* holder) :
|
|||||||
ciSymbol* sig_symbol = env->get_symbol(h_m->signature());
|
ciSymbol* sig_symbol = env->get_symbol(h_m->signature());
|
||||||
constantPoolHandle cpool(Thread::current(), h_m->constants());
|
constantPoolHandle cpool(Thread::current(), h_m->constants());
|
||||||
_signature = new (env->arena()) ciSignature(_holder, cpool, sig_symbol);
|
_signature = new (env->arena()) ciSignature(_holder, cpool, sig_symbol);
|
||||||
_method_data = NULL;
|
_method_data = nullptr;
|
||||||
// Take a snapshot of these values, so they will be commensurate with the MDO.
|
// Take a snapshot of these values, so they will be commensurate with the MDO.
|
||||||
if (ProfileInterpreter || CompilerConfig::is_c1_profiling()) {
|
if (ProfileInterpreter || CompilerConfig::is_c1_profiling()) {
|
||||||
int invcnt = h_m->interpreter_invocation_count();
|
int invcnt = h_m->interpreter_invocation_count();
|
||||||
@ -166,20 +166,20 @@ ciMethod::ciMethod(ciInstanceKlass* holder,
|
|||||||
ciSymbol* name,
|
ciSymbol* name,
|
||||||
ciSymbol* signature,
|
ciSymbol* signature,
|
||||||
ciInstanceKlass* accessor) :
|
ciInstanceKlass* accessor) :
|
||||||
ciMetadata((Metadata*)NULL),
|
ciMetadata((Metadata*)nullptr),
|
||||||
_name( name),
|
_name( name),
|
||||||
_holder( holder),
|
_holder( holder),
|
||||||
_method_data( NULL),
|
_method_data( nullptr),
|
||||||
_method_blocks( NULL),
|
_method_blocks( nullptr),
|
||||||
_intrinsic_id( vmIntrinsics::_none),
|
_intrinsic_id( vmIntrinsics::_none),
|
||||||
_inline_instructions_size(-1),
|
_inline_instructions_size(-1),
|
||||||
_can_be_statically_bound(false),
|
_can_be_statically_bound(false),
|
||||||
_can_omit_stack_trace(true),
|
_can_omit_stack_trace(true),
|
||||||
_liveness( NULL)
|
_liveness( nullptr)
|
||||||
#if defined(COMPILER2)
|
#if defined(COMPILER2)
|
||||||
,
|
,
|
||||||
_flow( NULL),
|
_flow( nullptr),
|
||||||
_bcea( NULL)
|
_bcea( nullptr)
|
||||||
#endif // COMPILER2
|
#endif // COMPILER2
|
||||||
{
|
{
|
||||||
// Usually holder and accessor are the same type but in some cases
|
// Usually holder and accessor are the same type but in some cases
|
||||||
@ -208,7 +208,7 @@ void ciMethod::load_code() {
|
|||||||
// Revert any breakpoint bytecodes in ci's copy
|
// Revert any breakpoint bytecodes in ci's copy
|
||||||
if (me->number_of_breakpoints() > 0) {
|
if (me->number_of_breakpoints() > 0) {
|
||||||
BreakpointInfo* bp = me->method_holder()->breakpoints();
|
BreakpointInfo* bp = me->method_holder()->breakpoints();
|
||||||
for (; bp != NULL; bp = bp->next()) {
|
for (; bp != nullptr; bp = bp->next()) {
|
||||||
if (bp->match(me)) {
|
if (bp->match(me)) {
|
||||||
code_at_put(bp->bci(), bp->orig_bytecode());
|
code_at_put(bp->bci(), bp->orig_bytecode());
|
||||||
}
|
}
|
||||||
@ -320,7 +320,7 @@ bool ciMethod::has_balanced_monitors() {
|
|||||||
// ciMethod::get_flow_analysis
|
// ciMethod::get_flow_analysis
|
||||||
ciTypeFlow* ciMethod::get_flow_analysis() {
|
ciTypeFlow* ciMethod::get_flow_analysis() {
|
||||||
#if defined(COMPILER2)
|
#if defined(COMPILER2)
|
||||||
if (_flow == NULL) {
|
if (_flow == nullptr) {
|
||||||
ciEnv* env = CURRENT_ENV;
|
ciEnv* env = CURRENT_ENV;
|
||||||
_flow = new (env->arena()) ciTypeFlow(env, this);
|
_flow = new (env->arena()) ciTypeFlow(env, this);
|
||||||
_flow->do_flow();
|
_flow->do_flow();
|
||||||
@ -328,7 +328,7 @@ ciTypeFlow* ciMethod::get_flow_analysis() {
|
|||||||
return _flow;
|
return _flow;
|
||||||
#else // COMPILER2
|
#else // COMPILER2
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
#endif // COMPILER2
|
#endif // COMPILER2
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -345,7 +345,7 @@ ciTypeFlow* ciMethod::get_osr_flow_analysis(int osr_bci) {
|
|||||||
return flow;
|
return flow;
|
||||||
#else // COMPILER2
|
#else // COMPILER2
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
#endif // COMPILER2
|
#endif // COMPILER2
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -355,7 +355,7 @@ ciTypeFlow* ciMethod::get_osr_flow_analysis(int osr_bci) {
|
|||||||
// Which local variables are live at a specific bci?
|
// Which local variables are live at a specific bci?
|
||||||
MethodLivenessResult ciMethod::raw_liveness_at_bci(int bci) {
|
MethodLivenessResult ciMethod::raw_liveness_at_bci(int bci) {
|
||||||
check_is_loaded();
|
check_is_loaded();
|
||||||
if (_liveness == NULL) {
|
if (_liveness == nullptr) {
|
||||||
// Create the liveness analyzer.
|
// Create the liveness analyzer.
|
||||||
Arena* arena = CURRENT_ENV->arena();
|
Arena* arena = CURRENT_ENV->arena();
|
||||||
_liveness = new (arena) MethodLiveness(arena, this);
|
_liveness = new (arena) MethodLiveness(arena, this);
|
||||||
@ -416,7 +416,7 @@ ResourceBitMap ciMethod::live_local_oops_at_bci(int bci) {
|
|||||||
// Marks all bcis where a new basic block starts
|
// Marks all bcis where a new basic block starts
|
||||||
const BitMap& ciMethod::bci_block_start() {
|
const BitMap& ciMethod::bci_block_start() {
|
||||||
check_is_loaded();
|
check_is_loaded();
|
||||||
if (_liveness == NULL) {
|
if (_liveness == nullptr) {
|
||||||
// Create the liveness analyzer.
|
// Create the liveness analyzer.
|
||||||
Arena* arena = CURRENT_ENV->arena();
|
Arena* arena = CURRENT_ENV->arena();
|
||||||
_liveness = new (arena) MethodLiveness(arena, this);
|
_liveness = new (arena) MethodLiveness(arena, this);
|
||||||
@ -457,9 +457,9 @@ int ciMethod::check_overflow(int c, Bytecodes::Code code) {
|
|||||||
ciCallProfile ciMethod::call_profile_at_bci(int bci) {
|
ciCallProfile ciMethod::call_profile_at_bci(int bci) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
ciCallProfile result;
|
ciCallProfile result;
|
||||||
if (method_data() != NULL && method_data()->is_mature()) {
|
if (method_data() != nullptr && method_data()->is_mature()) {
|
||||||
ciProfileData* data = method_data()->bci_to_data(bci);
|
ciProfileData* data = method_data()->bci_to_data(bci);
|
||||||
if (data != NULL && data->is_CounterData()) {
|
if (data != nullptr && data->is_CounterData()) {
|
||||||
// Every profiled call site has a counter.
|
// Every profiled call site has a counter.
|
||||||
int count = check_overflow(data->as_CounterData()->count(), java_code_at_bci(bci));
|
int count = check_overflow(data->as_CounterData()->count(), java_code_at_bci(bci));
|
||||||
|
|
||||||
@ -473,7 +473,7 @@ ciCallProfile ciMethod::call_profile_at_bci(int bci) {
|
|||||||
// Precompute morphism for the possible fixup
|
// Precompute morphism for the possible fixup
|
||||||
for (uint i = 0; i < call->row_limit(); i++) {
|
for (uint i = 0; i < call->row_limit(); i++) {
|
||||||
ciKlass* receiver = call->receiver(i);
|
ciKlass* receiver = call->receiver(i);
|
||||||
if (receiver == NULL) continue;
|
if (receiver == nullptr) continue;
|
||||||
morphism++;
|
morphism++;
|
||||||
}
|
}
|
||||||
int epsilon = 0;
|
int epsilon = 0;
|
||||||
@ -487,7 +487,7 @@ ciCallProfile ciMethod::call_profile_at_bci(int bci) {
|
|||||||
}
|
}
|
||||||
for (uint i = 0; i < call->row_limit(); i++) {
|
for (uint i = 0; i < call->row_limit(); i++) {
|
||||||
ciKlass* receiver = call->receiver(i);
|
ciKlass* receiver = call->receiver(i);
|
||||||
if (receiver == NULL) continue;
|
if (receiver == nullptr) continue;
|
||||||
int rcount = saturated_add(call->receiver_count(i), epsilon);
|
int rcount = saturated_add(call->receiver_count(i), epsilon);
|
||||||
if (rcount == 0) rcount = 1; // Should be valid value
|
if (rcount == 0) rcount = 1; // Should be valid value
|
||||||
receivers_count_total = saturated_add(receivers_count_total, rcount);
|
receivers_count_total = saturated_add(receivers_count_total, rcount);
|
||||||
@ -564,15 +564,15 @@ void ciMethod::assert_call_type_ok(int bci) {
|
|||||||
*
|
*
|
||||||
* @param [in]bci bci of the call
|
* @param [in]bci bci of the call
|
||||||
* @param [in]i argument number
|
* @param [in]i argument number
|
||||||
* @param [out]type profiled type of argument, NULL if none
|
* @param [out]type profiled type of argument, null if none
|
||||||
* @param [out]ptr_kind whether always null, never null or maybe null
|
* @param [out]ptr_kind whether always null, never null or maybe null
|
||||||
* @return true if profiling exists
|
* @return true if profiling exists
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
bool ciMethod::argument_profiled_type(int bci, int i, ciKlass*& type, ProfilePtrKind& ptr_kind) {
|
bool ciMethod::argument_profiled_type(int bci, int i, ciKlass*& type, ProfilePtrKind& ptr_kind) {
|
||||||
if (MethodData::profile_parameters() && method_data() != NULL && method_data()->is_mature()) {
|
if (MethodData::profile_parameters() && method_data() != nullptr && method_data()->is_mature()) {
|
||||||
ciProfileData* data = method_data()->bci_to_data(bci);
|
ciProfileData* data = method_data()->bci_to_data(bci);
|
||||||
if (data != NULL) {
|
if (data != nullptr) {
|
||||||
if (data->is_VirtualCallTypeData()) {
|
if (data->is_VirtualCallTypeData()) {
|
||||||
assert_virtual_call_type_ok(bci);
|
assert_virtual_call_type_ok(bci);
|
||||||
ciVirtualCallTypeData* call = (ciVirtualCallTypeData*)data->as_VirtualCallTypeData();
|
ciVirtualCallTypeData* call = (ciVirtualCallTypeData*)data->as_VirtualCallTypeData();
|
||||||
@ -602,15 +602,15 @@ bool ciMethod::argument_profiled_type(int bci, int i, ciKlass*& type, ProfilePtr
|
|||||||
* the call at bci bci
|
* the call at bci bci
|
||||||
*
|
*
|
||||||
* @param [in]bci bci of the call
|
* @param [in]bci bci of the call
|
||||||
* @param [out]type profiled type of argument, NULL if none
|
* @param [out]type profiled type of argument, null if none
|
||||||
* @param [out]ptr_kind whether always null, never null or maybe null
|
* @param [out]ptr_kind whether always null, never null or maybe null
|
||||||
* @return true if profiling exists
|
* @return true if profiling exists
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
bool ciMethod::return_profiled_type(int bci, ciKlass*& type, ProfilePtrKind& ptr_kind) {
|
bool ciMethod::return_profiled_type(int bci, ciKlass*& type, ProfilePtrKind& ptr_kind) {
|
||||||
if (MethodData::profile_return() && method_data() != NULL && method_data()->is_mature()) {
|
if (MethodData::profile_return() && method_data() != nullptr && method_data()->is_mature()) {
|
||||||
ciProfileData* data = method_data()->bci_to_data(bci);
|
ciProfileData* data = method_data()->bci_to_data(bci);
|
||||||
if (data != NULL) {
|
if (data != nullptr) {
|
||||||
if (data->is_VirtualCallTypeData()) {
|
if (data->is_VirtualCallTypeData()) {
|
||||||
assert_virtual_call_type_ok(bci);
|
assert_virtual_call_type_ok(bci);
|
||||||
ciVirtualCallTypeData* call = (ciVirtualCallTypeData*)data->as_VirtualCallTypeData();
|
ciVirtualCallTypeData* call = (ciVirtualCallTypeData*)data->as_VirtualCallTypeData();
|
||||||
@ -637,15 +637,15 @@ bool ciMethod::return_profiled_type(int bci, ciKlass*& type, ProfilePtrKind& ptr
|
|||||||
* Check whether profiling provides a type for the parameter i
|
* Check whether profiling provides a type for the parameter i
|
||||||
*
|
*
|
||||||
* @param [in]i parameter number
|
* @param [in]i parameter number
|
||||||
* @param [out]type profiled type of parameter, NULL if none
|
* @param [out]type profiled type of parameter, null if none
|
||||||
* @param [out]ptr_kind whether always null, never null or maybe null
|
* @param [out]ptr_kind whether always null, never null or maybe null
|
||||||
* @return true if profiling exists
|
* @return true if profiling exists
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
bool ciMethod::parameter_profiled_type(int i, ciKlass*& type, ProfilePtrKind& ptr_kind) {
|
bool ciMethod::parameter_profiled_type(int i, ciKlass*& type, ProfilePtrKind& ptr_kind) {
|
||||||
if (MethodData::profile_parameters() && method_data() != NULL && method_data()->is_mature()) {
|
if (MethodData::profile_parameters() && method_data() != nullptr && method_data()->is_mature()) {
|
||||||
ciParametersTypeData* parameters = method_data()->parameters_type_data();
|
ciParametersTypeData* parameters = method_data()->parameters_type_data();
|
||||||
if (parameters != NULL && i < parameters->number_of_parameters()) {
|
if (parameters != nullptr && i < parameters->number_of_parameters()) {
|
||||||
type = parameters->valid_parameter_type(i);
|
type = parameters->valid_parameter_type(i);
|
||||||
ptr_kind = parameters->parameter_ptr_kind(i);
|
ptr_kind = parameters->parameter_ptr_kind(i);
|
||||||
return true;
|
return true;
|
||||||
@ -659,7 +659,7 @@ bool ciMethod::parameter_profiled_type(int i, ciKlass*& type, ProfilePtrKind& pt
|
|||||||
// ciMethod::find_monomorphic_target
|
// ciMethod::find_monomorphic_target
|
||||||
//
|
//
|
||||||
// Given a certain calling environment, find the monomorphic target
|
// Given a certain calling environment, find the monomorphic target
|
||||||
// for the call. Return NULL if the call is not monomorphic in
|
// for the call. Return null if the call is not monomorphic in
|
||||||
// its calling environment, or if there are only abstract methods.
|
// its calling environment, or if there are only abstract methods.
|
||||||
// The returned method is never abstract.
|
// The returned method is never abstract.
|
||||||
// Note: If caller uses a non-null result, it must inform dependencies
|
// Note: If caller uses a non-null result, it must inform dependencies
|
||||||
@ -672,13 +672,13 @@ ciMethod* ciMethod::find_monomorphic_target(ciInstanceKlass* caller,
|
|||||||
|
|
||||||
if (actual_recv->is_interface()) {
|
if (actual_recv->is_interface()) {
|
||||||
// %%% We cannot trust interface types, yet. See bug 6312651.
|
// %%% We cannot trust interface types, yet. See bug 6312651.
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
ciMethod* root_m = resolve_invoke(caller, actual_recv, check_access, true /* allow_abstract */);
|
ciMethod* root_m = resolve_invoke(caller, actual_recv, check_access, true /* allow_abstract */);
|
||||||
if (root_m == NULL) {
|
if (root_m == nullptr) {
|
||||||
// Something went wrong looking up the actual receiver method.
|
// Something went wrong looking up the actual receiver method.
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make certain quick checks even if UseCHA is false.
|
// Make certain quick checks even if UseCHA is false.
|
||||||
@ -693,7 +693,7 @@ ciMethod* ciMethod::find_monomorphic_target(ciInstanceKlass* caller,
|
|||||||
// Easy case. There is no other place to put a method, so don't bother
|
// Easy case. There is no other place to put a method, so don't bother
|
||||||
// to go through the VM_ENTRY_MARK and all the rest.
|
// to go through the VM_ENTRY_MARK and all the rest.
|
||||||
if (root_m->is_abstract()) {
|
if (root_m->is_abstract()) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return root_m;
|
return root_m;
|
||||||
}
|
}
|
||||||
@ -704,7 +704,7 @@ ciMethod* ciMethod::find_monomorphic_target(ciInstanceKlass* caller,
|
|||||||
// The inline_native_clone intrinsic narrows Object to T[] properly,
|
// The inline_native_clone intrinsic narrows Object to T[] properly,
|
||||||
// so there is no need to do the same job here.
|
// so there is no need to do the same job here.
|
||||||
|
|
||||||
if (!UseCHA) return NULL;
|
if (!UseCHA) return nullptr;
|
||||||
|
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
|
|
||||||
@ -719,16 +719,16 @@ ciMethod* ciMethod::find_monomorphic_target(ciInstanceKlass* caller,
|
|||||||
this->get_Method()));
|
this->get_Method()));
|
||||||
} else {
|
} else {
|
||||||
if (root_m->is_abstract()) {
|
if (root_m->is_abstract()) {
|
||||||
return NULL; // not supported
|
return nullptr; // not supported
|
||||||
}
|
}
|
||||||
target = methodHandle(THREAD, Dependencies::find_unique_concrete_method(context, root_m->get_Method()));
|
target = methodHandle(THREAD, Dependencies::find_unique_concrete_method(context, root_m->get_Method()));
|
||||||
}
|
}
|
||||||
assert(target() == NULL || !target()->is_abstract(), "not allowed");
|
assert(target() == nullptr || !target()->is_abstract(), "not allowed");
|
||||||
// %%% Should upgrade this ciMethod API to look for 1 or 2 concrete methods.
|
// %%% Should upgrade this ciMethod API to look for 1 or 2 concrete methods.
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
if (TraceDependencies && target() != NULL && target() != root_m->get_Method()) {
|
if (TraceDependencies && target() != nullptr && target() != root_m->get_Method()) {
|
||||||
tty->print("found a non-root unique target method");
|
tty->print("found a non-root unique target method");
|
||||||
tty->print_cr(" context = %s", actual_recv->get_Klass()->external_name());
|
tty->print_cr(" context = %s", actual_recv->get_Klass()->external_name());
|
||||||
tty->print(" method = ");
|
tty->print(" method = ");
|
||||||
@ -737,8 +737,8 @@ ciMethod* ciMethod::find_monomorphic_target(ciInstanceKlass* caller,
|
|||||||
}
|
}
|
||||||
#endif //PRODUCT
|
#endif //PRODUCT
|
||||||
|
|
||||||
if (target() == NULL) {
|
if (target() == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (target() == root_m->get_Method()) {
|
if (target() == root_m->get_Method()) {
|
||||||
return root_m;
|
return root_m;
|
||||||
@ -748,11 +748,11 @@ ciMethod* ciMethod::find_monomorphic_target(ciInstanceKlass* caller,
|
|||||||
// If we are going to reason about inheritance, it's easiest
|
// If we are going to reason about inheritance, it's easiest
|
||||||
// if the method in question is public, protected, or private.
|
// if the method in question is public, protected, or private.
|
||||||
// If the answer is not root_m, it is conservatively correct
|
// If the answer is not root_m, it is conservatively correct
|
||||||
// to return NULL, even if the CHA encountered irrelevant
|
// to return null, even if the CHA encountered irrelevant
|
||||||
// methods in other packages.
|
// methods in other packages.
|
||||||
// %%% TO DO: Work out logic for package-private methods
|
// %%% TO DO: Work out logic for package-private methods
|
||||||
// with the same name but different vtable indexes.
|
// with the same name but different vtable indexes.
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return CURRENT_THREAD_ENV->get_method(target());
|
return CURRENT_THREAD_ENV->get_method(target());
|
||||||
}
|
}
|
||||||
@ -783,7 +783,7 @@ bool ciMethod::can_omit_stack_trace() const {
|
|||||||
// ciMethod::resolve_invoke
|
// ciMethod::resolve_invoke
|
||||||
//
|
//
|
||||||
// Given a known receiver klass, find the target for the call.
|
// Given a known receiver klass, find the target for the call.
|
||||||
// Return NULL if the call has no target or the target is abstract.
|
// Return null if the call has no target or the target is abstract.
|
||||||
ciMethod* ciMethod::resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, bool check_access, bool allow_abstract) {
|
ciMethod* ciMethod::resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, bool check_access, bool allow_abstract) {
|
||||||
check_is_loaded();
|
check_is_loaded();
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
@ -797,7 +797,7 @@ ciMethod* ciMethod::resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, boo
|
|||||||
LinkInfo link_info(resolved, h_name, h_signature, caller_klass,
|
LinkInfo link_info(resolved, h_name, h_signature, caller_klass,
|
||||||
check_access ? LinkInfo::AccessCheck::required : LinkInfo::AccessCheck::skip,
|
check_access ? LinkInfo::AccessCheck::required : LinkInfo::AccessCheck::skip,
|
||||||
check_access ? LinkInfo::LoaderConstraintCheck::required : LinkInfo::LoaderConstraintCheck::skip);
|
check_access ? LinkInfo::LoaderConstraintCheck::required : LinkInfo::LoaderConstraintCheck::skip);
|
||||||
Method* m = NULL;
|
Method* m = nullptr;
|
||||||
// Only do exact lookup if receiver klass has been linked. Otherwise,
|
// Only do exact lookup if receiver klass has been linked. Otherwise,
|
||||||
// the vtable has not been setup, and the LinkResolver will fail.
|
// the vtable has not been setup, and the LinkResolver will fail.
|
||||||
if (recv->is_array_klass()
|
if (recv->is_array_klass()
|
||||||
@ -810,9 +810,9 @@ ciMethod* ciMethod::resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, boo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m == NULL) {
|
if (m == nullptr) {
|
||||||
// Return NULL only if there was a problem with lookup (uninitialized class, etc.)
|
// Return null only if there was a problem with lookup (uninitialized class, etc.)
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
ciMethod* result = this;
|
ciMethod* result = this;
|
||||||
@ -822,7 +822,7 @@ ciMethod* ciMethod::resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, boo
|
|||||||
|
|
||||||
if (result->is_abstract() && !allow_abstract) {
|
if (result->is_abstract() && !allow_abstract) {
|
||||||
// Don't return abstract methods because they aren't optimizable or interesting.
|
// Don't return abstract methods because they aren't optimizable or interesting.
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -893,7 +893,7 @@ ciKlass* ciMethod::get_declared_method_holder_at_bci(int bci) {
|
|||||||
// they can be usefully and stably compared against the
|
// they can be usefully and stably compared against the
|
||||||
// invocation counts in methods.
|
// invocation counts in methods.
|
||||||
int ciMethod::scale_count(int count, float prof_factor) {
|
int ciMethod::scale_count(int count, float prof_factor) {
|
||||||
if (count > 0 && method_data() != NULL) {
|
if (count > 0 && method_data() != nullptr) {
|
||||||
int counter_life = method_data()->invocation_count();
|
int counter_life = method_data()->invocation_count();
|
||||||
int method_life = interpreter_invocation_count();
|
int method_life = interpreter_invocation_count();
|
||||||
if (method_life < counter_life) { // may happen because of the snapshot timing
|
if (method_life < counter_life) { // may happen because of the snapshot timing
|
||||||
@ -979,13 +979,13 @@ bool ciMethod::ensure_method_data(const methodHandle& h_m) {
|
|||||||
if (is_native() || is_abstract() || h_m()->is_accessor()) {
|
if (is_native() || is_abstract() || h_m()->is_accessor()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (h_m()->method_data() == NULL) {
|
if (h_m()->method_data() == nullptr) {
|
||||||
Method::build_profiling_method_data(h_m, THREAD);
|
Method::build_profiling_method_data(h_m, THREAD);
|
||||||
if (HAS_PENDING_EXCEPTION) {
|
if (HAS_PENDING_EXCEPTION) {
|
||||||
CLEAR_PENDING_EXCEPTION;
|
CLEAR_PENDING_EXCEPTION;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (h_m()->method_data() != NULL) {
|
if (h_m()->method_data() != nullptr) {
|
||||||
_method_data = CURRENT_ENV->get_method_data(h_m()->method_data());
|
_method_data = CURRENT_ENV->get_method_data(h_m()->method_data());
|
||||||
return _method_data->load_data();
|
return _method_data->load_data();
|
||||||
} else {
|
} else {
|
||||||
@ -997,7 +997,7 @@ bool ciMethod::ensure_method_data(const methodHandle& h_m) {
|
|||||||
// public, retroactive version
|
// public, retroactive version
|
||||||
bool ciMethod::ensure_method_data() {
|
bool ciMethod::ensure_method_data() {
|
||||||
bool result = true;
|
bool result = true;
|
||||||
if (_method_data == NULL || _method_data->is_empty()) {
|
if (_method_data == nullptr || _method_data->is_empty()) {
|
||||||
GUARDED_VM_ENTRY({
|
GUARDED_VM_ENTRY({
|
||||||
methodHandle mh(Thread::current(), get_Method());
|
methodHandle mh(Thread::current(), get_Method());
|
||||||
result = ensure_method_data(mh);
|
result = ensure_method_data(mh);
|
||||||
@ -1011,7 +1011,7 @@ bool ciMethod::ensure_method_data() {
|
|||||||
// ciMethod::method_data
|
// ciMethod::method_data
|
||||||
//
|
//
|
||||||
ciMethodData* ciMethod::method_data() {
|
ciMethodData* ciMethod::method_data() {
|
||||||
if (_method_data != NULL) {
|
if (_method_data != nullptr) {
|
||||||
return _method_data;
|
return _method_data;
|
||||||
}
|
}
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
@ -1019,7 +1019,7 @@ ciMethodData* ciMethod::method_data() {
|
|||||||
Thread* my_thread = JavaThread::current();
|
Thread* my_thread = JavaThread::current();
|
||||||
methodHandle h_m(my_thread, get_Method());
|
methodHandle h_m(my_thread, get_Method());
|
||||||
|
|
||||||
if (h_m()->method_data() != NULL) {
|
if (h_m()->method_data() != nullptr) {
|
||||||
_method_data = CURRENT_ENV->get_method_data(h_m()->method_data());
|
_method_data = CURRENT_ENV->get_method_data(h_m()->method_data());
|
||||||
_method_data->load_data();
|
_method_data->load_data();
|
||||||
} else {
|
} else {
|
||||||
@ -1032,11 +1032,11 @@ ciMethodData* ciMethod::method_data() {
|
|||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciMethod::method_data_or_null
|
// ciMethod::method_data_or_null
|
||||||
// Returns a pointer to ciMethodData if MDO exists on the VM side,
|
// Returns a pointer to ciMethodData if MDO exists on the VM side,
|
||||||
// NULL otherwise.
|
// null otherwise.
|
||||||
ciMethodData* ciMethod::method_data_or_null() {
|
ciMethodData* ciMethod::method_data_or_null() {
|
||||||
ciMethodData *md = method_data();
|
ciMethodData *md = method_data();
|
||||||
if (md->is_empty()) {
|
if (md->is_empty()) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return md;
|
return md;
|
||||||
}
|
}
|
||||||
@ -1123,7 +1123,7 @@ int ciMethod::inline_instructions_size() {
|
|||||||
if (_inline_instructions_size == -1) {
|
if (_inline_instructions_size == -1) {
|
||||||
GUARDED_VM_ENTRY(
|
GUARDED_VM_ENTRY(
|
||||||
CompiledMethod* code = get_Method()->code();
|
CompiledMethod* code = get_Method()->code();
|
||||||
if (code != NULL && (code->comp_level() == CompLevel_full_optimization)) {
|
if (code != nullptr && (code->comp_level() == CompLevel_full_optimization)) {
|
||||||
int isize = code->insts_end() - code->verified_entry_point() - code->skipped_instructions_size();
|
int isize = code->insts_end() - code->verified_entry_point() - code->skipped_instructions_size();
|
||||||
_inline_instructions_size = isize > 0 ? isize : 0;
|
_inline_instructions_size = isize > 0 ? isize : 0;
|
||||||
} else {
|
} else {
|
||||||
@ -1139,7 +1139,7 @@ int ciMethod::inline_instructions_size() {
|
|||||||
void ciMethod::log_nmethod_identity(xmlStream* log) {
|
void ciMethod::log_nmethod_identity(xmlStream* log) {
|
||||||
GUARDED_VM_ENTRY(
|
GUARDED_VM_ENTRY(
|
||||||
CompiledMethod* code = get_Method()->code();
|
CompiledMethod* code = get_Method()->code();
|
||||||
if (code != NULL) {
|
if (code != nullptr) {
|
||||||
code->log_identity(log);
|
code->log_identity(log);
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
@ -1271,18 +1271,18 @@ bool ciMethod::is_vector_method() const {
|
|||||||
|
|
||||||
BCEscapeAnalyzer *ciMethod::get_bcea() {
|
BCEscapeAnalyzer *ciMethod::get_bcea() {
|
||||||
#ifdef COMPILER2
|
#ifdef COMPILER2
|
||||||
if (_bcea == NULL) {
|
if (_bcea == nullptr) {
|
||||||
_bcea = new (CURRENT_ENV->arena()) BCEscapeAnalyzer(this, NULL);
|
_bcea = new (CURRENT_ENV->arena()) BCEscapeAnalyzer(this, nullptr);
|
||||||
}
|
}
|
||||||
return _bcea;
|
return _bcea;
|
||||||
#else // COMPILER2
|
#else // COMPILER2
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
#endif // COMPILER2
|
#endif // COMPILER2
|
||||||
}
|
}
|
||||||
|
|
||||||
ciMethodBlocks *ciMethod::get_method_blocks() {
|
ciMethodBlocks *ciMethod::get_method_blocks() {
|
||||||
if (_method_blocks == NULL) {
|
if (_method_blocks == nullptr) {
|
||||||
Arena *arena = CURRENT_ENV->arena();
|
Arena *arena = CURRENT_ENV->arena();
|
||||||
_method_blocks = new (arena) ciMethodBlocks(arena, this);
|
_method_blocks = new (arena) ciMethodBlocks(arena, this);
|
||||||
}
|
}
|
||||||
@ -1314,8 +1314,8 @@ void ciMethod::dump_replay_data(outputStream* st) {
|
|||||||
st->print("ciMethod ");
|
st->print("ciMethod ");
|
||||||
dump_name_as_ascii(st);
|
dump_name_as_ascii(st);
|
||||||
st->print_cr(" %d %d %d %d %d",
|
st->print_cr(" %d %d %d %d %d",
|
||||||
mcs == NULL ? 0 : mcs->invocation_counter()->raw_counter(),
|
mcs == nullptr ? 0 : mcs->invocation_counter()->raw_counter(),
|
||||||
mcs == NULL ? 0 : mcs->backedge_counter()->raw_counter(),
|
mcs == nullptr ? 0 : mcs->backedge_counter()->raw_counter(),
|
||||||
interpreter_invocation_count(),
|
interpreter_invocation_count(),
|
||||||
interpreter_throwout_count(),
|
interpreter_throwout_count(),
|
||||||
_inline_instructions_size);
|
_inline_instructions_size);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -175,12 +175,12 @@ class ciMethod : public ciMetadata {
|
|||||||
|
|
||||||
Method* get_Method() const {
|
Method* get_Method() const {
|
||||||
Method* m = (Method*)_metadata;
|
Method* m = (Method*)_metadata;
|
||||||
assert(m != NULL, "illegal use of unloaded method");
|
assert(m != nullptr, "illegal use of unloaded method");
|
||||||
return m;
|
return m;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Method code and related information.
|
// Method code and related information.
|
||||||
address code() { if (_code == NULL) load_code(); return _code; }
|
address code() { if (_code == nullptr) load_code(); return _code; }
|
||||||
int code_size() const { check_is_loaded(); return _code_size; }
|
int code_size() const { check_is_loaded(); return _code_size; }
|
||||||
int max_stack() const { check_is_loaded(); return _max_stack; }
|
int max_stack() const { check_is_loaded(); return _max_stack; }
|
||||||
int max_locals() const { check_is_loaded(); return _max_locals; }
|
int max_locals() const { check_is_loaded(); return _max_locals; }
|
||||||
@ -214,11 +214,11 @@ class ciMethod : public ciMetadata {
|
|||||||
|
|
||||||
Bytecodes::Code java_code_at_bci(int bci) {
|
Bytecodes::Code java_code_at_bci(int bci) {
|
||||||
address bcp = code() + bci;
|
address bcp = code() + bci;
|
||||||
return Bytecodes::java_code_at(NULL, bcp);
|
return Bytecodes::java_code_at(nullptr, bcp);
|
||||||
}
|
}
|
||||||
Bytecodes::Code raw_code_at_bci(int bci) {
|
Bytecodes::Code raw_code_at_bci(int bci) {
|
||||||
address bcp = code() + bci;
|
address bcp = code() + bci;
|
||||||
return Bytecodes::code_at(NULL, bcp);
|
return Bytecodes::code_at(nullptr, bcp);
|
||||||
}
|
}
|
||||||
BCEscapeAnalyzer *get_bcea();
|
BCEscapeAnalyzer *get_bcea();
|
||||||
ciMethodBlocks *get_method_blocks();
|
ciMethodBlocks *get_method_blocks();
|
||||||
@ -283,12 +283,12 @@ class ciMethod : public ciMetadata {
|
|||||||
bool ignored_will_link;
|
bool ignored_will_link;
|
||||||
ciSignature* declared_signature;
|
ciSignature* declared_signature;
|
||||||
get_method_at_bci(bci, ignored_will_link, &declared_signature);
|
get_method_at_bci(bci, ignored_will_link, &declared_signature);
|
||||||
assert(declared_signature != NULL, "cannot be null");
|
assert(declared_signature != nullptr, "cannot be null");
|
||||||
return declared_signature;
|
return declared_signature;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Given a certain calling environment, find the monomorphic target
|
// Given a certain calling environment, find the monomorphic target
|
||||||
// for the call. Return NULL if the call is not monomorphic in
|
// for the call. Return null if the call is not monomorphic in
|
||||||
// its calling environment.
|
// its calling environment.
|
||||||
ciMethod* find_monomorphic_target(ciInstanceKlass* caller,
|
ciMethod* find_monomorphic_target(ciInstanceKlass* caller,
|
||||||
ciInstanceKlass* callee_holder,
|
ciInstanceKlass* callee_holder,
|
||||||
@ -296,7 +296,7 @@ class ciMethod : public ciMetadata {
|
|||||||
bool check_access = true);
|
bool check_access = true);
|
||||||
|
|
||||||
// Given a known receiver klass, find the target for the call.
|
// Given a known receiver klass, find the target for the call.
|
||||||
// Return NULL if the call has no target or is abstract.
|
// Return null if the call has no target or is abstract.
|
||||||
ciMethod* resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, bool check_access = true, bool allow_abstract = false);
|
ciMethod* resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, bool check_access = true, bool allow_abstract = false);
|
||||||
|
|
||||||
// Find the proper vtable index to invoke this method.
|
// Find the proper vtable index to invoke this method.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2006, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2006, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,7 +41,7 @@ ciBlock *ciMethodBlocks::block_containing(int bci) {
|
|||||||
bool ciMethodBlocks::is_block_start(int bci) {
|
bool ciMethodBlocks::is_block_start(int bci) {
|
||||||
assert(bci >= 0 && bci < _code_size, "valid bytecode range");
|
assert(bci >= 0 && bci < _code_size, "valid bytecode range");
|
||||||
ciBlock *b = _bci_to_block[bci];
|
ciBlock *b = _bci_to_block[bci];
|
||||||
assert(b != NULL, "must have block for bytecode");
|
assert(b != nullptr, "must have block for bytecode");
|
||||||
return b->start_bci() == bci;
|
return b->start_bci() == bci;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -55,7 +55,7 @@ ciBlock *ciMethodBlocks::split_block_at(int bci) {
|
|||||||
ciBlock *former_block = block_containing(bci);
|
ciBlock *former_block = block_containing(bci);
|
||||||
ciBlock *new_block = new(_arena) ciBlock(_method, _num_blocks++, former_block->start_bci());
|
ciBlock *new_block = new(_arena) ciBlock(_method, _num_blocks++, former_block->start_bci());
|
||||||
_blocks->append(new_block);
|
_blocks->append(new_block);
|
||||||
assert(former_block != NULL, "must not be NULL");
|
assert(former_block != nullptr, "must not be nullptr");
|
||||||
new_block->set_limit_bci(bci);
|
new_block->set_limit_bci(bci);
|
||||||
former_block->set_start_bci(bci);
|
former_block->set_start_bci(bci);
|
||||||
for (int pos=bci-1; pos >= 0; pos--) {
|
for (int pos=bci-1; pos >= 0; pos--) {
|
||||||
@ -63,7 +63,7 @@ ciBlock *ciMethodBlocks::split_block_at(int bci) {
|
|||||||
if (current_block == former_block) {
|
if (current_block == former_block) {
|
||||||
// Replace it.
|
// Replace it.
|
||||||
_bci_to_block[pos] = new_block;
|
_bci_to_block[pos] = new_block;
|
||||||
} else if (current_block == NULL) {
|
} else if (current_block == nullptr) {
|
||||||
// Non-bytecode start. Skip.
|
// Non-bytecode start. Skip.
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
@ -84,7 +84,7 @@ ciBlock *ciMethodBlocks::split_block_at(int bci) {
|
|||||||
|
|
||||||
ciBlock *ciMethodBlocks::make_block_at(int bci) {
|
ciBlock *ciMethodBlocks::make_block_at(int bci) {
|
||||||
ciBlock *cb = block_containing(bci);
|
ciBlock *cb = block_containing(bci);
|
||||||
if (cb == NULL ) {
|
if (cb == nullptr ) {
|
||||||
// This is our first time visiting this bytecode. Create
|
// This is our first time visiting this bytecode. Create
|
||||||
// a fresh block and assign it this starting point.
|
// a fresh block and assign it this starting point.
|
||||||
ciBlock *nb = new(_arena) ciBlock(_method, _num_blocks++, bci);
|
ciBlock *nb = new(_arena) ciBlock(_method, _num_blocks++, bci);
|
||||||
@ -117,9 +117,9 @@ void ciMethodBlocks::do_analysis() {
|
|||||||
// Determine if a new block has been made at the current bci. If
|
// Determine if a new block has been made at the current bci. If
|
||||||
// this block differs from our current range, switch to the new
|
// this block differs from our current range, switch to the new
|
||||||
// one and end the old one.
|
// one and end the old one.
|
||||||
assert(cur_block != NULL, "must always have a current block");
|
assert(cur_block != nullptr, "must always have a current block");
|
||||||
ciBlock *new_block = block_containing(bci);
|
ciBlock *new_block = block_containing(bci);
|
||||||
if (new_block == NULL || new_block == cur_block) {
|
if (new_block == nullptr || new_block == cur_block) {
|
||||||
// We have not marked this bci as the start of a new block.
|
// We have not marked this bci as the start of a new block.
|
||||||
// Keep interpreting the current_range.
|
// Keep interpreting the current_range.
|
||||||
_bci_to_block[bci] = cur_block;
|
_bci_to_block[bci] = cur_block;
|
||||||
@ -265,7 +265,7 @@ ciMethodBlocks::ciMethodBlocks(Arena *arena, ciMethod *meth): _method(meth),
|
|||||||
_arena(arena), _num_blocks(0), _code_size(meth->code_size()) {
|
_arena(arena), _num_blocks(0), _code_size(meth->code_size()) {
|
||||||
int block_estimate = _code_size / 8;
|
int block_estimate = _code_size / 8;
|
||||||
|
|
||||||
_blocks = new(_arena) GrowableArray<ciBlock *>(_arena, block_estimate, 0, NULL);
|
_blocks = new(_arena) GrowableArray<ciBlock *>(_arena, block_estimate, 0, nullptr);
|
||||||
int b2bsize = _code_size * sizeof(ciBlock **);
|
int b2bsize = _code_size * sizeof(ciBlock **);
|
||||||
_bci_to_block = (ciBlock **) arena->Amalloc(b2bsize);
|
_bci_to_block = (ciBlock **) arena->Amalloc(b2bsize);
|
||||||
Copy::zero_to_words((HeapWord*) _bci_to_block, b2bsize / sizeof(HeapWord));
|
Copy::zero_to_words((HeapWord*) _bci_to_block, b2bsize / sizeof(HeapWord));
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,7 +41,7 @@
|
|||||||
//
|
//
|
||||||
ciMethodData::ciMethodData(MethodData* md)
|
ciMethodData::ciMethodData(MethodData* md)
|
||||||
: ciMetadata(md),
|
: ciMetadata(md),
|
||||||
_data_size(0), _extra_data_size(0), _data(NULL),
|
_data_size(0), _extra_data_size(0), _data(nullptr),
|
||||||
// Set an initial hint. Don't use set_hint_di() because
|
// Set an initial hint. Don't use set_hint_di() because
|
||||||
// first_di() may be out of bounds if data_size is 0.
|
// first_di() may be out of bounds if data_size is 0.
|
||||||
_hint_di(first_di()),
|
_hint_di(first_di()),
|
||||||
@ -51,7 +51,7 @@ ciMethodData::ciMethodData(MethodData* md)
|
|||||||
_eflags(0), _arg_local(0), _arg_stack(0), _arg_returned(0),
|
_eflags(0), _arg_local(0), _arg_stack(0), _arg_returned(0),
|
||||||
_invocation_counter(0),
|
_invocation_counter(0),
|
||||||
_orig(),
|
_orig(),
|
||||||
_parameters(NULL) {}
|
_parameters(nullptr) {}
|
||||||
|
|
||||||
// Check for entries that reference an unloaded method
|
// Check for entries that reference an unloaded method
|
||||||
class PrepareExtraDataClosure : public CleanExtraDataClosure {
|
class PrepareExtraDataClosure : public CleanExtraDataClosure {
|
||||||
@ -70,7 +70,7 @@ public:
|
|||||||
if (!m->method_holder()->is_loader_alive()) {
|
if (!m->method_holder()->is_loader_alive()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (CURRENT_ENV->cached_metadata(m) == NULL) {
|
if (CURRENT_ENV->cached_metadata(m) == nullptr) {
|
||||||
// Uncached entries need to be pre-populated.
|
// Uncached entries need to be pre-populated.
|
||||||
_uncached_methods.append(m);
|
_uncached_methods.append(m);
|
||||||
}
|
}
|
||||||
@ -169,7 +169,7 @@ void ciMethodData::load_remaining_extra_data() {
|
|||||||
|
|
||||||
bool ciMethodData::load_data() {
|
bool ciMethodData::load_data() {
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if (mdo == NULL) {
|
if (mdo == nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -236,7 +236,7 @@ bool ciMethodData::load_data() {
|
|||||||
ci_data = next_data(ci_data);
|
ci_data = next_data(ci_data);
|
||||||
data = mdo->next_data(data);
|
data = mdo->next_data(data);
|
||||||
}
|
}
|
||||||
if (mdo->parameters_type_data() != NULL) {
|
if (mdo->parameters_type_data() != nullptr) {
|
||||||
_parameters = data_layout_at(mdo->parameters_type_data_di());
|
_parameters = data_layout_at(mdo->parameters_type_data_di());
|
||||||
ciParametersTypeData* parameters = new ciParametersTypeData(_parameters);
|
ciParametersTypeData* parameters = new ciParametersTypeData(_parameters);
|
||||||
parameters->translate_from(mdo->parameters_type_data());
|
parameters->translate_from(mdo->parameters_type_data());
|
||||||
@ -273,7 +273,7 @@ bool ciMethodData::load_data() {
|
|||||||
void ciReceiverTypeData::translate_receiver_data_from(const ProfileData* data) {
|
void ciReceiverTypeData::translate_receiver_data_from(const ProfileData* data) {
|
||||||
for (uint row = 0; row < row_limit(); row++) {
|
for (uint row = 0; row < row_limit(); row++) {
|
||||||
Klass* k = data->as_ReceiverTypeData()->receiver(row);
|
Klass* k = data->as_ReceiverTypeData()->receiver(row);
|
||||||
if (k != NULL) {
|
if (k != nullptr) {
|
||||||
if (k->is_loader_alive()) {
|
if (k->is_loader_alive()) {
|
||||||
ciKlass* klass = CURRENT_ENV->get_klass(k);
|
ciKlass* klass = CURRENT_ENV->get_klass(k);
|
||||||
set_receiver(row, klass);
|
set_receiver(row, klass);
|
||||||
@ -282,7 +282,7 @@ void ciReceiverTypeData::translate_receiver_data_from(const ProfileData* data) {
|
|||||||
clear_row(row);
|
clear_row(row);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
set_receiver(row, NULL);
|
set_receiver(row, nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -291,9 +291,9 @@ void ciTypeStackSlotEntries::translate_type_data_from(const TypeStackSlotEntries
|
|||||||
for (int i = 0; i < number_of_entries(); i++) {
|
for (int i = 0; i < number_of_entries(); i++) {
|
||||||
intptr_t k = entries->type(i);
|
intptr_t k = entries->type(i);
|
||||||
Klass* klass = (Klass*)klass_part(k);
|
Klass* klass = (Klass*)klass_part(k);
|
||||||
if (klass != NULL && !klass->is_loader_alive()) {
|
if (klass != nullptr && !klass->is_loader_alive()) {
|
||||||
// With concurrent class unloading, the MDO could have stale metadata; override it
|
// With concurrent class unloading, the MDO could have stale metadata; override it
|
||||||
TypeStackSlotEntries::set_type(i, TypeStackSlotEntries::with_status((Klass*)NULL, k));
|
TypeStackSlotEntries::set_type(i, TypeStackSlotEntries::with_status((Klass*)nullptr, k));
|
||||||
} else {
|
} else {
|
||||||
TypeStackSlotEntries::set_type(i, translate_klass(k));
|
TypeStackSlotEntries::set_type(i, translate_klass(k));
|
||||||
}
|
}
|
||||||
@ -303,9 +303,9 @@ void ciTypeStackSlotEntries::translate_type_data_from(const TypeStackSlotEntries
|
|||||||
void ciReturnTypeEntry::translate_type_data_from(const ReturnTypeEntry* ret) {
|
void ciReturnTypeEntry::translate_type_data_from(const ReturnTypeEntry* ret) {
|
||||||
intptr_t k = ret->type();
|
intptr_t k = ret->type();
|
||||||
Klass* klass = (Klass*)klass_part(k);
|
Klass* klass = (Klass*)klass_part(k);
|
||||||
if (klass != NULL && !klass->is_loader_alive()) {
|
if (klass != nullptr && !klass->is_loader_alive()) {
|
||||||
// With concurrent class unloading, the MDO could have stale metadata; override it
|
// With concurrent class unloading, the MDO could have stale metadata; override it
|
||||||
set_type(ReturnTypeEntry::with_status((Klass*)NULL, k));
|
set_type(ReturnTypeEntry::with_status((Klass*)nullptr, k));
|
||||||
} else {
|
} else {
|
||||||
set_type(translate_klass(k));
|
set_type(translate_klass(k));
|
||||||
}
|
}
|
||||||
@ -320,7 +320,7 @@ void ciSpeculativeTrapData::translate_from(const ProfileData* data) {
|
|||||||
// Get the data at an arbitrary (sort of) data index.
|
// Get the data at an arbitrary (sort of) data index.
|
||||||
ciProfileData* ciMethodData::data_at(int data_index) {
|
ciProfileData* ciMethodData::data_at(int data_index) {
|
||||||
if (out_of_bounds(data_index)) {
|
if (out_of_bounds(data_index)) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
DataLayout* data_layout = data_layout_at(data_index);
|
DataLayout* data_layout = data_layout_at(data_index);
|
||||||
return data_from(data_layout);
|
return data_from(data_layout);
|
||||||
@ -331,7 +331,7 @@ ciProfileData* ciMethodData::data_from(DataLayout* data_layout) {
|
|||||||
case DataLayout::no_tag:
|
case DataLayout::no_tag:
|
||||||
default:
|
default:
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
case DataLayout::bit_data_tag:
|
case DataLayout::bit_data_tag:
|
||||||
return new ciBitData(data_layout);
|
return new ciBitData(data_layout);
|
||||||
case DataLayout::counter_data_tag:
|
case DataLayout::counter_data_tag:
|
||||||
@ -371,7 +371,7 @@ DataLayout* ciMethodData::next_data_layout(DataLayout* current) {
|
|||||||
int current_index = dp_to_di((address)current);
|
int current_index = dp_to_di((address)current);
|
||||||
int next_index = current_index + current->size_in_bytes();
|
int next_index = current_index + current->size_in_bytes();
|
||||||
if (out_of_bounds(next_index)) {
|
if (out_of_bounds(next_index)) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
DataLayout* next = data_layout_at(next_index);
|
DataLayout* next = data_layout_at(next_index);
|
||||||
return next;
|
return next;
|
||||||
@ -386,11 +386,11 @@ ciProfileData* ciMethodData::bci_to_extra_data(int bci, ciMethod* m, bool& two_f
|
|||||||
case DataLayout::no_tag:
|
case DataLayout::no_tag:
|
||||||
_saw_free_extra_data = true; // observed an empty slot (common case)
|
_saw_free_extra_data = true; // observed an empty slot (common case)
|
||||||
two_free_slots = (MethodData::next_extra(dp)->tag() == DataLayout::no_tag);
|
two_free_slots = (MethodData::next_extra(dp)->tag() == DataLayout::no_tag);
|
||||||
return NULL;
|
return nullptr;
|
||||||
case DataLayout::arg_info_data_tag:
|
case DataLayout::arg_info_data_tag:
|
||||||
return NULL; // ArgInfoData is after the trap data right before the parameter data.
|
return nullptr; // ArgInfoData is after the trap data right before the parameter data.
|
||||||
case DataLayout::bit_data_tag:
|
case DataLayout::bit_data_tag:
|
||||||
if (m == NULL && dp->bci() == bci) {
|
if (m == nullptr && dp->bci() == bci) {
|
||||||
return new ciBitData(dp);
|
return new ciBitData(dp);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -398,7 +398,7 @@ ciProfileData* ciMethodData::bci_to_extra_data(int bci, ciMethod* m, bool& two_f
|
|||||||
ciSpeculativeTrapData* data = new ciSpeculativeTrapData(dp);
|
ciSpeculativeTrapData* data = new ciSpeculativeTrapData(dp);
|
||||||
// data->method() might be null if the MDO is snapshotted
|
// data->method() might be null if the MDO is snapshotted
|
||||||
// concurrently with a trap
|
// concurrently with a trap
|
||||||
if (m != NULL && data->method() == m && dp->bci() == bci) {
|
if (m != nullptr && data->method() == m && dp->bci() == bci) {
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -407,13 +407,13 @@ ciProfileData* ciMethodData::bci_to_extra_data(int bci, ciMethod* m, bool& two_f
|
|||||||
fatal("bad tag = %d", dp->tag());
|
fatal("bad tag = %d", dp->tag());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Translate a bci to its corresponding data, or NULL.
|
// Translate a bci to its corresponding data, or nullptr.
|
||||||
ciProfileData* ciMethodData::bci_to_data(int bci, ciMethod* m) {
|
ciProfileData* ciMethodData::bci_to_data(int bci, ciMethod* m) {
|
||||||
// If m is not NULL we look for a SpeculativeTrapData entry
|
// If m is not nullptr we look for a SpeculativeTrapData entry
|
||||||
if (m == NULL) {
|
if (m == nullptr) {
|
||||||
DataLayout* data_layout = data_layout_before(bci);
|
DataLayout* data_layout = data_layout_before(bci);
|
||||||
for ( ; is_valid(data_layout); data_layout = next_data_layout(data_layout)) {
|
for ( ; is_valid(data_layout); data_layout = next_data_layout(data_layout)) {
|
||||||
if (data_layout->bci() == bci) {
|
if (data_layout->bci() == bci) {
|
||||||
@ -426,16 +426,16 @@ ciProfileData* ciMethodData::bci_to_data(int bci, ciMethod* m) {
|
|||||||
}
|
}
|
||||||
bool two_free_slots = false;
|
bool two_free_slots = false;
|
||||||
ciProfileData* result = bci_to_extra_data(bci, m, two_free_slots);
|
ciProfileData* result = bci_to_extra_data(bci, m, two_free_slots);
|
||||||
if (result != NULL) {
|
if (result != nullptr) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
if (m != NULL && !two_free_slots) {
|
if (m != nullptr && !two_free_slots) {
|
||||||
// We were looking for a SpeculativeTrapData entry we didn't
|
// We were looking for a SpeculativeTrapData entry we didn't
|
||||||
// find. Room is not available for more SpeculativeTrapData
|
// find. Room is not available for more SpeculativeTrapData
|
||||||
// entries, look in the non SpeculativeTrapData entries.
|
// entries, look in the non SpeculativeTrapData entries.
|
||||||
return bci_to_data(bci, NULL);
|
return bci_to_data(bci, nullptr);
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Conservatively decode the trap_state of a ciProfileData.
|
// Conservatively decode the trap_state of a ciProfileData.
|
||||||
@ -450,7 +450,7 @@ int ciMethodData::has_trap_at(ciProfileData* data, int reason) {
|
|||||||
} else if (per_bc_reason == Deoptimization::Reason_none) {
|
} else if (per_bc_reason == Deoptimization::Reason_none) {
|
||||||
// We cannot conclude anything; a trap happened somewhere, maybe here.
|
// We cannot conclude anything; a trap happened somewhere, maybe here.
|
||||||
return -1;
|
return -1;
|
||||||
} else if (data == NULL) {
|
} else if (data == nullptr) {
|
||||||
// No profile here, not even an extra_data record allocated on the fly.
|
// No profile here, not even an extra_data record allocated on the fly.
|
||||||
// If there are empty extra_data records, and there had been a trap,
|
// If there are empty extra_data records, and there had been a trap,
|
||||||
// there would have been a non-null data pointer. If there are no
|
// there would have been a non-null data pointer. If there are no
|
||||||
@ -465,7 +465,7 @@ int ciMethodData::has_trap_at(ciProfileData* data, int reason) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int ciMethodData::trap_recompiled_at(ciProfileData* data) {
|
int ciMethodData::trap_recompiled_at(ciProfileData* data) {
|
||||||
if (data == NULL) {
|
if (data == nullptr) {
|
||||||
return (_saw_free_extra_data? 0: -1); // (see previous method)
|
return (_saw_free_extra_data? 0: -1); // (see previous method)
|
||||||
} else {
|
} else {
|
||||||
return Deoptimization::trap_state_is_recompiled(data->trap_state())? 1: 0;
|
return Deoptimization::trap_state_is_recompiled(data->trap_state())? 1: 0;
|
||||||
@ -475,10 +475,10 @@ int ciMethodData::trap_recompiled_at(ciProfileData* data) {
|
|||||||
void ciMethodData::clear_escape_info() {
|
void ciMethodData::clear_escape_info() {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if (mdo != NULL) {
|
if (mdo != nullptr) {
|
||||||
mdo->clear_escape_info();
|
mdo->clear_escape_info();
|
||||||
ArgInfoData *aid = arg_info();
|
ArgInfoData *aid = arg_info();
|
||||||
int arg_count = (aid == NULL) ? 0 : aid->number_of_args();
|
int arg_count = (aid == nullptr) ? 0 : aid->number_of_args();
|
||||||
for (int i = 0; i < arg_count; i++) {
|
for (int i = 0; i < arg_count; i++) {
|
||||||
set_arg_modified(i, 0);
|
set_arg_modified(i, 0);
|
||||||
}
|
}
|
||||||
@ -490,7 +490,7 @@ void ciMethodData::clear_escape_info() {
|
|||||||
void ciMethodData::update_escape_info() {
|
void ciMethodData::update_escape_info() {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if ( mdo != NULL) {
|
if ( mdo != nullptr) {
|
||||||
mdo->set_eflags(_eflags);
|
mdo->set_eflags(_eflags);
|
||||||
mdo->set_arg_local(_arg_local);
|
mdo->set_arg_local(_arg_local);
|
||||||
mdo->set_arg_stack(_arg_stack);
|
mdo->set_arg_stack(_arg_stack);
|
||||||
@ -505,7 +505,7 @@ void ciMethodData::update_escape_info() {
|
|||||||
void ciMethodData::set_compilation_stats(short loops, short blocks) {
|
void ciMethodData::set_compilation_stats(short loops, short blocks) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if (mdo != NULL) {
|
if (mdo != nullptr) {
|
||||||
mdo->set_num_loops(loops);
|
mdo->set_num_loops(loops);
|
||||||
mdo->set_num_blocks(blocks);
|
mdo->set_num_blocks(blocks);
|
||||||
}
|
}
|
||||||
@ -514,7 +514,7 @@ void ciMethodData::set_compilation_stats(short loops, short blocks) {
|
|||||||
void ciMethodData::set_would_profile(bool p) {
|
void ciMethodData::set_would_profile(bool p) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if (mdo != NULL) {
|
if (mdo != nullptr) {
|
||||||
mdo->set_would_profile(p);
|
mdo->set_would_profile(p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -522,9 +522,9 @@ void ciMethodData::set_would_profile(bool p) {
|
|||||||
void ciMethodData::set_argument_type(int bci, int i, ciKlass* k) {
|
void ciMethodData::set_argument_type(int bci, int i, ciKlass* k) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if (mdo != NULL) {
|
if (mdo != nullptr) {
|
||||||
ProfileData* data = mdo->bci_to_data(bci);
|
ProfileData* data = mdo->bci_to_data(bci);
|
||||||
if (data != NULL) {
|
if (data != nullptr) {
|
||||||
if (data->is_CallTypeData()) {
|
if (data->is_CallTypeData()) {
|
||||||
data->as_CallTypeData()->set_argument_type(i, k->get_Klass());
|
data->as_CallTypeData()->set_argument_type(i, k->get_Klass());
|
||||||
} else {
|
} else {
|
||||||
@ -538,7 +538,7 @@ void ciMethodData::set_argument_type(int bci, int i, ciKlass* k) {
|
|||||||
void ciMethodData::set_parameter_type(int i, ciKlass* k) {
|
void ciMethodData::set_parameter_type(int i, ciKlass* k) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if (mdo != NULL) {
|
if (mdo != nullptr) {
|
||||||
mdo->parameters_type_data()->set_type(i, k->get_Klass());
|
mdo->parameters_type_data()->set_type(i, k->get_Klass());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -546,9 +546,9 @@ void ciMethodData::set_parameter_type(int i, ciKlass* k) {
|
|||||||
void ciMethodData::set_return_type(int bci, ciKlass* k) {
|
void ciMethodData::set_return_type(int bci, ciKlass* k) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
MethodData* mdo = get_MethodData();
|
MethodData* mdo = get_MethodData();
|
||||||
if (mdo != NULL) {
|
if (mdo != nullptr) {
|
||||||
ProfileData* data = mdo->bci_to_data(bci);
|
ProfileData* data = mdo->bci_to_data(bci);
|
||||||
if (data != NULL) {
|
if (data != nullptr) {
|
||||||
if (data->is_CallTypeData()) {
|
if (data->is_CallTypeData()) {
|
||||||
data->as_CallTypeData()->set_return_type(k->get_Klass());
|
data->as_CallTypeData()->set_return_type(k->get_Klass());
|
||||||
} else {
|
} else {
|
||||||
@ -585,7 +585,7 @@ void ciMethodData::set_arg_returned(int i) {
|
|||||||
|
|
||||||
void ciMethodData::set_arg_modified(int arg, uint val) {
|
void ciMethodData::set_arg_modified(int arg, uint val) {
|
||||||
ArgInfoData *aid = arg_info();
|
ArgInfoData *aid = arg_info();
|
||||||
if (aid == NULL)
|
if (aid == nullptr)
|
||||||
return;
|
return;
|
||||||
assert(arg >= 0 && arg < aid->number_of_args(), "valid argument number");
|
assert(arg >= 0 && arg < aid->number_of_args(), "valid argument number");
|
||||||
aid->set_arg_modified(arg, val);
|
aid->set_arg_modified(arg, val);
|
||||||
@ -605,14 +605,14 @@ bool ciMethodData::is_arg_returned(int i) const {
|
|||||||
|
|
||||||
uint ciMethodData::arg_modified(int arg) const {
|
uint ciMethodData::arg_modified(int arg) const {
|
||||||
ArgInfoData *aid = arg_info();
|
ArgInfoData *aid = arg_info();
|
||||||
if (aid == NULL)
|
if (aid == nullptr)
|
||||||
return 0;
|
return 0;
|
||||||
assert(arg >= 0 && arg < aid->number_of_args(), "valid argument number");
|
assert(arg >= 0 && arg < aid->number_of_args(), "valid argument number");
|
||||||
return aid->arg_modified(arg);
|
return aid->arg_modified(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
ciParametersTypeData* ciMethodData::parameters_type_data() const {
|
ciParametersTypeData* ciMethodData::parameters_type_data() const {
|
||||||
return _parameters != NULL ? new ciParametersTypeData(_parameters) : NULL;
|
return _parameters != nullptr ? new ciParametersTypeData(_parameters) : nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
ByteSize ciMethodData::offset_of_slot(ciProfileData* data, ByteSize slot_offset_in_data) {
|
ByteSize ciMethodData::offset_of_slot(ciProfileData* data, ByteSize slot_offset_in_data) {
|
||||||
@ -636,7 +636,7 @@ ciArgInfoData *ciMethodData::arg_info() const {
|
|||||||
if (dp->tag() == DataLayout::arg_info_data_tag)
|
if (dp->tag() == DataLayout::arg_info_data_tag)
|
||||||
return new ciArgInfoData(dp);
|
return new ciArgInfoData(dp);
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -646,7 +646,7 @@ void ciMethodData::print_impl(outputStream* st) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ciMethodData::dump_replay_data_type_helper(outputStream* out, int round, int& count, ProfileData* pdata, ByteSize offset, ciKlass* k) {
|
void ciMethodData::dump_replay_data_type_helper(outputStream* out, int round, int& count, ProfileData* pdata, ByteSize offset, ciKlass* k) {
|
||||||
if (k != NULL) {
|
if (k != nullptr) {
|
||||||
if (round == 0) {
|
if (round == 0) {
|
||||||
count++;
|
count++;
|
||||||
} else {
|
} else {
|
||||||
@ -687,7 +687,7 @@ void ciMethodData::dump_replay_data_extra_data_helper(outputStream* out, int rou
|
|||||||
case DataLayout::speculative_trap_data_tag: {
|
case DataLayout::speculative_trap_data_tag: {
|
||||||
ciSpeculativeTrapData* data = new ciSpeculativeTrapData(dp);
|
ciSpeculativeTrapData* data = new ciSpeculativeTrapData(dp);
|
||||||
ciMethod* m = data->method();
|
ciMethod* m = data->method();
|
||||||
if (m != NULL) {
|
if (m != nullptr) {
|
||||||
if (round == 0) {
|
if (round == 0) {
|
||||||
count++;
|
count++;
|
||||||
} else {
|
} else {
|
||||||
@ -753,7 +753,7 @@ void ciMethodData::dump_replay_data(outputStream* out) {
|
|||||||
dump_replay_data_call_type_helper<ciCallTypeData>(out, round, count, call_type_data);
|
dump_replay_data_call_type_helper<ciCallTypeData>(out, round, count, call_type_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (parameters != NULL) {
|
if (parameters != nullptr) {
|
||||||
for (int i = 0; i < parameters->number_of_parameters(); i++) {
|
for (int i = 0; i < parameters->number_of_parameters(); i++) {
|
||||||
dump_replay_data_type_helper(out, round, count, parameters, ParametersTypeData::type_offset(i), parameters->valid_parameter_type(i));
|
dump_replay_data_type_helper(out, round, count, parameters, ParametersTypeData::type_offset(i), parameters->valid_parameter_type(i));
|
||||||
}
|
}
|
||||||
@ -774,7 +774,7 @@ void ciMethodData::print() {
|
|||||||
void ciMethodData::print_data_on(outputStream* st) {
|
void ciMethodData::print_data_on(outputStream* st) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
ciParametersTypeData* parameters = parameters_type_data();
|
ciParametersTypeData* parameters = parameters_type_data();
|
||||||
if (parameters != NULL) {
|
if (parameters != nullptr) {
|
||||||
parameters->print_data_on(st);
|
parameters->print_data_on(st);
|
||||||
}
|
}
|
||||||
ciProfileData* data;
|
ciProfileData* data;
|
||||||
@ -858,11 +858,11 @@ void ciReceiverTypeData::print_receiver_data_on(outputStream* st) const {
|
|||||||
uint row;
|
uint row;
|
||||||
int entries = 0;
|
int entries = 0;
|
||||||
for (row = 0; row < row_limit(); row++) {
|
for (row = 0; row < row_limit(); row++) {
|
||||||
if (receiver(row) != NULL) entries++;
|
if (receiver(row) != nullptr) entries++;
|
||||||
}
|
}
|
||||||
st->print_cr("count(%u) entries(%u)", count(), entries);
|
st->print_cr("count(%u) entries(%u)", count(), entries);
|
||||||
for (row = 0; row < row_limit(); row++) {
|
for (row = 0; row < row_limit(); row++) {
|
||||||
if (receiver(row) != NULL) {
|
if (receiver(row) != nullptr) {
|
||||||
tab(st);
|
tab(st);
|
||||||
receiver(row)->print_name_on(st);
|
receiver(row)->print_name_on(st);
|
||||||
st->print_cr("(%u)", receiver_count(row));
|
st->print_cr("(%u)", receiver_count(row));
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -68,11 +68,11 @@ class ciTypeEntries {
|
|||||||
protected:
|
protected:
|
||||||
static intptr_t translate_klass(intptr_t k) {
|
static intptr_t translate_klass(intptr_t k) {
|
||||||
Klass* v = TypeEntries::valid_klass(k);
|
Klass* v = TypeEntries::valid_klass(k);
|
||||||
if (v != NULL) {
|
if (v != nullptr) {
|
||||||
ciKlass* klass = CURRENT_ENV->get_klass(v);
|
ciKlass* klass = CURRENT_ENV->get_klass(v);
|
||||||
return with_status(klass, k);
|
return with_status(klass, k);
|
||||||
}
|
}
|
||||||
return with_status(NULL, k);
|
return with_status(nullptr, k);
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -80,10 +80,10 @@ public:
|
|||||||
if (!TypeEntries::is_type_none(k) &&
|
if (!TypeEntries::is_type_none(k) &&
|
||||||
!TypeEntries::is_type_unknown(k)) {
|
!TypeEntries::is_type_unknown(k)) {
|
||||||
ciKlass* res = (ciKlass*)TypeEntries::klass_part(k);
|
ciKlass* res = (ciKlass*)TypeEntries::klass_part(k);
|
||||||
assert(res != NULL, "invalid");
|
assert(res != nullptr, "invalid");
|
||||||
return res;
|
return res;
|
||||||
} else {
|
} else {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -186,7 +186,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
void print_data_on(outputStream* st, const char* extra = NULL) const;
|
void print_data_on(outputStream* st, const char* extra = nullptr) const;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -203,7 +203,7 @@ public:
|
|||||||
ciKlass* receiver(uint row) const {
|
ciKlass* receiver(uint row) const {
|
||||||
assert((uint)row < row_limit(), "oob");
|
assert((uint)row < row_limit(), "oob");
|
||||||
ciKlass* recv = (ciKlass*)intptr_at(receiver0_offset + row * receiver_type_row_cell_count);
|
ciKlass* recv = (ciKlass*)intptr_at(receiver0_offset + row * receiver_type_row_cell_count);
|
||||||
assert(recv == NULL || recv->is_klass(), "wrong type");
|
assert(recv == nullptr || recv->is_klass(), "wrong type");
|
||||||
return recv;
|
return recv;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -213,7 +213,7 @@ public:
|
|||||||
}
|
}
|
||||||
void translate_receiver_data_from(const ProfileData* data);
|
void translate_receiver_data_from(const ProfileData* data);
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
void print_data_on(outputStream* st, const char* extra = NULL) const;
|
void print_data_on(outputStream* st, const char* extra = nullptr) const;
|
||||||
void print_receiver_data_on(outputStream* st) const;
|
void print_receiver_data_on(outputStream* st) const;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
@ -238,7 +238,7 @@ public:
|
|||||||
rtd_super()->translate_receiver_data_from(data);
|
rtd_super()->translate_receiver_data_from(data);
|
||||||
}
|
}
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
void print_data_on(outputStream* st, const char* extra = NULL) const;
|
void print_data_on(outputStream* st, const char* extra = nullptr) const;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -295,7 +295,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
void print_data_on(outputStream* st, const char* extra = NULL) const;
|
void print_data_on(outputStream* st, const char* extra = nullptr) const;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -339,7 +339,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
void print_data_on(outputStream* st, const char* extra = NULL) const;
|
void print_data_on(outputStream* st, const char* extra = nullptr) const;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -358,7 +358,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
void print_data_on(outputStream* st, const char* extra = NULL) const;
|
void print_data_on(outputStream* st, const char* extra = nullptr) const;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -403,13 +403,13 @@ private:
|
|||||||
// Coherent snapshot of original header.
|
// Coherent snapshot of original header.
|
||||||
MethodData::CompilerCounters _orig;
|
MethodData::CompilerCounters _orig;
|
||||||
|
|
||||||
// Area dedicated to parameters. NULL if no parameter profiling for this method.
|
// Area dedicated to parameters. null if no parameter profiling for this method.
|
||||||
DataLayout* _parameters;
|
DataLayout* _parameters;
|
||||||
int parameters_size() const {
|
int parameters_size() const {
|
||||||
return _parameters == NULL ? 0 : parameters_type_data()->size_in_bytes();
|
return _parameters == nullptr ? 0 : parameters_type_data()->size_in_bytes();
|
||||||
}
|
}
|
||||||
|
|
||||||
ciMethodData(MethodData* md = NULL);
|
ciMethodData(MethodData* md = nullptr);
|
||||||
|
|
||||||
// Accessors
|
// Accessors
|
||||||
int data_size() const { return _data_size; }
|
int data_size() const { return _data_size; }
|
||||||
@ -443,7 +443,7 @@ private:
|
|||||||
DataLayout* data_layout_before(int bci) {
|
DataLayout* data_layout_before(int bci) {
|
||||||
// avoid SEGV on this edge case
|
// avoid SEGV on this edge case
|
||||||
if (data_size() == 0)
|
if (data_size() == 0)
|
||||||
return NULL;
|
return nullptr;
|
||||||
DataLayout* layout = data_layout_at(hint_di());
|
DataLayout* layout = data_layout_at(hint_di());
|
||||||
if (layout->bci() <= bci)
|
if (layout->bci() <= bci)
|
||||||
return layout;
|
return layout;
|
||||||
@ -511,16 +511,16 @@ public:
|
|||||||
ciProfileData* first_data() { return data_at(first_di()); }
|
ciProfileData* first_data() { return data_at(first_di()); }
|
||||||
ciProfileData* next_data(ciProfileData* current);
|
ciProfileData* next_data(ciProfileData* current);
|
||||||
DataLayout* next_data_layout(DataLayout* current);
|
DataLayout* next_data_layout(DataLayout* current);
|
||||||
bool is_valid(ciProfileData* current) { return current != NULL; }
|
bool is_valid(ciProfileData* current) { return current != nullptr; }
|
||||||
bool is_valid(DataLayout* current) { return current != NULL; }
|
bool is_valid(DataLayout* current) { return current != nullptr; }
|
||||||
|
|
||||||
DataLayout* extra_data_base() const { return data_layout_at(data_size()); }
|
DataLayout* extra_data_base() const { return data_layout_at(data_size()); }
|
||||||
DataLayout* args_data_limit() const { return data_layout_at(data_size() + extra_data_size() -
|
DataLayout* args_data_limit() const { return data_layout_at(data_size() + extra_data_size() -
|
||||||
parameters_size()); }
|
parameters_size()); }
|
||||||
|
|
||||||
// Get the data at an arbitrary bci, or NULL if there is none. If m
|
// Get the data at an arbitrary bci, or null if there is none. If m
|
||||||
// is not NULL look for a SpeculativeTrapData if any first.
|
// is not null look for a SpeculativeTrapData if any first.
|
||||||
ciProfileData* bci_to_data(int bci, ciMethod* m = NULL);
|
ciProfileData* bci_to_data(int bci, ciMethod* m = nullptr);
|
||||||
|
|
||||||
uint overflow_trap_count() const {
|
uint overflow_trap_count() const {
|
||||||
return _orig.overflow_trap_count();
|
return _orig.overflow_trap_count();
|
||||||
@ -540,7 +540,7 @@ public:
|
|||||||
// Helpful query functions that decode trap_state.
|
// Helpful query functions that decode trap_state.
|
||||||
int has_trap_at(ciProfileData* data, int reason);
|
int has_trap_at(ciProfileData* data, int reason);
|
||||||
int has_trap_at(int bci, ciMethod* m, int reason) {
|
int has_trap_at(int bci, ciMethod* m, int reason) {
|
||||||
assert((m != NULL) == Deoptimization::reason_is_speculate(reason), "inconsistent method/reason");
|
assert((m != nullptr) == Deoptimization::reason_is_speculate(reason), "inconsistent method/reason");
|
||||||
return has_trap_at(bci_to_data(bci, m), reason);
|
return has_trap_at(bci_to_data(bci, m), reason);
|
||||||
}
|
}
|
||||||
int trap_recompiled_at(ciProfileData* data);
|
int trap_recompiled_at(ciProfileData* data);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -38,7 +38,7 @@ ciObject* ciObjArray::obj_at(int index) {
|
|||||||
objArrayOop array = get_objArrayOop();
|
objArrayOop array = get_objArrayOop();
|
||||||
assert(index >= 0 && index < array->length(), "OOB access");
|
assert(index >= 0 && index < array->length(), "OOB access");
|
||||||
oop o = array->obj_at(index);
|
oop o = array->obj_at(index);
|
||||||
if (o == NULL) {
|
if (o == nullptr) {
|
||||||
return ciNullObject::make();
|
return ciNullObject::make();
|
||||||
} else {
|
} else {
|
||||||
return CURRENT_ENV->get_object(o);
|
return CURRENT_ENV->get_object(o);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,7 +48,7 @@ ciObjArrayKlass::ciObjArrayKlass(Klass* k) : ciArrayKlass(k) {
|
|||||||
if (dimension() == 1) {
|
if (dimension() == 1) {
|
||||||
_element_klass = _base_element_klass;
|
_element_klass = _base_element_klass;
|
||||||
} else {
|
} else {
|
||||||
_element_klass = NULL;
|
_element_klass = nullptr;
|
||||||
}
|
}
|
||||||
if (!ciObjectFactory::is_initialized()) {
|
if (!ciObjectFactory::is_initialized()) {
|
||||||
assert(_element_klass->is_java_lang_Object(), "only arrays of object are shared");
|
assert(_element_klass->is_java_lang_Object(), "only arrays of object are shared");
|
||||||
@ -70,7 +70,7 @@ ciObjArrayKlass::ciObjArrayKlass(ciSymbol* array_name,
|
|||||||
if (dimension == 1) {
|
if (dimension == 1) {
|
||||||
_element_klass = base_element_klass;
|
_element_klass = base_element_klass;
|
||||||
} else {
|
} else {
|
||||||
_element_klass = NULL;
|
_element_klass = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -79,8 +79,8 @@ ciObjArrayKlass::ciObjArrayKlass(ciSymbol* array_name,
|
|||||||
//
|
//
|
||||||
// What is the one-level element type of this array?
|
// What is the one-level element type of this array?
|
||||||
ciKlass* ciObjArrayKlass::element_klass() {
|
ciKlass* ciObjArrayKlass::element_klass() {
|
||||||
if (_element_klass == NULL) {
|
if (_element_klass == nullptr) {
|
||||||
assert(dimension() > 1, "_element_klass should not be NULL");
|
assert(dimension() > 1, "_element_klass should not be null");
|
||||||
// Produce the element klass.
|
// Produce the element klass.
|
||||||
if (is_loaded()) {
|
if (is_loaded()) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
@ -179,11 +179,11 @@ ciKlass* ciObjArrayKlass::exact_klass() {
|
|||||||
ciType* base = base_element_type();
|
ciType* base = base_element_type();
|
||||||
if (base->is_instance_klass()) {
|
if (base->is_instance_klass()) {
|
||||||
ciInstanceKlass* ik = base->as_instance_klass();
|
ciInstanceKlass* ik = base->as_instance_klass();
|
||||||
if (ik->exact_klass() != NULL) {
|
if (ik->exact_klass() != nullptr) {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
} else if (base->is_primitive_type()) {
|
} else if (base->is_primitive_type()) {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2018, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -58,7 +58,7 @@ ciObject::ciObject(oop o) {
|
|||||||
Handle obj(Thread::current(), o);
|
Handle obj(Thread::current(), o);
|
||||||
_handle = JNIHandles::make_global(obj);
|
_handle = JNIHandles::make_global(obj);
|
||||||
}
|
}
|
||||||
_klass = NULL;
|
_klass = nullptr;
|
||||||
assert(oopDesc::is_oop_or_null(o), "Checking");
|
assert(oopDesc::is_oop_or_null(o), "Checking");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,7 +72,7 @@ ciObject::ciObject(Handle h) {
|
|||||||
} else {
|
} else {
|
||||||
_handle = JNIHandles::make_global(h);
|
_handle = JNIHandles::make_global(h);
|
||||||
}
|
}
|
||||||
_klass = NULL;
|
_klass = nullptr;
|
||||||
assert(oopDesc::is_oop_or_null(h()), "Checking");
|
assert(oopDesc::is_oop_or_null(h()), "Checking");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,19 +83,19 @@ ciObject::ciObject(Handle h) {
|
|||||||
// klass/method, if that makes sense.
|
// klass/method, if that makes sense.
|
||||||
ciObject::ciObject(ciKlass* klass) {
|
ciObject::ciObject(ciKlass* klass) {
|
||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
assert(klass != NULL, "must supply klass");
|
assert(klass != nullptr, "must supply klass");
|
||||||
_handle = NULL;
|
_handle = nullptr;
|
||||||
_klass = klass;
|
_klass = klass;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciObject::ciObject
|
// ciObject::ciObject
|
||||||
//
|
//
|
||||||
// NULL variant. Used only by ciNullObject.
|
// null variant. Used only by ciNullObject.
|
||||||
ciObject::ciObject() {
|
ciObject::ciObject() {
|
||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
_handle = NULL;
|
_handle = nullptr;
|
||||||
_klass = NULL;
|
_klass = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -111,14 +111,14 @@ oop ciObject::get_oop() const {
|
|||||||
//
|
//
|
||||||
// Get the ciKlass of this ciObject.
|
// Get the ciKlass of this ciObject.
|
||||||
ciKlass* ciObject::klass() {
|
ciKlass* ciObject::klass() {
|
||||||
if (_klass == NULL) {
|
if (_klass == nullptr) {
|
||||||
if (_handle == NULL) {
|
if (_handle == nullptr) {
|
||||||
// When both _klass and _handle are NULL, we are dealing
|
// When both _klass and _handle are null, we are dealing
|
||||||
// with the distinguished instance of ciNullObject.
|
// with the distinguished instance of ciNullObject.
|
||||||
// No one should ask it for its klass.
|
// No one should ask it for its klass.
|
||||||
assert(is_null_object(), "must be null object");
|
assert(is_null_object(), "must be null object");
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
GUARDED_VM_ENTRY(
|
GUARDED_VM_ENTRY(
|
||||||
@ -164,7 +164,7 @@ int ciObject::hash() {
|
|||||||
// This method should be changed to return an generified address
|
// This method should be changed to return an generified address
|
||||||
// to discourage use of the JNI handle.
|
// to discourage use of the JNI handle.
|
||||||
jobject ciObject::constant_encoding() {
|
jobject ciObject::constant_encoding() {
|
||||||
assert(is_null_object() || handle() != NULL, "cannot embed null pointer");
|
assert(is_null_object() || handle() != nullptr, "cannot embed null pointer");
|
||||||
return handle();
|
return handle();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -189,7 +189,7 @@ bool ciObject::should_be_constant() {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return handle() == NULL;
|
return handle() == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -211,7 +211,7 @@ void ciObject::print(outputStream* st) {
|
|||||||
// Print debugging output about the oop this ciObject represents.
|
// Print debugging output about the oop this ciObject represents.
|
||||||
void ciObject::print_oop(outputStream* st) {
|
void ciObject::print_oop(outputStream* st) {
|
||||||
if (is_null_object()) {
|
if (is_null_object()) {
|
||||||
st->print_cr("NULL");
|
st->print_cr("nullptr");
|
||||||
} else if (!is_loaded()) {
|
} else if (!is_loaded()) {
|
||||||
st->print_cr("UNLOADED");
|
st->print_cr("UNLOADED");
|
||||||
} else {
|
} else {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -53,7 +53,7 @@ class ciObject : public ciBaseObject {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
// A JNI handle referring to an oop in the VM. This
|
// A JNI handle referring to an oop in the VM. This
|
||||||
// handle may, in a small set of cases, correctly be NULL.
|
// handle may, in a small set of cases, correctly be null.
|
||||||
jobject _handle;
|
jobject _handle;
|
||||||
ciKlass* _klass;
|
ciKlass* _klass;
|
||||||
|
|
||||||
@ -120,7 +120,7 @@ public:
|
|||||||
// By convention the ciNullObject is considered loaded, and
|
// By convention the ciNullObject is considered loaded, and
|
||||||
// primitive types are considered loaded.
|
// primitive types are considered loaded.
|
||||||
bool is_loaded() const {
|
bool is_loaded() const {
|
||||||
return handle() != NULL || is_classless();
|
return handle() != nullptr || is_classless();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Subclass casting with assertions.
|
// Subclass casting with assertions.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -70,7 +70,7 @@
|
|||||||
// problematic the underlying data structure can be switched to some
|
// problematic the underlying data structure can be switched to some
|
||||||
// sort of balanced binary tree.
|
// sort of balanced binary tree.
|
||||||
|
|
||||||
GrowableArray<ciMetadata*>* ciObjectFactory::_shared_ci_metadata = NULL;
|
GrowableArray<ciMetadata*>* ciObjectFactory::_shared_ci_metadata = nullptr;
|
||||||
ciSymbol* ciObjectFactory::_shared_ci_symbols[vmSymbols::number_of_symbols()];
|
ciSymbol* ciObjectFactory::_shared_ci_symbols[vmSymbols::number_of_symbols()];
|
||||||
int ciObjectFactory::_shared_ident_limit = 0;
|
int ciObjectFactory::_shared_ident_limit = 0;
|
||||||
volatile bool ciObjectFactory::_initialized = false;
|
volatile bool ciObjectFactory::_initialized = false;
|
||||||
@ -81,20 +81,20 @@ volatile bool ciObjectFactory::_initialized = false;
|
|||||||
ciObjectFactory::ciObjectFactory(Arena* arena,
|
ciObjectFactory::ciObjectFactory(Arena* arena,
|
||||||
int expected_size)
|
int expected_size)
|
||||||
: _arena(arena),
|
: _arena(arena),
|
||||||
_ci_metadata(arena, expected_size, 0, NULL),
|
_ci_metadata(arena, expected_size, 0, nullptr),
|
||||||
_unloaded_methods(arena, 4, 0, NULL),
|
_unloaded_methods(arena, 4, 0, nullptr),
|
||||||
_unloaded_klasses(arena, 8, 0, NULL),
|
_unloaded_klasses(arena, 8, 0, nullptr),
|
||||||
_unloaded_instances(arena, 4, 0, NULL),
|
_unloaded_instances(arena, 4, 0, nullptr),
|
||||||
_return_addresses(arena, 8, 0, NULL),
|
_return_addresses(arena, 8, 0, nullptr),
|
||||||
_symbols(arena, 100, 0, NULL),
|
_symbols(arena, 100, 0, nullptr),
|
||||||
_next_ident(_shared_ident_limit),
|
_next_ident(_shared_ident_limit),
|
||||||
_non_perm_count(0) {
|
_non_perm_count(0) {
|
||||||
for (int i = 0; i < NON_PERM_BUCKETS; i++) {
|
for (int i = 0; i < NON_PERM_BUCKETS; i++) {
|
||||||
_non_perm_bucket[i] = NULL;
|
_non_perm_bucket[i] = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the shared ci objects exist append them to this factory's objects
|
// If the shared ci objects exist append them to this factory's objects
|
||||||
if (_shared_ci_metadata != NULL) {
|
if (_shared_ci_metadata != nullptr) {
|
||||||
_ci_metadata.appendAll(_shared_ci_metadata);
|
_ci_metadata.appendAll(_shared_ci_metadata);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -143,7 +143,7 @@ void ciObjectFactory::init_shared_objects() {
|
|||||||
|
|
||||||
for (int i = T_BOOLEAN; i <= T_CONFLICT; i++) {
|
for (int i = T_BOOLEAN; i <= T_CONFLICT; i++) {
|
||||||
BasicType t = (BasicType)i;
|
BasicType t = (BasicType)i;
|
||||||
if (type2name(t) != NULL && !is_reference_type(t) &&
|
if (type2name(t) != nullptr && !is_reference_type(t) &&
|
||||||
t != T_NARROWOOP && t != T_NARROWKLASS) {
|
t != T_NARROWOOP && t != T_NARROWKLASS) {
|
||||||
ciType::_basic_types[t] = new (_arena) ciType(t);
|
ciType::_basic_types[t] = new (_arena) ciType(t);
|
||||||
init_ident_of(ciType::_basic_types[t]);
|
init_ident_of(ciType::_basic_types[t]);
|
||||||
@ -174,7 +174,7 @@ void ciObjectFactory::init_shared_objects() {
|
|||||||
|
|
||||||
ciEnv::_unloaded_cisymbol = ciObjectFactory::get_symbol(vmSymbols::dummy_symbol());
|
ciEnv::_unloaded_cisymbol = ciObjectFactory::get_symbol(vmSymbols::dummy_symbol());
|
||||||
// Create dummy InstanceKlass and ObjArrayKlass object and assign them idents
|
// Create dummy InstanceKlass and ObjArrayKlass object and assign them idents
|
||||||
ciEnv::_unloaded_ciinstance_klass = new (_arena) ciInstanceKlass(ciEnv::_unloaded_cisymbol, NULL, NULL);
|
ciEnv::_unloaded_ciinstance_klass = new (_arena) ciInstanceKlass(ciEnv::_unloaded_cisymbol, nullptr, nullptr);
|
||||||
init_ident_of(ciEnv::_unloaded_ciinstance_klass);
|
init_ident_of(ciEnv::_unloaded_ciinstance_klass);
|
||||||
ciEnv::_unloaded_ciobjarrayklass = new (_arena) ciObjArrayKlass(ciEnv::_unloaded_cisymbol, ciEnv::_unloaded_ciinstance_klass, 1);
|
ciEnv::_unloaded_ciobjarrayklass = new (_arena) ciObjArrayKlass(ciEnv::_unloaded_cisymbol, ciEnv::_unloaded_ciinstance_klass, 1);
|
||||||
init_ident_of(ciEnv::_unloaded_ciobjarrayklass);
|
init_ident_of(ciEnv::_unloaded_ciobjarrayklass);
|
||||||
@ -236,7 +236,7 @@ ciObject* ciObjectFactory::get(oop key) {
|
|||||||
assert(Universe::heap()->is_in(key), "must be");
|
assert(Universe::heap()->is_in(key), "must be");
|
||||||
|
|
||||||
NonPermObject* &bucket = find_non_perm(key);
|
NonPermObject* &bucket = find_non_perm(key);
|
||||||
if (bucket != NULL) {
|
if (bucket != nullptr) {
|
||||||
return bucket->object();
|
return bucket->object();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -272,7 +272,7 @@ ciMetadata* ciObjectFactory::cached_metadata(Metadata* key) {
|
|||||||
int index = _ci_metadata.find_sorted<Metadata*, ciObjectFactory::metadata_compare>(key, found);
|
int index = _ci_metadata.find_sorted<Metadata*, ciObjectFactory::metadata_compare>(key, found);
|
||||||
|
|
||||||
if (!found) {
|
if (!found) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return _ci_metadata.at(index)->as_metadata();
|
return _ci_metadata.at(index)->as_metadata();
|
||||||
}
|
}
|
||||||
@ -297,7 +297,7 @@ ciMetadata* ciObjectFactory::get_metadata(Metadata* key) {
|
|||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
if (CIObjectFactoryVerify) {
|
if (CIObjectFactoryVerify) {
|
||||||
Metadata* last = NULL;
|
Metadata* last = nullptr;
|
||||||
for (int j = 0; j < _ci_metadata.length(); j++) {
|
for (int j = 0; j < _ci_metadata.length(); j++) {
|
||||||
Metadata* o = _ci_metadata.at(j)->constant_encoding();
|
Metadata* o = _ci_metadata.at(j)->constant_encoding();
|
||||||
assert(last < o, "out of order");
|
assert(last < o, "out of order");
|
||||||
@ -369,7 +369,7 @@ ciObject* ciObjectFactory::create_new_object(oop o) {
|
|||||||
|
|
||||||
// The oop is of some type not supported by the compiler interface.
|
// The oop is of some type not supported by the compiler interface.
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -405,7 +405,7 @@ ciMetadata* ciObjectFactory::create_new_metadata(Metadata* o) {
|
|||||||
|
|
||||||
// The Metadata* is of some type not supported by the compiler interface.
|
// The Metadata* is of some type not supported by the compiler interface.
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
@ -420,8 +420,8 @@ ciMethod* ciObjectFactory::get_unloaded_method(ciInstanceKlass* holder,
|
|||||||
ciSymbol* name,
|
ciSymbol* name,
|
||||||
ciSymbol* signature,
|
ciSymbol* signature,
|
||||||
ciInstanceKlass* accessor) {
|
ciInstanceKlass* accessor) {
|
||||||
assert(accessor != NULL, "need origin of access");
|
assert(accessor != nullptr, "need origin of access");
|
||||||
ciSignature* that = NULL;
|
ciSignature* that = nullptr;
|
||||||
for (int i = 0; i < _unloaded_methods.length(); i++) {
|
for (int i = 0; i < _unloaded_methods.length(); i++) {
|
||||||
ciMethod* entry = _unloaded_methods.at(i);
|
ciMethod* entry = _unloaded_methods.at(i);
|
||||||
if (entry->holder()->equals(holder) &&
|
if (entry->holder()->equals(holder) &&
|
||||||
@ -433,7 +433,7 @@ ciMethod* ciObjectFactory::get_unloaded_method(ciInstanceKlass* holder,
|
|||||||
return entry;
|
return entry;
|
||||||
} else {
|
} else {
|
||||||
// Lazily create ciSignature
|
// Lazily create ciSignature
|
||||||
if (that == NULL) that = new (arena()) ciSignature(accessor, constantPoolHandle(), signature);
|
if (that == nullptr) that = new (arena()) ciSignature(accessor, constantPoolHandle(), signature);
|
||||||
if (entry->signature()->equals(that)) {
|
if (entry->signature()->equals(that)) {
|
||||||
// We've found a match.
|
// We've found a match.
|
||||||
return entry;
|
return entry;
|
||||||
@ -464,9 +464,9 @@ ciKlass* ciObjectFactory::get_unloaded_klass(ciKlass* accessing_klass,
|
|||||||
ciSymbol* name,
|
ciSymbol* name,
|
||||||
bool create_if_not_found) {
|
bool create_if_not_found) {
|
||||||
EXCEPTION_CONTEXT;
|
EXCEPTION_CONTEXT;
|
||||||
oop loader = NULL;
|
oop loader = nullptr;
|
||||||
oop domain = NULL;
|
oop domain = nullptr;
|
||||||
if (accessing_klass != NULL) {
|
if (accessing_klass != nullptr) {
|
||||||
loader = accessing_klass->loader();
|
loader = accessing_klass->loader();
|
||||||
domain = accessing_klass->protection_domain();
|
domain = accessing_klass->protection_domain();
|
||||||
}
|
}
|
||||||
@ -481,11 +481,11 @@ ciKlass* ciObjectFactory::get_unloaded_klass(ciKlass* accessing_klass,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!create_if_not_found)
|
if (!create_if_not_found)
|
||||||
return NULL;
|
return nullptr;
|
||||||
|
|
||||||
// This is a new unloaded klass. Create it and stick it in
|
// This is a new unloaded klass. Create it and stick it in
|
||||||
// the cache.
|
// the cache.
|
||||||
ciKlass* new_klass = NULL;
|
ciKlass* new_klass = nullptr;
|
||||||
|
|
||||||
// Two cases: this is an unloaded ObjArrayKlass or an
|
// Two cases: this is an unloaded ObjArrayKlass or an
|
||||||
// unloaded InstanceKlass. Deal with both.
|
// unloaded InstanceKlass. Deal with both.
|
||||||
@ -495,7 +495,7 @@ ciKlass* ciObjectFactory::get_unloaded_klass(ciKlass* accessing_klass,
|
|||||||
int dimension = ss.skip_array_prefix(); // skip all '['s
|
int dimension = ss.skip_array_prefix(); // skip all '['s
|
||||||
BasicType element_type = ss.type();
|
BasicType element_type = ss.type();
|
||||||
assert(element_type != T_ARRAY, "unsuccessful decomposition");
|
assert(element_type != T_ARRAY, "unsuccessful decomposition");
|
||||||
ciKlass* element_klass = NULL;
|
ciKlass* element_klass = nullptr;
|
||||||
if (element_type == T_OBJECT) {
|
if (element_type == T_OBJECT) {
|
||||||
ciEnv *env = CURRENT_THREAD_ENV;
|
ciEnv *env = CURRENT_THREAD_ENV;
|
||||||
ciSymbol* ci_name = env->get_symbol(ss.as_symbol());
|
ciSymbol* ci_name = env->get_symbol(ss.as_symbol());
|
||||||
@ -512,9 +512,9 @@ ciKlass* ciObjectFactory::get_unloaded_klass(ciKlass* accessing_klass,
|
|||||||
}
|
}
|
||||||
new_klass = new (arena()) ciObjArrayKlass(name, element_klass, dimension);
|
new_klass = new (arena()) ciObjArrayKlass(name, element_klass, dimension);
|
||||||
} else {
|
} else {
|
||||||
jobject loader_handle = NULL;
|
jobject loader_handle = nullptr;
|
||||||
jobject domain_handle = NULL;
|
jobject domain_handle = nullptr;
|
||||||
if (accessing_klass != NULL) {
|
if (accessing_klass != nullptr) {
|
||||||
loader_handle = accessing_klass->loader_handle();
|
loader_handle = accessing_klass->loader_handle();
|
||||||
domain_handle = accessing_klass->protection_domain_handle();
|
domain_handle = accessing_klass->protection_domain_handle();
|
||||||
}
|
}
|
||||||
@ -563,7 +563,7 @@ ciInstance* ciObjectFactory::get_unloaded_instance(ciInstanceKlass* instance_kla
|
|||||||
//
|
//
|
||||||
// Currently, this ignores the parameters and returns a unique unloaded instance.
|
// Currently, this ignores the parameters and returns a unique unloaded instance.
|
||||||
ciInstance* ciObjectFactory::get_unloaded_klass_mirror(ciKlass* type) {
|
ciInstance* ciObjectFactory::get_unloaded_klass_mirror(ciKlass* type) {
|
||||||
assert(ciEnv::_Class_klass != NULL, "");
|
assert(ciEnv::_Class_klass != nullptr, "");
|
||||||
return get_unloaded_instance(ciEnv::_Class_klass->as_instance_klass());
|
return get_unloaded_instance(ciEnv::_Class_klass->as_instance_klass());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -577,7 +577,7 @@ ciInstance* ciObjectFactory::get_unloaded_method_handle_constant(ciKlass* holde
|
|||||||
ciSymbol* name,
|
ciSymbol* name,
|
||||||
ciSymbol* signature,
|
ciSymbol* signature,
|
||||||
int ref_kind) {
|
int ref_kind) {
|
||||||
assert(ciEnv::_MethodHandle_klass != NULL, "");
|
assert(ciEnv::_MethodHandle_klass != nullptr, "");
|
||||||
return get_unloaded_instance(ciEnv::_MethodHandle_klass->as_instance_klass());
|
return get_unloaded_instance(ciEnv::_MethodHandle_klass->as_instance_klass());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -588,12 +588,12 @@ ciInstance* ciObjectFactory::get_unloaded_method_handle_constant(ciKlass* holde
|
|||||||
//
|
//
|
||||||
// Currently, this ignores the parameters and returns a unique unloaded instance.
|
// Currently, this ignores the parameters and returns a unique unloaded instance.
|
||||||
ciInstance* ciObjectFactory::get_unloaded_method_type_constant(ciSymbol* signature) {
|
ciInstance* ciObjectFactory::get_unloaded_method_type_constant(ciSymbol* signature) {
|
||||||
assert(ciEnv::_MethodType_klass != NULL, "");
|
assert(ciEnv::_MethodType_klass != nullptr, "");
|
||||||
return get_unloaded_instance(ciEnv::_MethodType_klass->as_instance_klass());
|
return get_unloaded_instance(ciEnv::_MethodType_klass->as_instance_klass());
|
||||||
}
|
}
|
||||||
|
|
||||||
ciInstance* ciObjectFactory::get_unloaded_object_constant() {
|
ciInstance* ciObjectFactory::get_unloaded_object_constant() {
|
||||||
assert(ciEnv::_Object_klass != NULL, "");
|
assert(ciEnv::_Object_klass != nullptr, "");
|
||||||
return get_unloaded_instance(ciEnv::_Object_klass->as_instance_klass());
|
return get_unloaded_instance(ciEnv::_Object_klass->as_instance_klass());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -633,7 +633,7 @@ void ciObjectFactory::init_ident_of(ciBaseObject* obj) {
|
|||||||
obj->set_ident(_next_ident++);
|
obj->set_ident(_next_ident++);
|
||||||
}
|
}
|
||||||
|
|
||||||
static ciObjectFactory::NonPermObject* emptyBucket = NULL;
|
static ciObjectFactory::NonPermObject* emptyBucket = nullptr;
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciObjectFactory::find_non_perm
|
// ciObjectFactory::find_non_perm
|
||||||
@ -645,7 +645,7 @@ ciObjectFactory::NonPermObject* &ciObjectFactory::find_non_perm(oop key) {
|
|||||||
assert(Universe::heap()->is_in(key), "must be");
|
assert(Universe::heap()->is_in(key), "must be");
|
||||||
ciMetadata* klass = get_metadata(key->klass());
|
ciMetadata* klass = get_metadata(key->klass());
|
||||||
NonPermObject* *bp = &_non_perm_bucket[(unsigned) klass->hash() % NON_PERM_BUCKETS];
|
NonPermObject* *bp = &_non_perm_bucket[(unsigned) klass->hash() % NON_PERM_BUCKETS];
|
||||||
for (NonPermObject* p; (p = (*bp)) != NULL; bp = &p->next()) {
|
for (NonPermObject* p; (p = (*bp)) != nullptr; bp = &p->next()) {
|
||||||
if (is_equal(p, key)) break;
|
if (is_equal(p, key)) break;
|
||||||
}
|
}
|
||||||
return (*bp);
|
return (*bp);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2013, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2013, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -146,19 +146,19 @@ class CompileReplay : public StackObj {
|
|||||||
_protection_domain_initialized = false;
|
_protection_domain_initialized = false;
|
||||||
|
|
||||||
_stream = os::fopen(filename, "rt");
|
_stream = os::fopen(filename, "rt");
|
||||||
if (_stream == NULL) {
|
if (_stream == nullptr) {
|
||||||
fprintf(stderr, "ERROR: Can't open replay file %s\n", filename);
|
fprintf(stderr, "ERROR: Can't open replay file %s\n", filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
_ci_inline_records = NULL;
|
_ci_inline_records = nullptr;
|
||||||
_error_message = NULL;
|
_error_message = nullptr;
|
||||||
|
|
||||||
_buffer_length = 32;
|
_buffer_length = 32;
|
||||||
_buffer = NEW_RESOURCE_ARRAY(char, _buffer_length);
|
_buffer = NEW_RESOURCE_ARRAY(char, _buffer_length);
|
||||||
_bufptr = _buffer;
|
_bufptr = _buffer;
|
||||||
|
|
||||||
_imethod = NULL;
|
_imethod = nullptr;
|
||||||
_iklass = NULL;
|
_iklass = nullptr;
|
||||||
_entry_bci = 0;
|
_entry_bci = 0;
|
||||||
_comp_level = 0;
|
_comp_level = 0;
|
||||||
_version = 0;
|
_version = 0;
|
||||||
@ -167,7 +167,7 @@ class CompileReplay : public StackObj {
|
|||||||
}
|
}
|
||||||
|
|
||||||
~CompileReplay() {
|
~CompileReplay() {
|
||||||
if (_stream != NULL) fclose(_stream);
|
if (_stream != nullptr) fclose(_stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
void test() {
|
void test() {
|
||||||
@ -183,11 +183,11 @@ class CompileReplay : public StackObj {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool had_error() {
|
bool had_error() {
|
||||||
return _error_message != NULL || _thread->has_pending_exception();
|
return _error_message != nullptr || _thread->has_pending_exception();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool can_replay() {
|
bool can_replay() {
|
||||||
return !(_stream == NULL || had_error());
|
return !(_stream == nullptr || had_error());
|
||||||
}
|
}
|
||||||
|
|
||||||
void report_error(const char* msg) {
|
void report_error(const char* msg) {
|
||||||
@ -246,20 +246,20 @@ class CompileReplay : public StackObj {
|
|||||||
}
|
}
|
||||||
if (_bufptr == str) {
|
if (_bufptr == str) {
|
||||||
// nothing here
|
// nothing here
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
char* parse_string() {
|
char* parse_string() {
|
||||||
if (had_error()) return NULL;
|
if (had_error()) return nullptr;
|
||||||
|
|
||||||
skip_ws();
|
skip_ws();
|
||||||
return scan_and_terminate(' ');
|
return scan_and_terminate(' ');
|
||||||
}
|
}
|
||||||
|
|
||||||
char* parse_quoted_string() {
|
char* parse_quoted_string() {
|
||||||
if (had_error()) return NULL;
|
if (had_error()) return nullptr;
|
||||||
|
|
||||||
skip_ws();
|
skip_ws();
|
||||||
|
|
||||||
@ -273,7 +273,7 @@ class CompileReplay : public StackObj {
|
|||||||
|
|
||||||
char* parse_escaped_string() {
|
char* parse_escaped_string() {
|
||||||
char* result = parse_quoted_string();
|
char* result = parse_quoted_string();
|
||||||
if (result != NULL) {
|
if (result != nullptr) {
|
||||||
unescape_string(result);
|
unescape_string(result);
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
@ -282,7 +282,7 @@ class CompileReplay : public StackObj {
|
|||||||
// Look for the tag 'tag' followed by an
|
// Look for the tag 'tag' followed by an
|
||||||
bool parse_tag_and_count(const char* tag, int& length) {
|
bool parse_tag_and_count(const char* tag, int& length) {
|
||||||
const char* t = parse_string();
|
const char* t = parse_string();
|
||||||
if (t == NULL) {
|
if (t == nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -299,7 +299,7 @@ class CompileReplay : public StackObj {
|
|||||||
char* parse_data(const char* tag, int& length) {
|
char* parse_data(const char* tag, int& length) {
|
||||||
int read_size = 0;
|
int read_size = 0;
|
||||||
if (!parse_tag_and_count(tag, read_size)) {
|
if (!parse_tag_and_count(tag, read_size)) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
int actual_size = sizeof(MethodData::CompilerCounters);
|
int actual_size = sizeof(MethodData::CompilerCounters);
|
||||||
@ -341,7 +341,7 @@ class CompileReplay : public StackObj {
|
|||||||
// Where each # is an intptr_t item
|
// Where each # is an intptr_t item
|
||||||
intptr_t* parse_intptr_data(const char* tag, int& length) {
|
intptr_t* parse_intptr_data(const char* tag, int& length) {
|
||||||
if (!parse_tag_and_count(tag, length)) {
|
if (!parse_tag_and_count(tag, length)) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
intptr_t* result = NEW_RESOURCE_ARRAY(intptr_t, length);
|
intptr_t* result = NEW_RESOURCE_ARRAY(intptr_t, length);
|
||||||
@ -356,16 +356,16 @@ class CompileReplay : public StackObj {
|
|||||||
// Parse a possibly quoted version of a symbol into a symbolOop
|
// Parse a possibly quoted version of a symbol into a symbolOop
|
||||||
Symbol* parse_symbol() {
|
Symbol* parse_symbol() {
|
||||||
const char* str = parse_escaped_string();
|
const char* str = parse_escaped_string();
|
||||||
if (str != NULL) {
|
if (str != nullptr) {
|
||||||
Symbol* sym = SymbolTable::new_symbol(str);
|
Symbol* sym = SymbolTable::new_symbol(str);
|
||||||
return sym;
|
return sym;
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool parse_terminator() {
|
bool parse_terminator() {
|
||||||
char* terminator = parse_string();
|
char* terminator = parse_string();
|
||||||
if (terminator != NULL && strcmp(terminator, ";") == 0) {
|
if (terminator != nullptr && strcmp(terminator, ";") == 0) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -376,12 +376,12 @@ class CompileReplay : public StackObj {
|
|||||||
// syntax: @cpi <klass> <cpi> <location>* ;
|
// syntax: @cpi <klass> <cpi> <location>* ;
|
||||||
Klass* parse_cp_ref(TRAPS) {
|
Klass* parse_cp_ref(TRAPS) {
|
||||||
JavaThread* thread = THREAD;
|
JavaThread* thread = THREAD;
|
||||||
oop obj = NULL;
|
oop obj = nullptr;
|
||||||
char* ref = parse_string();
|
char* ref = parse_string();
|
||||||
if (strcmp(ref, "bci") == 0) {
|
if (strcmp(ref, "bci") == 0) {
|
||||||
Method* m = parse_method(CHECK_NULL);
|
Method* m = parse_method(CHECK_NULL);
|
||||||
if (m == NULL) {
|
if (m == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
InstanceKlass* ik = m->method_holder();
|
InstanceKlass* ik = m->method_holder();
|
||||||
@ -393,7 +393,7 @@ class CompileReplay : public StackObj {
|
|||||||
int bci = parse_int("bci");
|
int bci = parse_int("bci");
|
||||||
if (m->validate_bci(bci) != bci) {
|
if (m->validate_bci(bci) != bci) {
|
||||||
report_error("bad bci");
|
report_error("bad bci");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
ik->link_class(CHECK_NULL);
|
ik->link_class(CHECK_NULL);
|
||||||
@ -401,12 +401,12 @@ class CompileReplay : public StackObj {
|
|||||||
Bytecode_invoke bytecode = Bytecode_invoke_check(caller, bci);
|
Bytecode_invoke bytecode = Bytecode_invoke_check(caller, bci);
|
||||||
if (!Bytecodes::is_defined(bytecode.code()) || !bytecode.is_valid()) {
|
if (!Bytecodes::is_defined(bytecode.code()) || !bytecode.is_valid()) {
|
||||||
report_error("no invoke found at bci");
|
report_error("no invoke found at bci");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
bytecode.verify();
|
bytecode.verify();
|
||||||
int index = bytecode.index();
|
int index = bytecode.index();
|
||||||
|
|
||||||
ConstantPoolCacheEntry* cp_cache_entry = NULL;
|
ConstantPoolCacheEntry* cp_cache_entry = nullptr;
|
||||||
CallInfo callInfo;
|
CallInfo callInfo;
|
||||||
Bytecodes::Code bc = bytecode.invoke_code();
|
Bytecodes::Code bc = bytecode.invoke_code();
|
||||||
LinkResolver::resolve_invoke(callInfo, Handle(), cp, index, bc, CHECK_NULL);
|
LinkResolver::resolve_invoke(callInfo, Handle(), cp, index, bc, CHECK_NULL);
|
||||||
@ -423,7 +423,7 @@ class CompileReplay : public StackObj {
|
|||||||
cp_cache_entry->set_method_handle(cp, callInfo);
|
cp_cache_entry->set_method_handle(cp, callInfo);
|
||||||
} else {
|
} else {
|
||||||
report_error("no dynamic invoke found");
|
report_error("no dynamic invoke found");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
char* dyno_ref = parse_string();
|
char* dyno_ref = parse_string();
|
||||||
if (strcmp(dyno_ref, "<appendix>") == 0) {
|
if (strcmp(dyno_ref, "<appendix>") == 0) {
|
||||||
@ -431,12 +431,12 @@ class CompileReplay : public StackObj {
|
|||||||
} else if (strcmp(dyno_ref, "<adapter>") == 0) {
|
} else if (strcmp(dyno_ref, "<adapter>") == 0) {
|
||||||
if (!parse_terminator()) {
|
if (!parse_terminator()) {
|
||||||
report_error("no dynamic invoke found");
|
report_error("no dynamic invoke found");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
Method* adapter = cp_cache_entry->f1_as_method();
|
Method* adapter = cp_cache_entry->f1_as_method();
|
||||||
if (adapter == NULL) {
|
if (adapter == nullptr) {
|
||||||
report_error("no adapter found");
|
report_error("no adapter found");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return adapter->method_holder();
|
return adapter->method_holder();
|
||||||
} else if (strcmp(dyno_ref, "<bsm>") == 0) {
|
} else if (strcmp(dyno_ref, "<bsm>") == 0) {
|
||||||
@ -445,18 +445,18 @@ class CompileReplay : public StackObj {
|
|||||||
obj = cp->resolve_possibly_cached_constant_at(bootstrap_specifier.bsm_index(), CHECK_NULL);
|
obj = cp->resolve_possibly_cached_constant_at(bootstrap_specifier.bsm_index(), CHECK_NULL);
|
||||||
} else {
|
} else {
|
||||||
report_error("unrecognized token");
|
report_error("unrecognized token");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// constant pool ref (MethodHandle)
|
// constant pool ref (MethodHandle)
|
||||||
if (strcmp(ref, "cpi") != 0) {
|
if (strcmp(ref, "cpi") != 0) {
|
||||||
report_error("unexpected token");
|
report_error("unexpected token");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
Klass* k = parse_klass(CHECK_NULL);
|
Klass* k = parse_klass(CHECK_NULL);
|
||||||
if (k == NULL) {
|
if (k == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
InstanceKlass* ik = InstanceKlass::cast(k);
|
InstanceKlass* ik = InstanceKlass::cast(k);
|
||||||
const constantPoolHandle cp(Thread::current(), ik->constants());
|
const constantPoolHandle cp(Thread::current(), ik->constants());
|
||||||
@ -465,28 +465,28 @@ class CompileReplay : public StackObj {
|
|||||||
|
|
||||||
if (cpi >= cp->length()) {
|
if (cpi >= cp->length()) {
|
||||||
report_error("bad cpi");
|
report_error("bad cpi");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (!cp->tag_at(cpi).is_method_handle()) {
|
if (!cp->tag_at(cpi).is_method_handle()) {
|
||||||
report_error("no method handle found at cpi");
|
report_error("no method handle found at cpi");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
ik->link_class(CHECK_NULL);
|
ik->link_class(CHECK_NULL);
|
||||||
obj = cp->resolve_possibly_cached_constant_at(cpi, CHECK_NULL);
|
obj = cp->resolve_possibly_cached_constant_at(cpi, CHECK_NULL);
|
||||||
}
|
}
|
||||||
if (obj == NULL) {
|
if (obj == nullptr) {
|
||||||
report_error("null cp object found");
|
report_error("null cp object found");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
Klass* k = NULL;
|
Klass* k = nullptr;
|
||||||
skip_ws();
|
skip_ws();
|
||||||
// loop: read fields
|
// loop: read fields
|
||||||
char* field = NULL;
|
char* field = nullptr;
|
||||||
do {
|
do {
|
||||||
field = parse_string();
|
field = parse_string();
|
||||||
if (field == NULL) {
|
if (field == nullptr) {
|
||||||
report_error("no field found");
|
report_error("no field found");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (strcmp(field, ";") == 0) {
|
if (strcmp(field, ";") == 0) {
|
||||||
break;
|
break;
|
||||||
@ -494,32 +494,32 @@ class CompileReplay : public StackObj {
|
|||||||
// raw Method*
|
// raw Method*
|
||||||
if (strcmp(field, "<vmtarget>") == 0) {
|
if (strcmp(field, "<vmtarget>") == 0) {
|
||||||
Method* vmtarget = java_lang_invoke_MemberName::vmtarget(obj);
|
Method* vmtarget = java_lang_invoke_MemberName::vmtarget(obj);
|
||||||
k = (vmtarget == NULL) ? NULL : vmtarget->method_holder();
|
k = (vmtarget == nullptr) ? nullptr : vmtarget->method_holder();
|
||||||
if (k == NULL) {
|
if (k == nullptr) {
|
||||||
report_error("null vmtarget found");
|
report_error("null vmtarget found");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (!parse_terminator()) {
|
if (!parse_terminator()) {
|
||||||
report_error("missing terminator");
|
report_error("missing terminator");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return k;
|
return k;
|
||||||
}
|
}
|
||||||
obj = ciReplay::obj_field(obj, field);
|
obj = ciReplay::obj_field(obj, field);
|
||||||
// array
|
// array
|
||||||
if (obj != NULL && obj->is_objArray()) {
|
if (obj != nullptr && obj->is_objArray()) {
|
||||||
objArrayOop arr = (objArrayOop)obj;
|
objArrayOop arr = (objArrayOop)obj;
|
||||||
int index = parse_int("index");
|
int index = parse_int("index");
|
||||||
if (index >= arr->length()) {
|
if (index >= arr->length()) {
|
||||||
report_error("bad array index");
|
report_error("bad array index");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
obj = arr->obj_at(index);
|
obj = arr->obj_at(index);
|
||||||
}
|
}
|
||||||
} while (obj != NULL);
|
} while (obj != nullptr);
|
||||||
if (obj == NULL) {
|
if (obj == nullptr) {
|
||||||
report_error("null field found");
|
report_error("null field found");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
k = obj->klass();
|
k = obj->klass();
|
||||||
return k;
|
return k;
|
||||||
@ -535,17 +535,17 @@ class CompileReplay : public StackObj {
|
|||||||
if (cp_ref) {
|
if (cp_ref) {
|
||||||
++_bufptr;
|
++_bufptr;
|
||||||
Klass* k = parse_cp_ref(CHECK_NULL);
|
Klass* k = parse_cp_ref(CHECK_NULL);
|
||||||
if (k != NULL && !k->is_hidden()) {
|
if (k != nullptr && !k->is_hidden()) {
|
||||||
report_error("expected hidden class");
|
report_error("expected hidden class");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return k;
|
return k;
|
||||||
}
|
}
|
||||||
char* str = parse_escaped_string();
|
char* str = parse_escaped_string();
|
||||||
Symbol* klass_name = SymbolTable::new_symbol(str);
|
Symbol* klass_name = SymbolTable::new_symbol(str);
|
||||||
if (klass_name != NULL) {
|
if (klass_name != nullptr) {
|
||||||
Klass* k = NULL;
|
Klass* k = nullptr;
|
||||||
if (_iklass != NULL) {
|
if (_iklass != nullptr) {
|
||||||
k = (Klass*)_iklass->find_klass(ciSymbol::make(klass_name->as_C_string()))->constant_encoding();
|
k = (Klass*)_iklass->find_klass(ciSymbol::make(klass_name->as_C_string()))->constant_encoding();
|
||||||
} else {
|
} else {
|
||||||
k = SystemDictionary::resolve_or_fail(klass_name, _loader, _protection_domain, true, THREAD);
|
k = SystemDictionary::resolve_or_fail(klass_name, _loader, _protection_domain, true, THREAD);
|
||||||
@ -557,13 +557,13 @@ class CompileReplay : public StackObj {
|
|||||||
report_error(str);
|
report_error(str);
|
||||||
if (ReplayIgnoreInitErrors) {
|
if (ReplayIgnoreInitErrors) {
|
||||||
CLEAR_PENDING_EXCEPTION;
|
CLEAR_PENDING_EXCEPTION;
|
||||||
_error_message = NULL;
|
_error_message = nullptr;
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return k;
|
return k;
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Lookup a klass
|
// Lookup a klass
|
||||||
@ -575,14 +575,14 @@ class CompileReplay : public StackObj {
|
|||||||
// Parse the standard tuple of <klass> <name> <signature>
|
// Parse the standard tuple of <klass> <name> <signature>
|
||||||
Method* parse_method(TRAPS) {
|
Method* parse_method(TRAPS) {
|
||||||
InstanceKlass* k = (InstanceKlass*)parse_klass(CHECK_NULL);
|
InstanceKlass* k = (InstanceKlass*)parse_klass(CHECK_NULL);
|
||||||
if (k == NULL) {
|
if (k == nullptr) {
|
||||||
report_error("Can't find holder klass");
|
report_error("Can't find holder klass");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
Symbol* method_name = parse_symbol();
|
Symbol* method_name = parse_symbol();
|
||||||
Symbol* method_signature = parse_symbol();
|
Symbol* method_signature = parse_symbol();
|
||||||
Method* m = k->find_method(method_name, method_signature);
|
Method* m = k->find_method(method_name, method_signature);
|
||||||
if (m == NULL) {
|
if (m == nullptr) {
|
||||||
report_error("Can't find method");
|
report_error("Can't find method");
|
||||||
}
|
}
|
||||||
return m;
|
return m;
|
||||||
@ -626,7 +626,7 @@ class CompileReplay : public StackObj {
|
|||||||
tty->print_cr("Error while parsing line %d at position %d: %s\n", line_no, pos, _error_message);
|
tty->print_cr("Error while parsing line %d at position %d: %s\n", line_no, pos, _error_message);
|
||||||
if (ReplayIgnoreInitErrors) {
|
if (ReplayIgnoreInitErrors) {
|
||||||
CLEAR_PENDING_EXCEPTION;
|
CLEAR_PENDING_EXCEPTION;
|
||||||
_error_message = NULL;
|
_error_message = nullptr;
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -638,7 +638,7 @@ class CompileReplay : public StackObj {
|
|||||||
|
|
||||||
void process_command(TRAPS) {
|
void process_command(TRAPS) {
|
||||||
char* cmd = parse_string();
|
char* cmd = parse_string();
|
||||||
if (cmd == NULL) {
|
if (cmd == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (strcmp("#", cmd) == 0) {
|
if (strcmp("#", cmd) == 0) {
|
||||||
@ -679,7 +679,7 @@ class CompileReplay : public StackObj {
|
|||||||
// validation of comp_level
|
// validation of comp_level
|
||||||
bool is_valid_comp_level(int comp_level) {
|
bool is_valid_comp_level(int comp_level) {
|
||||||
const int msg_len = 256;
|
const int msg_len = 256;
|
||||||
char* msg = NULL;
|
char* msg = nullptr;
|
||||||
if (!is_compile(comp_level)) {
|
if (!is_compile(comp_level)) {
|
||||||
msg = NEW_RESOURCE_ARRAY(char, msg_len);
|
msg = NEW_RESOURCE_ARRAY(char, msg_len);
|
||||||
jio_snprintf(msg, msg_len, "%d isn't compilation level", comp_level);
|
jio_snprintf(msg, msg_len, "%d isn't compilation level", comp_level);
|
||||||
@ -690,7 +690,7 @@ class CompileReplay : public StackObj {
|
|||||||
msg = NEW_RESOURCE_ARRAY(char, msg_len);
|
msg = NEW_RESOURCE_ARRAY(char, msg_len);
|
||||||
jio_snprintf(msg, msg_len, "compilation level %d requires C2", comp_level);
|
jio_snprintf(msg, msg_len, "compilation level %d requires C2", comp_level);
|
||||||
}
|
}
|
||||||
if (msg != NULL) {
|
if (msg != nullptr) {
|
||||||
report_error(msg);
|
report_error(msg);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -709,22 +709,22 @@ class CompileReplay : public StackObj {
|
|||||||
c = get_line(c);
|
c = get_line(c);
|
||||||
// Expecting only lines with "compile" command in inline replay file.
|
// Expecting only lines with "compile" command in inline replay file.
|
||||||
char* cmd = parse_string();
|
char* cmd = parse_string();
|
||||||
if (cmd == NULL || strcmp("compile", cmd) != 0) {
|
if (cmd == nullptr || strcmp("compile", cmd) != 0) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
process_compile(CHECK_NULL);
|
process_compile(CHECK_NULL);
|
||||||
if (had_error()) {
|
if (had_error()) {
|
||||||
tty->print_cr("Error while parsing line %d: %s\n", line_no, _error_message);
|
tty->print_cr("Error while parsing line %d: %s\n", line_no, _error_message);
|
||||||
tty->print_cr("%s", _buffer);
|
tty->print_cr("%s", _buffer);
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (_ci_inline_records != NULL && _ci_inline_records->length() > 0) {
|
if (_ci_inline_records != nullptr && _ci_inline_records->length() > 0) {
|
||||||
// Found inlining record for the requested method.
|
// Found inlining record for the requested method.
|
||||||
return _ci_inline_records;
|
return _ci_inline_records;
|
||||||
}
|
}
|
||||||
line_no++;
|
line_no++;
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// compile <klass> <name> <signature> <entry_bci> <comp_level> inline <count> (<depth> <bci> <inline_late> <klass> <name> <signature>)*
|
// compile <klass> <name> <signature> <entry_bci> <comp_level> inline <count> (<depth> <bci> <inline_late> <klass> <name> <signature>)*
|
||||||
@ -736,7 +736,7 @@ class CompileReplay : public StackObj {
|
|||||||
if (!is_valid_comp_level(comp_level)) {
|
if (!is_valid_comp_level(comp_level)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (_imethod != NULL) {
|
if (_imethod != nullptr) {
|
||||||
// Replay Inlining
|
// Replay Inlining
|
||||||
if (entry_bci != _entry_bci || comp_level != _comp_level) {
|
if (entry_bci != _entry_bci || comp_level != _comp_level) {
|
||||||
return;
|
return;
|
||||||
@ -778,7 +778,7 @@ class CompileReplay : public StackObj {
|
|||||||
new_ciInlineRecord(inl_method, bci, depth, inline_late);
|
new_ciInlineRecord(inl_method, bci, depth, inline_late);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_imethod != NULL) {
|
if (_imethod != nullptr) {
|
||||||
return; // Replay Inlining
|
return; // Replay Inlining
|
||||||
}
|
}
|
||||||
InstanceKlass* ik = method->method_holder();
|
InstanceKlass* ik = method->method_holder();
|
||||||
@ -796,13 +796,13 @@ class CompileReplay : public StackObj {
|
|||||||
}
|
}
|
||||||
// Make sure the existence of a prior compile doesn't stop this one
|
// Make sure the existence of a prior compile doesn't stop this one
|
||||||
CompiledMethod* nm = (entry_bci != InvocationEntryBci) ? method->lookup_osr_nmethod_for(entry_bci, comp_level, true) : method->code();
|
CompiledMethod* nm = (entry_bci != InvocationEntryBci) ? method->lookup_osr_nmethod_for(entry_bci, comp_level, true) : method->code();
|
||||||
if (nm != NULL) {
|
if (nm != nullptr) {
|
||||||
nm->make_not_entrant();
|
nm->make_not_entrant();
|
||||||
}
|
}
|
||||||
replay_state = this;
|
replay_state = this;
|
||||||
CompileBroker::compile_method(methodHandle(THREAD, method), entry_bci, comp_level,
|
CompileBroker::compile_method(methodHandle(THREAD, method), entry_bci, comp_level,
|
||||||
methodHandle(), 0, CompileTask::Reason_Replay, THREAD);
|
methodHandle(), 0, CompileTask::Reason_Replay, THREAD);
|
||||||
replay_state = NULL;
|
replay_state = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ciMethod <klass> <name> <signature> <invocation_counter> <backedge_counter> <interpreter_invocation_count> <interpreter_throwout_count> <instructions_size>
|
// ciMethod <klass> <name> <signature> <invocation_counter> <backedge_counter> <interpreter_invocation_count> <interpreter_throwout_count> <instructions_size>
|
||||||
@ -826,7 +826,7 @@ class CompileReplay : public StackObj {
|
|||||||
// To be properly initialized, some profiling in the MDO needs the
|
// To be properly initialized, some profiling in the MDO needs the
|
||||||
// method to be rewritten (number of arguments at a call for instance)
|
// method to be rewritten (number of arguments at a call for instance)
|
||||||
method->method_holder()->link_class(CHECK);
|
method->method_holder()->link_class(CHECK);
|
||||||
assert(method->method_data() == NULL, "Should only be initialized once");
|
assert(method->method_data() == nullptr, "Should only be initialized once");
|
||||||
ClassLoaderData* loader_data = method->method_holder()->class_loader_data();
|
ClassLoaderData* loader_data = method->method_holder()->class_loader_data();
|
||||||
MethodData* method_data = MethodData::allocate(loader_data, methodHandle(THREAD, method), CHECK);
|
MethodData* method_data = MethodData::allocate(loader_data, methodHandle(THREAD, method), CHECK);
|
||||||
method->set_method_data(method_data);
|
method->set_method_data(method_data);
|
||||||
@ -841,11 +841,11 @@ class CompileReplay : public StackObj {
|
|||||||
}
|
}
|
||||||
|
|
||||||
rec->_orig_data = parse_data("orig", rec->_orig_data_length);
|
rec->_orig_data = parse_data("orig", rec->_orig_data_length);
|
||||||
if (rec->_orig_data == NULL) {
|
if (rec->_orig_data == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
rec->_data = parse_intptr_data("data", rec->_data_length);
|
rec->_data = parse_intptr_data("data", rec->_data_length);
|
||||||
if (rec->_data == NULL) {
|
if (rec->_data == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!parse_tag_and_count("oops", rec->_classes_length)) {
|
if (!parse_tag_and_count("oops", rec->_classes_length)) {
|
||||||
@ -889,8 +889,8 @@ class CompileReplay : public StackObj {
|
|||||||
Klass* k = parse_klass(CHECK);
|
Klass* k = parse_klass(CHECK);
|
||||||
|
|
||||||
if (_version >= 1) {
|
if (_version >= 1) {
|
||||||
if (!_protection_domain_initialized && k != NULL) {
|
if (!_protection_domain_initialized && k != nullptr) {
|
||||||
assert(_protection_domain() == NULL, "must be uninitialized");
|
assert(_protection_domain() == nullptr, "must be uninitialized");
|
||||||
// The first entry is the holder class of the method for which a replay compilation is requested.
|
// The first entry is the holder class of the method for which a replay compilation is requested.
|
||||||
// Use the same protection domain to load all subsequent classes in order to resolve all classes
|
// Use the same protection domain to load all subsequent classes in order to resolve all classes
|
||||||
// in signatures of inlinees. This ensures that inlining can be done as stated in the replay file.
|
// in signatures of inlinees. This ensures that inlining can be done as stated in the replay file.
|
||||||
@ -900,11 +900,11 @@ class CompileReplay : public StackObj {
|
|||||||
_protection_domain_initialized = true;
|
_protection_domain_initialized = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (k == NULL) {
|
if (k == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const char* comment = parse_string();
|
const char* comment = parse_string();
|
||||||
bool is_comment = comment != NULL && strcmp(comment, "#") == 0;
|
bool is_comment = comment != nullptr && strcmp(comment, "#") == 0;
|
||||||
if (k->is_hidden() != is_comment) {
|
if (k->is_hidden() != is_comment) {
|
||||||
report_error("hidden class with comment expected");
|
report_error("hidden class with comment expected");
|
||||||
return;
|
return;
|
||||||
@ -926,7 +926,7 @@ class CompileReplay : public StackObj {
|
|||||||
// constant pool tags are in the same state.
|
// constant pool tags are in the same state.
|
||||||
void process_ciInstanceKlass(TRAPS) {
|
void process_ciInstanceKlass(TRAPS) {
|
||||||
InstanceKlass* k = (InstanceKlass*)parse_klass(CHECK);
|
InstanceKlass* k = (InstanceKlass*)parse_klass(CHECK);
|
||||||
if (k == NULL) {
|
if (k == nullptr) {
|
||||||
skip_remaining();
|
skip_remaining();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1025,8 +1025,8 @@ class CompileReplay : public StackObj {
|
|||||||
void process_staticfield(TRAPS) {
|
void process_staticfield(TRAPS) {
|
||||||
InstanceKlass* k = (InstanceKlass *)parse_klass(CHECK);
|
InstanceKlass* k = (InstanceKlass *)parse_klass(CHECK);
|
||||||
|
|
||||||
if (k == NULL || ReplaySuppressInitializers == 0 ||
|
if (k == nullptr || ReplaySuppressInitializers == 0 ||
|
||||||
(ReplaySuppressInitializers == 2 && k->class_loader() == NULL)) {
|
(ReplaySuppressInitializers == 2 && k->class_loader() == nullptr)) {
|
||||||
skip_remaining();
|
skip_remaining();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1048,12 +1048,12 @@ class CompileReplay : public StackObj {
|
|||||||
oop java_mirror = k->java_mirror();
|
oop java_mirror = k->java_mirror();
|
||||||
if (field_signature[0] == JVM_SIGNATURE_ARRAY) {
|
if (field_signature[0] == JVM_SIGNATURE_ARRAY) {
|
||||||
int length = parse_int("array length");
|
int length = parse_int("array length");
|
||||||
oop value = NULL;
|
oop value = nullptr;
|
||||||
|
|
||||||
if (field_signature[1] == JVM_SIGNATURE_ARRAY) {
|
if (field_signature[1] == JVM_SIGNATURE_ARRAY) {
|
||||||
// multi dimensional array
|
// multi dimensional array
|
||||||
ArrayKlass* kelem = (ArrayKlass *)parse_klass(CHECK);
|
ArrayKlass* kelem = (ArrayKlass *)parse_klass(CHECK);
|
||||||
if (kelem == NULL) {
|
if (kelem == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int rank = 0;
|
int rank = 0;
|
||||||
@ -1175,7 +1175,7 @@ class CompileReplay : public StackObj {
|
|||||||
return rec;
|
return rec;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create and initialize a record for a ciInstanceKlass which was present at replay dump time.
|
// Create and initialize a record for a ciInstanceKlass which was present at replay dump time.
|
||||||
@ -1197,7 +1197,7 @@ class CompileReplay : public StackObj {
|
|||||||
return rec;
|
return rec;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create and initialize a record for a ciMethodData
|
// Create and initialize a record for a ciMethodData
|
||||||
@ -1223,7 +1223,7 @@ class CompileReplay : public StackObj {
|
|||||||
return rec;
|
return rec;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create and initialize a record for a ciInlineRecord
|
// Create and initialize a record for a ciInlineRecord
|
||||||
@ -1241,15 +1241,15 @@ class CompileReplay : public StackObj {
|
|||||||
|
|
||||||
// Lookup inlining data for a ciMethod
|
// Lookup inlining data for a ciMethod
|
||||||
ciInlineRecord* find_ciInlineRecord(Method* method, int bci, int depth) {
|
ciInlineRecord* find_ciInlineRecord(Method* method, int bci, int depth) {
|
||||||
if (_ci_inline_records != NULL) {
|
if (_ci_inline_records != nullptr) {
|
||||||
return find_ciInlineRecord(_ci_inline_records, method, bci, depth);
|
return find_ciInlineRecord(_ci_inline_records, method, bci, depth);
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ciInlineRecord* find_ciInlineRecord(GrowableArray<ciInlineRecord*>* records,
|
static ciInlineRecord* find_ciInlineRecord(GrowableArray<ciInlineRecord*>* records,
|
||||||
Method* method, int bci, int depth) {
|
Method* method, int bci, int depth) {
|
||||||
if (records != NULL) {
|
if (records != nullptr) {
|
||||||
const char* klass_name = method->method_holder()->name()->as_utf8();
|
const char* klass_name = method->method_holder()->name()->as_utf8();
|
||||||
const char* method_name = method->name()->as_utf8();
|
const char* method_name = method->name()->as_utf8();
|
||||||
const char* signature = method->signature()->as_utf8();
|
const char* signature = method->signature()->as_utf8();
|
||||||
@ -1264,7 +1264,7 @@ class CompileReplay : public StackObj {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* error_message() {
|
const char* error_message() {
|
||||||
@ -1272,7 +1272,7 @@ class CompileReplay : public StackObj {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void reset() {
|
void reset() {
|
||||||
_error_message = NULL;
|
_error_message = nullptr;
|
||||||
_ci_method_records.clear();
|
_ci_method_records.clear();
|
||||||
_ci_method_data_records.clear();
|
_ci_method_data_records.clear();
|
||||||
}
|
}
|
||||||
@ -1335,13 +1335,13 @@ void ciReplay::replay(TRAPS) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool ciReplay::no_replay_state() {
|
bool ciReplay::no_replay_state() {
|
||||||
return replay_state == NULL;
|
return replay_state == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void* ciReplay::load_inline_data(ciMethod* method, int entry_bci, int comp_level) {
|
void* ciReplay::load_inline_data(ciMethod* method, int entry_bci, int comp_level) {
|
||||||
if (FLAG_IS_DEFAULT(InlineDataFile)) {
|
if (FLAG_IS_DEFAULT(InlineDataFile)) {
|
||||||
tty->print_cr("ERROR: no inline replay data file specified (use -XX:InlineDataFile=inline_pid12345.txt).");
|
tty->print_cr("ERROR: no inline replay data file specified (use -XX:InlineDataFile=inline_pid12345.txt).");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
@ -1349,7 +1349,7 @@ void* ciReplay::load_inline_data(ciMethod* method, int entry_bci, int comp_level
|
|||||||
CompileReplay rp(InlineDataFile, THREAD);
|
CompileReplay rp(InlineDataFile, THREAD);
|
||||||
if (!rp.can_replay()) {
|
if (!rp.can_replay()) {
|
||||||
tty->print_cr("ciReplay: !rp.can_replay()");
|
tty->print_cr("ciReplay: !rp.can_replay()");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
void* data = rp.process_inline(method, method->get_Method(), entry_bci, comp_level, THREAD);
|
void* data = rp.process_inline(method, method->get_Method(), entry_bci, comp_level, THREAD);
|
||||||
if (HAS_PENDING_EXCEPTION) {
|
if (HAS_PENDING_EXCEPTION) {
|
||||||
@ -1357,12 +1357,12 @@ void* ciReplay::load_inline_data(ciMethod* method, int entry_bci, int comp_level
|
|||||||
CLEAR_PENDING_EXCEPTION;
|
CLEAR_PENDING_EXCEPTION;
|
||||||
java_lang_Throwable::print_stack_trace(throwable, tty);
|
java_lang_Throwable::print_stack_trace(throwable, tty);
|
||||||
tty->cr();
|
tty->cr();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rp.had_error()) {
|
if (rp.had_error()) {
|
||||||
tty->print_cr("ciReplay: Failed on %s", rp.error_message());
|
tty->print_cr("ciReplay: Failed on %s", rp.error_message());
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
@ -1418,7 +1418,7 @@ void ciReplay::initialize(ciMethodData* m) {
|
|||||||
|
|
||||||
Method* method = m->get_MethodData()->method();
|
Method* method = m->get_MethodData()->method();
|
||||||
ciMethodDataRecord* rec = replay_state->find_ciMethodDataRecord(method);
|
ciMethodDataRecord* rec = replay_state->find_ciMethodDataRecord(method);
|
||||||
if (rec == NULL) {
|
if (rec == nullptr) {
|
||||||
// This indicates some mismatch with the original environment and
|
// This indicates some mismatch with the original environment and
|
||||||
// the replay environment though it's not always enough to
|
// the replay environment though it's not always enough to
|
||||||
// interfere with reproducing a bug
|
// interfere with reproducing a bug
|
||||||
@ -1438,7 +1438,7 @@ void ciReplay::initialize(ciMethodData* m) {
|
|||||||
Klass *k = rec->_classes[i];
|
Klass *k = rec->_classes[i];
|
||||||
// In case this class pointer is is tagged, preserve the tag bits
|
// In case this class pointer is is tagged, preserve the tag bits
|
||||||
intptr_t status = 0;
|
intptr_t status = 0;
|
||||||
if (k != NULL) {
|
if (k != nullptr) {
|
||||||
status = ciTypeEntries::with_status(env->get_metadata(k)->as_klass(), rec->_data[rec->_classes_offsets[i]]);
|
status = ciTypeEntries::with_status(env->get_metadata(k)->as_klass(), rec->_data[rec->_classes_offsets[i]]);
|
||||||
}
|
}
|
||||||
rec->_data[rec->_classes_offsets[i]] = status;
|
rec->_data[rec->_classes_offsets[i]] = status;
|
||||||
@ -1468,25 +1468,25 @@ bool ciReplay::should_not_inline(ciMethod* method) {
|
|||||||
}
|
}
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
// ciMethod without a record shouldn't be inlined.
|
// ciMethod without a record shouldn't be inlined.
|
||||||
return replay_state->find_ciMethodRecord(method->get_Method()) == NULL;
|
return replay_state->find_ciMethodRecord(method->get_Method()) == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ciReplay::should_inline(void* data, ciMethod* method, int bci, int inline_depth, bool& should_delay) {
|
bool ciReplay::should_inline(void* data, ciMethod* method, int bci, int inline_depth, bool& should_delay) {
|
||||||
if (data != NULL) {
|
if (data != nullptr) {
|
||||||
GrowableArray<ciInlineRecord*>* records = (GrowableArray<ciInlineRecord*>*)data;
|
GrowableArray<ciInlineRecord*>* records = (GrowableArray<ciInlineRecord*>*)data;
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
// Inline record are ordered by bci and depth.
|
// Inline record are ordered by bci and depth.
|
||||||
ciInlineRecord* record = CompileReplay::find_ciInlineRecord(records, method->get_Method(), bci, inline_depth);
|
ciInlineRecord* record = CompileReplay::find_ciInlineRecord(records, method->get_Method(), bci, inline_depth);
|
||||||
if (record == NULL) {
|
if (record == nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
should_delay = record->_inline_late;
|
should_delay = record->_inline_late;
|
||||||
return true;
|
return true;
|
||||||
} else if (replay_state != NULL) {
|
} else if (replay_state != nullptr) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
// Inline record are ordered by bci and depth.
|
// Inline record are ordered by bci and depth.
|
||||||
ciInlineRecord* record = replay_state->find_ciInlineRecord(method->get_Method(), bci, inline_depth);
|
ciInlineRecord* record = replay_state->find_ciInlineRecord(method->get_Method(), bci, inline_depth);
|
||||||
if (record == NULL) {
|
if (record == nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
should_delay = record->_inline_late;
|
should_delay = record->_inline_late;
|
||||||
@ -1496,15 +1496,15 @@ bool ciReplay::should_inline(void* data, ciMethod* method, int bci, int inline_d
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool ciReplay::should_not_inline(void* data, ciMethod* method, int bci, int inline_depth) {
|
bool ciReplay::should_not_inline(void* data, ciMethod* method, int bci, int inline_depth) {
|
||||||
if (data != NULL) {
|
if (data != nullptr) {
|
||||||
GrowableArray<ciInlineRecord*>* records = (GrowableArray<ciInlineRecord*>*)data;
|
GrowableArray<ciInlineRecord*>* records = (GrowableArray<ciInlineRecord*>*)data;
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
// Inline record are ordered by bci and depth.
|
// Inline record are ordered by bci and depth.
|
||||||
return CompileReplay::find_ciInlineRecord(records, method->get_Method(), bci, inline_depth) == NULL;
|
return CompileReplay::find_ciInlineRecord(records, method->get_Method(), bci, inline_depth) == nullptr;
|
||||||
} else if (replay_state != NULL) {
|
} else if (replay_state != nullptr) {
|
||||||
VM_ENTRY_MARK;
|
VM_ENTRY_MARK;
|
||||||
// Inline record are ordered by bci and depth.
|
// Inline record are ordered by bci and depth.
|
||||||
return replay_state->find_ciInlineRecord(method->get_Method(), bci, inline_depth) == NULL;
|
return replay_state->find_ciInlineRecord(method->get_Method(), bci, inline_depth) == nullptr;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -1519,7 +1519,7 @@ void ciReplay::initialize(ciMethod* m) {
|
|||||||
|
|
||||||
Method* method = m->get_Method();
|
Method* method = m->get_Method();
|
||||||
ciMethodRecord* rec = replay_state->find_ciMethodRecord(method);
|
ciMethodRecord* rec = replay_state->find_ciMethodRecord(method);
|
||||||
if (rec == NULL) {
|
if (rec == nullptr) {
|
||||||
// This indicates some mismatch with the original environment and
|
// This indicates some mismatch with the original environment and
|
||||||
// the replay environment though it's not always enough to
|
// the replay environment though it's not always enough to
|
||||||
// interfere with reproducing a bug
|
// interfere with reproducing a bug
|
||||||
@ -1533,7 +1533,7 @@ void ciReplay::initialize(ciMethod* m) {
|
|||||||
m->_interpreter_invocation_count = rec->_interpreter_invocation_count;
|
m->_interpreter_invocation_count = rec->_interpreter_invocation_count;
|
||||||
m->_interpreter_throwout_count = rec->_interpreter_throwout_count;
|
m->_interpreter_throwout_count = rec->_interpreter_throwout_count;
|
||||||
MethodCounters* mcs = method->get_method_counters(CHECK_AND_CLEAR);
|
MethodCounters* mcs = method->get_method_counters(CHECK_AND_CLEAR);
|
||||||
guarantee(mcs != NULL, "method counters allocation failed");
|
guarantee(mcs != nullptr, "method counters allocation failed");
|
||||||
mcs->invocation_counter()->_counter = rec->_invocation_counter;
|
mcs->invocation_counter()->_counter = rec->_invocation_counter;
|
||||||
mcs->backedge_counter()->_counter = rec->_backedge_counter;
|
mcs->backedge_counter()->_counter = rec->_backedge_counter;
|
||||||
}
|
}
|
||||||
@ -1544,7 +1544,7 @@ void ciReplay::initialize(ciInstanceKlass* ci_ik, InstanceKlass* ik) {
|
|||||||
|
|
||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
ciInstanceKlassRecord* rec = replay_state->find_ciInstanceKlass(ik);
|
ciInstanceKlassRecord* rec = replay_state->find_ciInstanceKlass(ik);
|
||||||
assert(rec != NULL, "ciInstanceKlass must be whitelisted");
|
assert(rec != nullptr, "ciInstanceKlass must be whitelisted");
|
||||||
ci_ik->_java_mirror = CURRENT_ENV->get_instance(JNIHandles::resolve(rec->_java_mirror));
|
ci_ik->_java_mirror = CURRENT_ENV->get_instance(JNIHandles::resolve(rec->_java_mirror));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1557,7 +1557,7 @@ bool ciReplay::is_loaded(Method* method) {
|
|||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
|
|
||||||
ciMethodRecord* rec = replay_state->find_ciMethodRecord(method);
|
ciMethodRecord* rec = replay_state->find_ciMethodRecord(method);
|
||||||
return rec != NULL;
|
return rec != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ciReplay::is_klass_unresolved(const InstanceKlass* klass) {
|
bool ciReplay::is_klass_unresolved(const InstanceKlass* klass) {
|
||||||
@ -1567,7 +1567,7 @@ bool ciReplay::is_klass_unresolved(const InstanceKlass* klass) {
|
|||||||
|
|
||||||
// Check if klass is found on whitelist.
|
// Check if klass is found on whitelist.
|
||||||
ciInstanceKlassRecord* rec = replay_state->find_ciInstanceKlass(klass);
|
ciInstanceKlassRecord* rec = replay_state->find_ciInstanceKlass(klass);
|
||||||
return rec == NULL;
|
return rec == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
oop ciReplay::obj_field(oop obj, Symbol* name) {
|
oop ciReplay::obj_field(oop obj, Symbol* name) {
|
||||||
@ -1595,14 +1595,14 @@ oop ciReplay::obj_field(oop obj, Symbol* name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ik = ik->java_super();
|
ik = ik->java_super();
|
||||||
} while (ik != NULL);
|
} while (ik != nullptr);
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
oop ciReplay::obj_field(oop obj, const char *name) {
|
oop ciReplay::obj_field(oop obj, const char *name) {
|
||||||
Symbol* fname = SymbolTable::probe(name, (int)strlen(name));
|
Symbol* fname = SymbolTable::probe(name, (int)strlen(name));
|
||||||
if (fname == NULL) {
|
if (fname == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return obj_field(obj, fname);
|
return obj_field(obj, fname);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -39,10 +39,10 @@
|
|||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciSignature::ciSignature
|
// ciSignature::ciSignature
|
||||||
ciSignature::ciSignature(ciKlass* accessing_klass, const constantPoolHandle& cpool, ciSymbol* symbol)
|
ciSignature::ciSignature(ciKlass* accessing_klass, const constantPoolHandle& cpool, ciSymbol* symbol)
|
||||||
: _symbol(symbol), _accessing_klass(accessing_klass), _types(CURRENT_ENV->arena(), 8, 0, NULL) {
|
: _symbol(symbol), _accessing_klass(accessing_klass), _types(CURRENT_ENV->arena(), 8, 0, nullptr) {
|
||||||
ASSERT_IN_VM;
|
ASSERT_IN_VM;
|
||||||
EXCEPTION_CONTEXT;
|
EXCEPTION_CONTEXT;
|
||||||
assert(accessing_klass != NULL, "need origin of access");
|
assert(accessing_klass != nullptr, "need origin of access");
|
||||||
|
|
||||||
ciEnv* env = CURRENT_ENV;
|
ciEnv* env = CURRENT_ENV;
|
||||||
|
|
||||||
@ -50,7 +50,7 @@ ciSignature::ciSignature(ciKlass* accessing_klass, const constantPoolHandle& cpo
|
|||||||
ResourceMark rm(THREAD);
|
ResourceMark rm(THREAD);
|
||||||
for (SignatureStream ss(symbol->get_symbol()); !ss.is_done(); ss.next()) {
|
for (SignatureStream ss(symbol->get_symbol()); !ss.is_done(); ss.next()) {
|
||||||
// Process one element of the signature
|
// Process one element of the signature
|
||||||
ciType* type = NULL;
|
ciType* type = nullptr;
|
||||||
if (ss.is_reference()) {
|
if (ss.is_reference()) {
|
||||||
ciSymbol* klass_name = env->get_symbol(ss.as_symbol());
|
ciSymbol* klass_name = env->get_symbol(ss.as_symbol());
|
||||||
type = env->get_klass_by_name_impl(_accessing_klass, cpool, klass_name, false);
|
type = env->get_klass_by_name_impl(_accessing_klass, cpool, klass_name, false);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -84,16 +84,16 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
ciBytecodeStream() {
|
ciBytecodeStream() {
|
||||||
reset_to_method(NULL);
|
reset_to_method(nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
ciMethod* method() const { return _method; }
|
ciMethod* method() const { return _method; }
|
||||||
|
|
||||||
void reset_to_method(ciMethod* m) {
|
void reset_to_method(ciMethod* m) {
|
||||||
_method = m;
|
_method = m;
|
||||||
if (m == NULL) {
|
if (m == nullptr) {
|
||||||
_holder = NULL;
|
_holder = nullptr;
|
||||||
reset(NULL, 0);
|
reset(nullptr, 0);
|
||||||
} else {
|
} else {
|
||||||
_holder = m->holder();
|
_holder = m->holder();
|
||||||
reset(m->code(), m->code_size());
|
reset(m->code(), m->code_size());
|
||||||
@ -304,7 +304,7 @@ private:
|
|||||||
// holder is a method's holder
|
// holder is a method's holder
|
||||||
ciKlass* _holder;
|
ciKlass* _holder;
|
||||||
public:
|
public:
|
||||||
ciSignatureStream(ciSignature* signature, ciKlass* holder = NULL) {
|
ciSignatureStream(ciSignature* signature, ciKlass* holder = nullptr) {
|
||||||
_sig = signature;
|
_sig = signature;
|
||||||
_pos = 0;
|
_pos = 0;
|
||||||
_holder = holder;
|
_holder = holder;
|
||||||
@ -331,9 +331,9 @@ public:
|
|||||||
// next klass in the signature
|
// next klass in the signature
|
||||||
ciKlass* next_klass() {
|
ciKlass* next_klass() {
|
||||||
ciKlass* sig_k;
|
ciKlass* sig_k;
|
||||||
if (_holder != NULL) {
|
if (_holder != nullptr) {
|
||||||
sig_k = _holder;
|
sig_k = _holder;
|
||||||
_holder = NULL;
|
_holder = nullptr;
|
||||||
} else {
|
} else {
|
||||||
while (!type()->is_klass()) {
|
while (!type()->is_klass()) {
|
||||||
next();
|
next();
|
||||||
@ -373,13 +373,13 @@ public:
|
|||||||
|
|
||||||
_pos = 0;
|
_pos = 0;
|
||||||
_end = _method->_handler_count;
|
_end = _method->_handler_count;
|
||||||
_exception_klass = NULL;
|
_exception_klass = nullptr;
|
||||||
_bci = -1;
|
_bci = -1;
|
||||||
_is_exact = false;
|
_is_exact = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ciExceptionHandlerStream(ciMethod* method, int bci,
|
ciExceptionHandlerStream(ciMethod* method, int bci,
|
||||||
ciInstanceKlass* exception_klass = NULL,
|
ciInstanceKlass* exception_klass = nullptr,
|
||||||
bool is_exact = false) {
|
bool is_exact = false) {
|
||||||
_method = method;
|
_method = method;
|
||||||
|
|
||||||
@ -388,9 +388,9 @@ public:
|
|||||||
|
|
||||||
_pos = -1;
|
_pos = -1;
|
||||||
_end = _method->_handler_count + 1; // include the rethrow handler
|
_end = _method->_handler_count + 1; // include the rethrow handler
|
||||||
_exception_klass = (exception_klass != NULL && exception_klass->is_loaded()
|
_exception_klass = (exception_klass != nullptr && exception_klass->is_loaded()
|
||||||
? exception_klass
|
? exception_klass
|
||||||
: NULL);
|
: nullptr);
|
||||||
_bci = bci;
|
_bci = bci;
|
||||||
assert(_bci >= 0, "bci out of range");
|
assert(_bci >= 0, "bci out of range");
|
||||||
_is_exact = is_exact;
|
_is_exact = is_exact;
|
||||||
@ -424,7 +424,7 @@ public:
|
|||||||
// Found final active catch block.
|
// Found final active catch block.
|
||||||
_end = _pos+1;
|
_end = _pos+1;
|
||||||
return;
|
return;
|
||||||
} else if (_exception_klass == NULL || !handler->catch_klass()->is_loaded()) {
|
} else if (_exception_klass == nullptr || !handler->catch_klass()->is_loaded()) {
|
||||||
// We cannot do any type analysis here. Must conservatively assume
|
// We cannot do any type analysis here. Must conservatively assume
|
||||||
// catch block is reachable.
|
// catch block is reachable.
|
||||||
return;
|
return;
|
||||||
@ -457,7 +457,7 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
// Implementation for declarations in bytecode.hpp
|
// Implementation for declarations in bytecode.hpp
|
||||||
Bytecode::Bytecode(const ciBytecodeStream* stream, address bcp): _bcp(bcp != NULL ? bcp : stream->cur_bcp()), _code(Bytecodes::code_at(NULL, addr_at(0))) {}
|
Bytecode::Bytecode(const ciBytecodeStream* stream, address bcp): _bcp(bcp != nullptr ? bcp : stream->cur_bcp()), _code(Bytecodes::code_at(nullptr, addr_at(0))) {}
|
||||||
Bytecode_lookupswitch::Bytecode_lookupswitch(const ciBytecodeStream* stream): Bytecode(stream) { verify(); }
|
Bytecode_lookupswitch::Bytecode_lookupswitch(const ciBytecodeStream* stream): Bytecode(stream) { verify(); }
|
||||||
Bytecode_tableswitch::Bytecode_tableswitch(const ciBytecodeStream* stream): Bytecode(stream) { verify(); }
|
Bytecode_tableswitch::Bytecode_tableswitch(const ciBytecodeStream* stream): Bytecode(stream) { verify(); }
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -36,7 +36,7 @@
|
|||||||
ciSymbol::ciSymbol(Symbol* s, vmSymbolID sid)
|
ciSymbol::ciSymbol(Symbol* s, vmSymbolID sid)
|
||||||
: _symbol(s), _sid(sid)
|
: _symbol(s), _sid(sid)
|
||||||
{
|
{
|
||||||
assert(_symbol != NULL, "adding null symbol");
|
assert(_symbol != nullptr, "adding null symbol");
|
||||||
_symbol->increment_refcount(); // increment ref count
|
_symbol->increment_refcount(); // increment ref count
|
||||||
assert(sid_ok(), "sid must be consistent with vmSymbols");
|
assert(sid_ok(), "sid must be consistent with vmSymbols");
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -111,7 +111,7 @@ ciType* ciType::make(BasicType t) {
|
|||||||
// Note: Bare T_ADDRESS means a raw pointer type, not a return_address.
|
// Note: Bare T_ADDRESS means a raw pointer type, not a return_address.
|
||||||
assert((uint)t < T_CONFLICT+1, "range check");
|
assert((uint)t < T_CONFLICT+1, "range check");
|
||||||
if (t == T_OBJECT) return ciEnv::_Object_klass; // java/lang/Object
|
if (t == T_OBJECT) return ciEnv::_Object_klass; // java/lang/Object
|
||||||
assert(_basic_types[t] != NULL, "domain check");
|
assert(_basic_types[t] != nullptr, "domain check");
|
||||||
return _basic_types[t];
|
return _basic_types[t];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -57,12 +57,12 @@
|
|||||||
// ciTypeFlow::JsrSet::JsrSet
|
// ciTypeFlow::JsrSet::JsrSet
|
||||||
|
|
||||||
// Allocate growable array storage in Arena.
|
// Allocate growable array storage in Arena.
|
||||||
ciTypeFlow::JsrSet::JsrSet(Arena* arena, int default_len) : _set(arena, default_len, 0, NULL) {
|
ciTypeFlow::JsrSet::JsrSet(Arena* arena, int default_len) : _set(arena, default_len, 0, nullptr) {
|
||||||
assert(arena != NULL, "invariant");
|
assert(arena != nullptr, "invariant");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Allocate growable array storage in current ResourceArea.
|
// Allocate growable array storage in current ResourceArea.
|
||||||
ciTypeFlow::JsrSet::JsrSet(int default_len) : _set(default_len, 0, NULL) {}
|
ciTypeFlow::JsrSet::JsrSet(int default_len) : _set(default_len, 0, nullptr) {}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// ciTypeFlow::JsrSet::copy_into
|
// ciTypeFlow::JsrSet::copy_into
|
||||||
@ -167,7 +167,7 @@ void ciTypeFlow::JsrSet::insert_jsr_record(JsrRecord* record) {
|
|||||||
|
|
||||||
// Insert the record into the list.
|
// Insert the record into the list.
|
||||||
JsrRecord* swap = record;
|
JsrRecord* swap = record;
|
||||||
JsrRecord* temp = NULL;
|
JsrRecord* temp = nullptr;
|
||||||
for ( ; pos < len; pos++) {
|
for ( ; pos < len; pos++) {
|
||||||
temp = _set.at(pos);
|
temp = _set.at(pos);
|
||||||
_set.at_put(pos, swap);
|
_set.at_put(pos, swap);
|
||||||
@ -368,13 +368,13 @@ const ciTypeFlow::StateVector* ciTypeFlow::get_start_state() {
|
|||||||
ciTypeFlow* non_osr_flow = method()->get_flow_analysis();
|
ciTypeFlow* non_osr_flow = method()->get_flow_analysis();
|
||||||
if (non_osr_flow->failing()) {
|
if (non_osr_flow->failing()) {
|
||||||
record_failure(non_osr_flow->failure_reason());
|
record_failure(non_osr_flow->failure_reason());
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
JsrSet* jsrs = new JsrSet(4);
|
JsrSet* jsrs = new JsrSet(4);
|
||||||
Block* non_osr_block = non_osr_flow->existing_block_at(start_bci(), jsrs);
|
Block* non_osr_block = non_osr_flow->existing_block_at(start_bci(), jsrs);
|
||||||
if (non_osr_block == NULL) {
|
if (non_osr_block == nullptr) {
|
||||||
record_failure("cannot reach OSR point");
|
record_failure("cannot reach OSR point");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
// load up the non-OSR state at this point
|
// load up the non-OSR state at this point
|
||||||
non_osr_block->copy_state_into(state);
|
non_osr_block->copy_state_into(state);
|
||||||
@ -551,7 +551,7 @@ void ciTypeFlow::StateVector::push_translate(ciType* type) {
|
|||||||
void ciTypeFlow::StateVector::do_aaload(ciBytecodeStream* str) {
|
void ciTypeFlow::StateVector::do_aaload(ciBytecodeStream* str) {
|
||||||
pop_int();
|
pop_int();
|
||||||
ciObjArrayKlass* array_klass = pop_objArray();
|
ciObjArrayKlass* array_klass = pop_objArray();
|
||||||
if (array_klass == NULL) {
|
if (array_klass == nullptr) {
|
||||||
// Did aaload on a null reference; push a null and ignore the exception.
|
// Did aaload on a null reference; push a null and ignore the exception.
|
||||||
// This instruction will never continue normally. All we have to do
|
// This instruction will never continue normally. All we have to do
|
||||||
// is report a value that will meet correctly with any downstream
|
// is report a value that will meet correctly with any downstream
|
||||||
@ -588,7 +588,7 @@ void ciTypeFlow::StateVector::do_checkcast(ciBytecodeStream* str) {
|
|||||||
bool will_link;
|
bool will_link;
|
||||||
ciKlass* klass = str->get_klass(will_link);
|
ciKlass* klass = str->get_klass(will_link);
|
||||||
if (!will_link) {
|
if (!will_link) {
|
||||||
// VM's interpreter will not load 'klass' if object is NULL.
|
// VM's interpreter will not load 'klass' if object is null.
|
||||||
// Type flow after this block may still be needed in two situations:
|
// Type flow after this block may still be needed in two situations:
|
||||||
// 1) C2 uses do_null_assert() and continues compilation for later blocks
|
// 1) C2 uses do_null_assert() and continues compilation for later blocks
|
||||||
// 2) C2 does an OSR compile in a later block (see bug 4778368).
|
// 2) C2 does an OSR compile in a later block (see bug 4778368).
|
||||||
@ -648,13 +648,13 @@ void ciTypeFlow::StateVector::do_getstatic(ciBytecodeStream* str) {
|
|||||||
void ciTypeFlow::StateVector::do_invoke(ciBytecodeStream* str,
|
void ciTypeFlow::StateVector::do_invoke(ciBytecodeStream* str,
|
||||||
bool has_receiver) {
|
bool has_receiver) {
|
||||||
bool will_link;
|
bool will_link;
|
||||||
ciSignature* declared_signature = NULL;
|
ciSignature* declared_signature = nullptr;
|
||||||
ciMethod* callee = str->get_method(will_link, &declared_signature);
|
ciMethod* callee = str->get_method(will_link, &declared_signature);
|
||||||
assert(declared_signature != NULL, "cannot be null");
|
assert(declared_signature != nullptr, "cannot be null");
|
||||||
if (!will_link) {
|
if (!will_link) {
|
||||||
// We weren't able to find the method.
|
// We weren't able to find the method.
|
||||||
if (str->cur_bc() == Bytecodes::_invokedynamic) {
|
if (str->cur_bc() == Bytecodes::_invokedynamic) {
|
||||||
trap(str, NULL,
|
trap(str, nullptr,
|
||||||
Deoptimization::make_trap_request
|
Deoptimization::make_trap_request
|
||||||
(Deoptimization::Reason_uninitialized,
|
(Deoptimization::Reason_uninitialized,
|
||||||
Deoptimization::Action_reinterpret));
|
Deoptimization::Action_reinterpret));
|
||||||
@ -721,7 +721,7 @@ void ciTypeFlow::StateVector::do_jsr(ciBytecodeStream* str) {
|
|||||||
// ciTypeFlow::StateVector::do_ldc
|
// ciTypeFlow::StateVector::do_ldc
|
||||||
void ciTypeFlow::StateVector::do_ldc(ciBytecodeStream* str) {
|
void ciTypeFlow::StateVector::do_ldc(ciBytecodeStream* str) {
|
||||||
if (str->is_in_error()) {
|
if (str->is_in_error()) {
|
||||||
trap(str, NULL, Deoptimization::make_trap_request(Deoptimization::Reason_unhandled,
|
trap(str, nullptr, Deoptimization::make_trap_request(Deoptimization::Reason_unhandled,
|
||||||
Deoptimization::Action_none));
|
Deoptimization::Action_none));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -834,9 +834,9 @@ void ciTypeFlow::StateVector::trap(ciBytecodeStream* str, ciKlass* klass, int in
|
|||||||
|
|
||||||
// Log information about this trap:
|
// Log information about this trap:
|
||||||
CompileLog* log = outer()->env()->log();
|
CompileLog* log = outer()->env()->log();
|
||||||
if (log != NULL) {
|
if (log != nullptr) {
|
||||||
int mid = log->identify(outer()->method());
|
int mid = log->identify(outer()->method());
|
||||||
int kid = (klass == NULL)? -1: log->identify(klass);
|
int kid = (klass == nullptr)? -1: log->identify(klass);
|
||||||
log->begin_elem("uncommon_trap method='%d' bci='%d'", mid, str->cur_bci());
|
log->begin_elem("uncommon_trap method='%d' bci='%d'", mid, str->cur_bci());
|
||||||
char buf[100];
|
char buf[100];
|
||||||
log->print(" %s", Deoptimization::format_trap_request(buf, sizeof(buf),
|
log->print(" %s", Deoptimization::format_trap_request(buf, sizeof(buf),
|
||||||
@ -1567,7 +1567,7 @@ void ciTypeFlow::SuccIter::next() {
|
|||||||
next++;
|
next++;
|
||||||
}
|
}
|
||||||
_index = -1;
|
_index = -1;
|
||||||
_succ = NULL;
|
_succ = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -1591,17 +1591,17 @@ void ciTypeFlow::SuccIter::set_succ(Block* succ) {
|
|||||||
// ciTypeFlow::Block::Block
|
// ciTypeFlow::Block::Block
|
||||||
ciTypeFlow::Block::Block(ciTypeFlow* outer,
|
ciTypeFlow::Block::Block(ciTypeFlow* outer,
|
||||||
ciBlock *ciblk,
|
ciBlock *ciblk,
|
||||||
ciTypeFlow::JsrSet* jsrs) : _predecessors(outer->arena(), 1, 0, NULL) {
|
ciTypeFlow::JsrSet* jsrs) : _predecessors(outer->arena(), 1, 0, nullptr) {
|
||||||
_ciblock = ciblk;
|
_ciblock = ciblk;
|
||||||
_exceptions = NULL;
|
_exceptions = nullptr;
|
||||||
_exc_klasses = NULL;
|
_exc_klasses = nullptr;
|
||||||
_successors = NULL;
|
_successors = nullptr;
|
||||||
_state = new (outer->arena()) StateVector(outer);
|
_state = new (outer->arena()) StateVector(outer);
|
||||||
JsrSet* new_jsrs =
|
JsrSet* new_jsrs =
|
||||||
new (outer->arena()) JsrSet(outer->arena(), jsrs->size());
|
new (outer->arena()) JsrSet(outer->arena(), jsrs->size());
|
||||||
jsrs->copy_into(new_jsrs);
|
jsrs->copy_into(new_jsrs);
|
||||||
_jsrs = new_jsrs;
|
_jsrs = new_jsrs;
|
||||||
_next = NULL;
|
_next = nullptr;
|
||||||
_on_work_list = false;
|
_on_work_list = false;
|
||||||
_backedge_copy = false;
|
_backedge_copy = false;
|
||||||
_has_monitorenter = false;
|
_has_monitorenter = false;
|
||||||
@ -1623,9 +1623,9 @@ ciTypeFlow::Block::Block(ciTypeFlow* outer,
|
|||||||
void ciTypeFlow::Block::df_init() {
|
void ciTypeFlow::Block::df_init() {
|
||||||
_pre_order = -1; assert(!has_pre_order(), "");
|
_pre_order = -1; assert(!has_pre_order(), "");
|
||||||
_post_order = -1; assert(!has_post_order(), "");
|
_post_order = -1; assert(!has_post_order(), "");
|
||||||
_loop = NULL;
|
_loop = nullptr;
|
||||||
_irreducible_entry = false;
|
_irreducible_entry = false;
|
||||||
_rpo_next = NULL;
|
_rpo_next = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -1636,7 +1636,7 @@ GrowableArray<ciTypeFlow::Block*>*
|
|||||||
ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
||||||
ciTypeFlow::StateVector* state,
|
ciTypeFlow::StateVector* state,
|
||||||
ciTypeFlow::JsrSet* jsrs) {
|
ciTypeFlow::JsrSet* jsrs) {
|
||||||
if (_successors == NULL) {
|
if (_successors == nullptr) {
|
||||||
if (CITraceTypeFlow) {
|
if (CITraceTypeFlow) {
|
||||||
tty->print(">> Computing successors for block ");
|
tty->print(">> Computing successors for block ");
|
||||||
print_value_on(tty);
|
print_value_on(tty);
|
||||||
@ -1645,18 +1645,18 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
|
|
||||||
ciTypeFlow* analyzer = outer();
|
ciTypeFlow* analyzer = outer();
|
||||||
Arena* arena = analyzer->arena();
|
Arena* arena = analyzer->arena();
|
||||||
Block* block = NULL;
|
Block* block = nullptr;
|
||||||
bool has_successor = !has_trap() &&
|
bool has_successor = !has_trap() &&
|
||||||
(control() != ciBlock::fall_through_bci || limit() < analyzer->code_size());
|
(control() != ciBlock::fall_through_bci || limit() < analyzer->code_size());
|
||||||
if (!has_successor) {
|
if (!has_successor) {
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 1, 0, nullptr);
|
||||||
// No successors
|
// No successors
|
||||||
} else if (control() == ciBlock::fall_through_bci) {
|
} else if (control() == ciBlock::fall_through_bci) {
|
||||||
assert(str->cur_bci() == limit(), "bad block end");
|
assert(str->cur_bci() == limit(), "bad block end");
|
||||||
// This block simply falls through to the next.
|
// This block simply falls through to the next.
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 1, 0, nullptr);
|
||||||
|
|
||||||
Block* block = analyzer->block_at(limit(), _jsrs);
|
Block* block = analyzer->block_at(limit(), _jsrs);
|
||||||
assert(_successors->length() == FALL_THROUGH, "");
|
assert(_successors->length() == FALL_THROUGH, "");
|
||||||
@ -1665,7 +1665,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
int current_bci = str->cur_bci();
|
int current_bci = str->cur_bci();
|
||||||
int next_bci = str->next_bci();
|
int next_bci = str->next_bci();
|
||||||
int branch_bci = -1;
|
int branch_bci = -1;
|
||||||
Block* target = NULL;
|
Block* target = nullptr;
|
||||||
assert(str->next_bci() == limit(), "bad block end");
|
assert(str->next_bci() == limit(), "bad block end");
|
||||||
// This block is not a simple fall-though. Interpret
|
// This block is not a simple fall-though. Interpret
|
||||||
// the current bytecode to find our successors.
|
// the current bytecode to find our successors.
|
||||||
@ -1681,7 +1681,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
// Our successors are the branch target and the next bci.
|
// Our successors are the branch target and the next bci.
|
||||||
branch_bci = str->get_dest();
|
branch_bci = str->get_dest();
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 2, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 2, 0, nullptr);
|
||||||
assert(_successors->length() == IF_NOT_TAKEN, "");
|
assert(_successors->length() == IF_NOT_TAKEN, "");
|
||||||
_successors->append(analyzer->block_at(next_bci, jsrs));
|
_successors->append(analyzer->block_at(next_bci, jsrs));
|
||||||
assert(_successors->length() == IF_TAKEN, "");
|
assert(_successors->length() == IF_TAKEN, "");
|
||||||
@ -1691,7 +1691,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
case Bytecodes::_goto:
|
case Bytecodes::_goto:
|
||||||
branch_bci = str->get_dest();
|
branch_bci = str->get_dest();
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 1, 0, nullptr);
|
||||||
assert(_successors->length() == GOTO_TARGET, "");
|
assert(_successors->length() == GOTO_TARGET, "");
|
||||||
_successors->append(analyzer->block_at(branch_bci, jsrs));
|
_successors->append(analyzer->block_at(branch_bci, jsrs));
|
||||||
break;
|
break;
|
||||||
@ -1699,7 +1699,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
case Bytecodes::_jsr:
|
case Bytecodes::_jsr:
|
||||||
branch_bci = str->get_dest();
|
branch_bci = str->get_dest();
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 1, 0, nullptr);
|
||||||
assert(_successors->length() == GOTO_TARGET, "");
|
assert(_successors->length() == GOTO_TARGET, "");
|
||||||
_successors->append(analyzer->block_at(branch_bci, jsrs));
|
_successors->append(analyzer->block_at(branch_bci, jsrs));
|
||||||
break;
|
break;
|
||||||
@ -1707,7 +1707,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
case Bytecodes::_goto_w:
|
case Bytecodes::_goto_w:
|
||||||
case Bytecodes::_jsr_w:
|
case Bytecodes::_jsr_w:
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 1, 0, nullptr);
|
||||||
assert(_successors->length() == GOTO_TARGET, "");
|
assert(_successors->length() == GOTO_TARGET, "");
|
||||||
_successors->append(analyzer->block_at(str->get_far_dest(), jsrs));
|
_successors->append(analyzer->block_at(str->get_far_dest(), jsrs));
|
||||||
break;
|
break;
|
||||||
@ -1717,7 +1717,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
|
|
||||||
int len = tableswitch.length();
|
int len = tableswitch.length();
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, len+1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, len+1, 0, nullptr);
|
||||||
int bci = current_bci + tableswitch.default_offset();
|
int bci = current_bci + tableswitch.default_offset();
|
||||||
Block* block = analyzer->block_at(bci, jsrs);
|
Block* block = analyzer->block_at(bci, jsrs);
|
||||||
assert(_successors->length() == SWITCH_DEFAULT, "");
|
assert(_successors->length() == SWITCH_DEFAULT, "");
|
||||||
@ -1736,7 +1736,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
|
|
||||||
int npairs = lookupswitch.number_of_pairs();
|
int npairs = lookupswitch.number_of_pairs();
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, npairs+1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, npairs+1, 0, nullptr);
|
||||||
int bci = current_bci + lookupswitch.default_offset();
|
int bci = current_bci + lookupswitch.default_offset();
|
||||||
Block* block = analyzer->block_at(bci, jsrs);
|
Block* block = analyzer->block_at(bci, jsrs);
|
||||||
assert(_successors->length() == SWITCH_DEFAULT, "");
|
assert(_successors->length() == SWITCH_DEFAULT, "");
|
||||||
@ -1756,13 +1756,13 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
case Bytecodes::_dreturn: case Bytecodes::_areturn:
|
case Bytecodes::_dreturn: case Bytecodes::_areturn:
|
||||||
case Bytecodes::_return:
|
case Bytecodes::_return:
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 1, 0, nullptr);
|
||||||
// No successors
|
// No successors
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Bytecodes::_ret: {
|
case Bytecodes::_ret: {
|
||||||
_successors =
|
_successors =
|
||||||
new (arena) GrowableArray<Block*>(arena, 1, 0, NULL);
|
new (arena) GrowableArray<Block*>(arena, 1, 0, nullptr);
|
||||||
|
|
||||||
Cell local = state->local(str->get_index());
|
Cell local = state->local(str->get_index());
|
||||||
ciType* return_address = state->type_at(local);
|
ciType* return_address = state->type_at(local);
|
||||||
@ -1794,7 +1794,7 @@ ciTypeFlow::Block::successors(ciBytecodeStream* str,
|
|||||||
//
|
//
|
||||||
// Compute the exceptional successors and types for this Block.
|
// Compute the exceptional successors and types for this Block.
|
||||||
void ciTypeFlow::Block::compute_exceptions() {
|
void ciTypeFlow::Block::compute_exceptions() {
|
||||||
assert(_exceptions == NULL && _exc_klasses == NULL, "repeat");
|
assert(_exceptions == nullptr && _exc_klasses == nullptr, "repeat");
|
||||||
|
|
||||||
if (CITraceTypeFlow) {
|
if (CITraceTypeFlow) {
|
||||||
tty->print(">> Computing exceptions for block ");
|
tty->print(">> Computing exceptions for block ");
|
||||||
@ -1810,14 +1810,14 @@ void ciTypeFlow::Block::compute_exceptions() {
|
|||||||
|
|
||||||
// Allocate our growable arrays.
|
// Allocate our growable arrays.
|
||||||
int exc_count = str.count();
|
int exc_count = str.count();
|
||||||
_exceptions = new (arena) GrowableArray<Block*>(arena, exc_count, 0, NULL);
|
_exceptions = new (arena) GrowableArray<Block*>(arena, exc_count, 0, nullptr);
|
||||||
_exc_klasses = new (arena) GrowableArray<ciInstanceKlass*>(arena, exc_count,
|
_exc_klasses = new (arena) GrowableArray<ciInstanceKlass*>(arena, exc_count,
|
||||||
0, NULL);
|
0, nullptr);
|
||||||
|
|
||||||
for ( ; !str.is_done(); str.next()) {
|
for ( ; !str.is_done(); str.next()) {
|
||||||
ciExceptionHandler* handler = str.handler();
|
ciExceptionHandler* handler = str.handler();
|
||||||
int bci = handler->handler_bci();
|
int bci = handler->handler_bci();
|
||||||
ciInstanceKlass* klass = NULL;
|
ciInstanceKlass* klass = nullptr;
|
||||||
if (bci == -1) {
|
if (bci == -1) {
|
||||||
// There is no catch all. It is possible to exit the method.
|
// There is no catch all. It is possible to exit the method.
|
||||||
break;
|
break;
|
||||||
@ -1875,7 +1875,7 @@ ciTypeFlow::Block* ciTypeFlow::Block::looping_succ(ciTypeFlow::Loop* lp) {
|
|||||||
return succ;
|
return succ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
@ -1902,18 +1902,18 @@ void ciTypeFlow::Block::print_on(outputStream* st) const {
|
|||||||
st->print (" ");
|
st->print (" ");
|
||||||
print_value_on(st);
|
print_value_on(st);
|
||||||
st->print(" Stored locals: "); def_locals()->print_on(st, outer()->method()->max_locals()); tty->cr();
|
st->print(" Stored locals: "); def_locals()->print_on(st, outer()->method()->max_locals()); tty->cr();
|
||||||
if (loop() && loop()->parent() != NULL) {
|
if (loop() && loop()->parent() != nullptr) {
|
||||||
st->print(" loops:");
|
st->print(" loops:");
|
||||||
Loop* lp = loop();
|
Loop* lp = loop();
|
||||||
do {
|
do {
|
||||||
st->print(" %d<-%d", lp->head()->pre_order(),lp->tail()->pre_order());
|
st->print(" %d<-%d", lp->head()->pre_order(),lp->tail()->pre_order());
|
||||||
if (lp->is_irreducible()) st->print("(ir)");
|
if (lp->is_irreducible()) st->print("(ir)");
|
||||||
lp = lp->parent();
|
lp = lp->parent();
|
||||||
} while (lp->parent() != NULL);
|
} while (lp->parent() != nullptr);
|
||||||
}
|
}
|
||||||
st->cr();
|
st->cr();
|
||||||
_state->print_on(st);
|
_state->print_on(st);
|
||||||
if (_successors == NULL) {
|
if (_successors == nullptr) {
|
||||||
st->print_cr(" No successor information");
|
st->print_cr(" No successor information");
|
||||||
} else {
|
} else {
|
||||||
int num_successors = _successors->length();
|
int num_successors = _successors->length();
|
||||||
@ -1937,7 +1937,7 @@ void ciTypeFlow::Block::print_on(outputStream* st) const {
|
|||||||
st->cr();
|
st->cr();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_exceptions == NULL) {
|
if (_exceptions == nullptr) {
|
||||||
st->print_cr(" No exception information");
|
st->print_cr(" No exception information");
|
||||||
} else {
|
} else {
|
||||||
int num_exceptions = _exceptions->length();
|
int num_exceptions = _exceptions->length();
|
||||||
@ -1987,17 +1987,17 @@ ciTypeFlow::ciTypeFlow(ciEnv* env, ciMethod* method, int osr_bci) {
|
|||||||
_method = method;
|
_method = method;
|
||||||
_has_irreducible_entry = false;
|
_has_irreducible_entry = false;
|
||||||
_osr_bci = osr_bci;
|
_osr_bci = osr_bci;
|
||||||
_failure_reason = NULL;
|
_failure_reason = nullptr;
|
||||||
assert(0 <= start_bci() && start_bci() < code_size() , "correct osr_bci argument: 0 <= %d < %d", start_bci(), code_size());
|
assert(0 <= start_bci() && start_bci() < code_size() , "correct osr_bci argument: 0 <= %d < %d", start_bci(), code_size());
|
||||||
_work_list = NULL;
|
_work_list = nullptr;
|
||||||
|
|
||||||
int ciblock_count = _method->get_method_blocks()->num_blocks();
|
int ciblock_count = _method->get_method_blocks()->num_blocks();
|
||||||
_idx_to_blocklist = NEW_ARENA_ARRAY(arena(), GrowableArray<Block*>*, ciblock_count);
|
_idx_to_blocklist = NEW_ARENA_ARRAY(arena(), GrowableArray<Block*>*, ciblock_count);
|
||||||
for (int i = 0; i < ciblock_count; i++) {
|
for (int i = 0; i < ciblock_count; i++) {
|
||||||
_idx_to_blocklist[i] = NULL;
|
_idx_to_blocklist[i] = nullptr;
|
||||||
}
|
}
|
||||||
_block_map = NULL; // until all blocks are seen
|
_block_map = nullptr; // until all blocks are seen
|
||||||
_jsr_records = NULL;
|
_jsr_records = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
@ -2008,7 +2008,7 @@ ciTypeFlow::Block* ciTypeFlow::work_list_next() {
|
|||||||
assert(!work_list_empty(), "work list must not be empty");
|
assert(!work_list_empty(), "work list must not be empty");
|
||||||
Block* next_block = _work_list;
|
Block* next_block = _work_list;
|
||||||
_work_list = next_block->next();
|
_work_list = next_block->next();
|
||||||
next_block->set_next(NULL);
|
next_block->set_next(nullptr);
|
||||||
next_block->set_on_work_list(false);
|
next_block->set_on_work_list(false);
|
||||||
return next_block;
|
return next_block;
|
||||||
}
|
}
|
||||||
@ -2031,16 +2031,16 @@ void ciTypeFlow::add_to_work_list(ciTypeFlow::Block* block) {
|
|||||||
|
|
||||||
// decreasing post order sort
|
// decreasing post order sort
|
||||||
|
|
||||||
Block* prev = NULL;
|
Block* prev = nullptr;
|
||||||
Block* current = _work_list;
|
Block* current = _work_list;
|
||||||
int po = block->post_order();
|
int po = block->post_order();
|
||||||
while (current != NULL) {
|
while (current != nullptr) {
|
||||||
if (!current->has_post_order() || po > current->post_order())
|
if (!current->has_post_order() || po > current->post_order())
|
||||||
break;
|
break;
|
||||||
prev = current;
|
prev = current;
|
||||||
current = current->next();
|
current = current->next();
|
||||||
}
|
}
|
||||||
if (prev == NULL) {
|
if (prev == nullptr) {
|
||||||
block->set_next(_work_list);
|
block->set_next(_work_list);
|
||||||
_work_list = block;
|
_work_list = block;
|
||||||
} else {
|
} else {
|
||||||
@ -2070,10 +2070,10 @@ ciTypeFlow::Block* ciTypeFlow::block_at(int bci, ciTypeFlow::JsrSet* jsrs, Creat
|
|||||||
assert(ciblk->start_bci() == bci, "bad ciBlock boundaries");
|
assert(ciblk->start_bci() == bci, "bad ciBlock boundaries");
|
||||||
Block* block = get_block_for(ciblk->index(), jsrs, option);
|
Block* block = get_block_for(ciblk->index(), jsrs, option);
|
||||||
|
|
||||||
assert(block == NULL? (option == no_create): block->is_backedge_copy() == (option == create_backedge_copy), "create option consistent with result");
|
assert(block == nullptr? (option == no_create): block->is_backedge_copy() == (option == create_backedge_copy), "create option consistent with result");
|
||||||
|
|
||||||
if (CITraceTypeFlow) {
|
if (CITraceTypeFlow) {
|
||||||
if (block != NULL) {
|
if (block != nullptr) {
|
||||||
tty->print(">> Found block ");
|
tty->print(">> Found block ");
|
||||||
block->print_value_on(tty);
|
block->print_value_on(tty);
|
||||||
tty->cr();
|
tty->cr();
|
||||||
@ -2092,13 +2092,13 @@ ciTypeFlow::Block* ciTypeFlow::block_at(int bci, ciTypeFlow::JsrSet* jsrs, Creat
|
|||||||
// does not already exist.
|
// does not already exist.
|
||||||
ciTypeFlow::JsrRecord* ciTypeFlow::make_jsr_record(int entry_address,
|
ciTypeFlow::JsrRecord* ciTypeFlow::make_jsr_record(int entry_address,
|
||||||
int return_address) {
|
int return_address) {
|
||||||
if (_jsr_records == NULL) {
|
if (_jsr_records == nullptr) {
|
||||||
_jsr_records = new (arena()) GrowableArray<JsrRecord*>(arena(),
|
_jsr_records = new (arena()) GrowableArray<JsrRecord*>(arena(),
|
||||||
2,
|
2,
|
||||||
0,
|
0,
|
||||||
NULL);
|
nullptr);
|
||||||
}
|
}
|
||||||
JsrRecord* record = NULL;
|
JsrRecord* record = nullptr;
|
||||||
int len = _jsr_records->length();
|
int len = _jsr_records->length();
|
||||||
for (int i = 0; i < len; i++) {
|
for (int i = 0; i < len; i++) {
|
||||||
JsrRecord* record = _jsr_records->at(i);
|
JsrRecord* record = _jsr_records->at(i);
|
||||||
@ -2229,8 +2229,8 @@ bool ciTypeFlow::clone_loop_heads(StateVector* temp_vector, JsrSet* temp_set) {
|
|||||||
|
|
||||||
// check _no_ shared head below us
|
// check _no_ shared head below us
|
||||||
Loop* ch;
|
Loop* ch;
|
||||||
for (ch = lp->child(); ch != NULL && ch->head() != head; ch = ch->sibling());
|
for (ch = lp->child(); ch != nullptr && ch->head() != head; ch = ch->sibling());
|
||||||
if (ch != NULL)
|
if (ch != nullptr)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// Clone head
|
// Clone head
|
||||||
@ -2290,8 +2290,8 @@ ciTypeFlow::Block* ciTypeFlow::clone_loop_head(Loop* lp, StateVector* temp_vecto
|
|||||||
|
|
||||||
// Accumulate profiled count for all backedges that share this loop's head
|
// Accumulate profiled count for all backedges that share this loop's head
|
||||||
int total_count = lp->profiled_count();
|
int total_count = lp->profiled_count();
|
||||||
for (Loop* lp1 = lp->parent(); lp1 != NULL; lp1 = lp1->parent()) {
|
for (Loop* lp1 = lp->parent(); lp1 != nullptr; lp1 = lp1->parent()) {
|
||||||
for (Loop* lp2 = lp1; lp2 != NULL; lp2 = lp2->sibling()) {
|
for (Loop* lp2 = lp1; lp2 != nullptr; lp2 = lp2->sibling()) {
|
||||||
if (lp2->head() == head && !lp2->tail()->is_backedge_copy()) {
|
if (lp2->head() == head && !lp2->tail()->is_backedge_copy()) {
|
||||||
total_count += lp2->profiled_count();
|
total_count += lp2->profiled_count();
|
||||||
}
|
}
|
||||||
@ -2302,8 +2302,8 @@ ciTypeFlow::Block* ciTypeFlow::clone_loop_head(Loop* lp, StateVector* temp_vecto
|
|||||||
int loops_with_shared_head = 0;
|
int loops_with_shared_head = 0;
|
||||||
Block* latest_tail = tail;
|
Block* latest_tail = tail;
|
||||||
bool done = false;
|
bool done = false;
|
||||||
for (Loop* lp1 = lp; lp1 != NULL && !done; lp1 = lp1->parent()) {
|
for (Loop* lp1 = lp; lp1 != nullptr && !done; lp1 = lp1->parent()) {
|
||||||
for (Loop* lp2 = lp1; lp2 != NULL && !done; lp2 = lp2->sibling()) {
|
for (Loop* lp2 = lp1; lp2 != nullptr && !done; lp2 = lp2->sibling()) {
|
||||||
if (lp2->head() == head && !lp2->tail()->is_backedge_copy()) {
|
if (lp2->head() == head && !lp2->tail()->is_backedge_copy()) {
|
||||||
count += lp2->profiled_count();
|
count += lp2->profiled_count();
|
||||||
if (lp2->tail()->post_order() < latest_tail->post_order()) {
|
if (lp2->tail()->post_order() < latest_tail->post_order()) {
|
||||||
@ -2422,7 +2422,7 @@ void ciTypeFlow::flow_block(ciTypeFlow::Block* block,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GrowableArray<Block*>* successors = NULL;
|
GrowableArray<Block*>* successors = nullptr;
|
||||||
if (control != ciBlock::fall_through_bci) {
|
if (control != ciBlock::fall_through_bci) {
|
||||||
// Check for exceptional control flow from this point.
|
// Check for exceptional control flow from this point.
|
||||||
if (has_exceptions && can_trap(str)) {
|
if (has_exceptions && can_trap(str)) {
|
||||||
@ -2441,7 +2441,7 @@ void ciTypeFlow::flow_block(ciTypeFlow::Block* block,
|
|||||||
state->apply_one_bytecode(&str);
|
state->apply_one_bytecode(&str);
|
||||||
} else {
|
} else {
|
||||||
// Fall through control
|
// Fall through control
|
||||||
successors = block->successors(&str, NULL, NULL);
|
successors = block->successors(&str, nullptr, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save set of locals defined in this block
|
// Save set of locals defined in this block
|
||||||
@ -2461,19 +2461,19 @@ void ciTypeFlow::flow_block(ciTypeFlow::Block* block,
|
|||||||
// Advance to next loop tree using a preorder, left-to-right traversal.
|
// Advance to next loop tree using a preorder, left-to-right traversal.
|
||||||
void ciTypeFlow::PreorderLoops::next() {
|
void ciTypeFlow::PreorderLoops::next() {
|
||||||
assert(!done(), "must not be done.");
|
assert(!done(), "must not be done.");
|
||||||
if (_current->child() != NULL) {
|
if (_current->child() != nullptr) {
|
||||||
_current = _current->child();
|
_current = _current->child();
|
||||||
} else if (_current->sibling() != NULL) {
|
} else if (_current->sibling() != nullptr) {
|
||||||
_current = _current->sibling();
|
_current = _current->sibling();
|
||||||
} else {
|
} else {
|
||||||
while (_current != _root && _current->sibling() == NULL) {
|
while (_current != _root && _current->sibling() == nullptr) {
|
||||||
_current = _current->parent();
|
_current = _current->parent();
|
||||||
}
|
}
|
||||||
if (_current == _root) {
|
if (_current == _root) {
|
||||||
_current = NULL;
|
_current = nullptr;
|
||||||
assert(done(), "must be done.");
|
assert(done(), "must be done.");
|
||||||
} else {
|
} else {
|
||||||
assert(_current->sibling() != NULL, "must be more to do");
|
assert(_current->sibling() != nullptr, "must be more to do");
|
||||||
_current = _current->sibling();
|
_current = _current->sibling();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2497,7 +2497,7 @@ int ciTypeFlow::Loop::profiled_count() {
|
|||||||
|
|
||||||
ciProfileData* data = methodData->bci_to_data(tail->control());
|
ciProfileData* data = methodData->bci_to_data(tail->control());
|
||||||
|
|
||||||
if (data == NULL || !data->is_JumpData()) {
|
if (data == nullptr || !data->is_JumpData()) {
|
||||||
_profiled_count = 0;
|
_profiled_count = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -2596,12 +2596,12 @@ bool ciTypeFlow::Loop::at_insertion_point(Loop* lp, Loop* current) {
|
|||||||
// ascending on secondary key: loop tail's pre_order.
|
// ascending on secondary key: loop tail's pre_order.
|
||||||
ciTypeFlow::Loop* ciTypeFlow::Loop::sorted_merge(Loop* lp) {
|
ciTypeFlow::Loop* ciTypeFlow::Loop::sorted_merge(Loop* lp) {
|
||||||
Loop* leaf = this;
|
Loop* leaf = this;
|
||||||
Loop* prev = NULL;
|
Loop* prev = nullptr;
|
||||||
Loop* current = leaf;
|
Loop* current = leaf;
|
||||||
while (lp != NULL) {
|
while (lp != nullptr) {
|
||||||
int lp_pre_order = lp->head()->pre_order();
|
int lp_pre_order = lp->head()->pre_order();
|
||||||
// Find insertion point for "lp"
|
// Find insertion point for "lp"
|
||||||
while (current != NULL) {
|
while (current != nullptr) {
|
||||||
if (current == lp) {
|
if (current == lp) {
|
||||||
return leaf; // Already in list
|
return leaf; // Already in list
|
||||||
}
|
}
|
||||||
@ -2614,7 +2614,7 @@ ciTypeFlow::Loop* ciTypeFlow::Loop::sorted_merge(Loop* lp) {
|
|||||||
Loop* next_lp = lp->parent(); // Save future list of items to insert
|
Loop* next_lp = lp->parent(); // Save future list of items to insert
|
||||||
// Insert lp before current
|
// Insert lp before current
|
||||||
lp->set_parent(current);
|
lp->set_parent(current);
|
||||||
if (prev != NULL) {
|
if (prev != nullptr) {
|
||||||
prev->set_parent(lp);
|
prev->set_parent(lp);
|
||||||
} else {
|
} else {
|
||||||
leaf = lp;
|
leaf = lp;
|
||||||
@ -2631,10 +2631,10 @@ ciTypeFlow::Loop* ciTypeFlow::Loop::sorted_merge(Loop* lp) {
|
|||||||
// Incrementally build loop tree.
|
// Incrementally build loop tree.
|
||||||
void ciTypeFlow::build_loop_tree(Block* blk) {
|
void ciTypeFlow::build_loop_tree(Block* blk) {
|
||||||
assert(!blk->is_post_visited(), "precondition");
|
assert(!blk->is_post_visited(), "precondition");
|
||||||
Loop* innermost = NULL; // merge of loop tree branches over all successors
|
Loop* innermost = nullptr; // merge of loop tree branches over all successors
|
||||||
|
|
||||||
for (SuccIter iter(blk); !iter.done(); iter.next()) {
|
for (SuccIter iter(blk); !iter.done(); iter.next()) {
|
||||||
Loop* lp = NULL;
|
Loop* lp = nullptr;
|
||||||
Block* succ = iter.succ();
|
Block* succ = iter.succ();
|
||||||
if (!succ->is_post_visited()) {
|
if (!succ->is_post_visited()) {
|
||||||
// Found backedge since predecessor post visited, but successor is not
|
// Found backedge since predecessor post visited, but successor is not
|
||||||
@ -2642,7 +2642,7 @@ void ciTypeFlow::build_loop_tree(Block* blk) {
|
|||||||
|
|
||||||
// Create a LoopNode to mark this loop.
|
// Create a LoopNode to mark this loop.
|
||||||
lp = new (arena()) Loop(succ, blk);
|
lp = new (arena()) Loop(succ, blk);
|
||||||
if (succ->loop() == NULL)
|
if (succ->loop() == nullptr)
|
||||||
succ->set_loop(lp);
|
succ->set_loop(lp);
|
||||||
// succ->loop will be updated to innermost loop on a later call, when blk==succ
|
// succ->loop will be updated to innermost loop on a later call, when blk==succ
|
||||||
|
|
||||||
@ -2650,10 +2650,10 @@ void ciTypeFlow::build_loop_tree(Block* blk) {
|
|||||||
lp = succ->loop();
|
lp = succ->loop();
|
||||||
|
|
||||||
// If succ is loop head, find outer loop.
|
// If succ is loop head, find outer loop.
|
||||||
while (lp != NULL && lp->head() == succ) {
|
while (lp != nullptr && lp->head() == succ) {
|
||||||
lp = lp->parent();
|
lp = lp->parent();
|
||||||
}
|
}
|
||||||
if (lp == NULL) {
|
if (lp == nullptr) {
|
||||||
// Infinite loop, it's parent is the root
|
// Infinite loop, it's parent is the root
|
||||||
lp = loop_tree_root();
|
lp = loop_tree_root();
|
||||||
}
|
}
|
||||||
@ -2670,7 +2670,7 @@ void ciTypeFlow::build_loop_tree(Block* blk) {
|
|||||||
add_to_work_list(succ);
|
add_to_work_list(succ);
|
||||||
}
|
}
|
||||||
Loop* plp = lp->parent();
|
Loop* plp = lp->parent();
|
||||||
if (plp == NULL) {
|
if (plp == nullptr) {
|
||||||
// This only happens for some irreducible cases. The parent
|
// This only happens for some irreducible cases. The parent
|
||||||
// will be updated during a later pass.
|
// will be updated during a later pass.
|
||||||
break;
|
break;
|
||||||
@ -2679,11 +2679,11 @@ void ciTypeFlow::build_loop_tree(Block* blk) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Merge loop tree branch for all successors.
|
// Merge loop tree branch for all successors.
|
||||||
innermost = innermost == NULL ? lp : innermost->sorted_merge(lp);
|
innermost = innermost == nullptr ? lp : innermost->sorted_merge(lp);
|
||||||
|
|
||||||
} // end loop
|
} // end loop
|
||||||
|
|
||||||
if (innermost == NULL) {
|
if (innermost == nullptr) {
|
||||||
assert(blk->successors()->length() == 0, "CFG exit");
|
assert(blk->successors()->length() == 0, "CFG exit");
|
||||||
blk->set_loop(loop_tree_root());
|
blk->set_loop(loop_tree_root());
|
||||||
} else if (innermost->head() == blk) {
|
} else if (innermost->head() == blk) {
|
||||||
@ -2692,7 +2692,7 @@ void ciTypeFlow::build_loop_tree(Block* blk) {
|
|||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
assert(blk->loop()->head() == innermost->head(), "same head");
|
assert(blk->loop()->head() == innermost->head(), "same head");
|
||||||
Loop* dl;
|
Loop* dl;
|
||||||
for (dl = innermost; dl != NULL && dl != blk->loop(); dl = dl->parent());
|
for (dl = innermost; dl != nullptr && dl != blk->loop(); dl = dl->parent());
|
||||||
assert(dl == blk->loop(), "blk->loop() already in innermost list");
|
assert(dl == blk->loop(), "blk->loop() already in innermost list");
|
||||||
#endif
|
#endif
|
||||||
blk->set_loop(innermost);
|
blk->set_loop(innermost);
|
||||||
@ -2718,7 +2718,7 @@ void ciTypeFlow::build_loop_tree(Block* blk) {
|
|||||||
//
|
//
|
||||||
// Returns true if lp is nested loop.
|
// Returns true if lp is nested loop.
|
||||||
bool ciTypeFlow::Loop::contains(ciTypeFlow::Loop* lp) const {
|
bool ciTypeFlow::Loop::contains(ciTypeFlow::Loop* lp) const {
|
||||||
assert(lp != NULL, "");
|
assert(lp != nullptr, "");
|
||||||
if (this == lp || head() == lp->head()) return true;
|
if (this == lp || head() == lp->head()) return true;
|
||||||
int depth1 = depth();
|
int depth1 = depth();
|
||||||
int depth2 = lp->depth();
|
int depth2 = lp->depth();
|
||||||
@ -2737,7 +2737,7 @@ bool ciTypeFlow::Loop::contains(ciTypeFlow::Loop* lp) const {
|
|||||||
// Loop depth
|
// Loop depth
|
||||||
int ciTypeFlow::Loop::depth() const {
|
int ciTypeFlow::Loop::depth() const {
|
||||||
int dp = 0;
|
int dp = 0;
|
||||||
for (Loop* lp = this->parent(); lp != NULL; lp = lp->parent())
|
for (Loop* lp = this->parent(); lp != nullptr; lp = lp->parent())
|
||||||
dp++;
|
dp++;
|
||||||
return dp;
|
return dp;
|
||||||
}
|
}
|
||||||
@ -2754,7 +2754,7 @@ void ciTypeFlow::Loop::print(outputStream* st, int indent) const {
|
|||||||
st->print(" defs: ");
|
st->print(" defs: ");
|
||||||
def_locals()->print_on(st, _head->outer()->method()->max_locals());
|
def_locals()->print_on(st, _head->outer()->method()->max_locals());
|
||||||
st->cr();
|
st->cr();
|
||||||
for (Loop* ch = child(); ch != NULL; ch = ch->sibling())
|
for (Loop* ch = child(); ch != nullptr; ch = ch->sibling())
|
||||||
ch->print(st, indent+2);
|
ch->print(st, indent+2);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -2783,7 +2783,7 @@ void ciTypeFlow::df_flow_types(Block* start,
|
|||||||
stk.push(start);
|
stk.push(start);
|
||||||
|
|
||||||
_next_pre_order = 0; // initialize pre_order counter
|
_next_pre_order = 0; // initialize pre_order counter
|
||||||
_rpo_list = NULL;
|
_rpo_list = nullptr;
|
||||||
int next_po = 0; // initialize post_order counter
|
int next_po = 0; // initialize post_order counter
|
||||||
|
|
||||||
// Compute RPO and the control flow graph
|
// Compute RPO and the control flow graph
|
||||||
@ -2861,7 +2861,7 @@ void ciTypeFlow::flow_types() {
|
|||||||
assert(_rpo_list == start, "must be start");
|
assert(_rpo_list == start, "must be start");
|
||||||
|
|
||||||
// Any loops found?
|
// Any loops found?
|
||||||
if (loop_tree_root()->child() != NULL &&
|
if (loop_tree_root()->child() != nullptr &&
|
||||||
env()->comp_level() >= CompLevel_full_optimization) {
|
env()->comp_level() >= CompLevel_full_optimization) {
|
||||||
// Loop optimizations are not performed on Tier1 compiles.
|
// Loop optimizations are not performed on Tier1 compiles.
|
||||||
|
|
||||||
@ -2869,8 +2869,8 @@ void ciTypeFlow::flow_types() {
|
|||||||
|
|
||||||
// If some loop heads were cloned, recompute postorder and loop tree
|
// If some loop heads were cloned, recompute postorder and loop tree
|
||||||
if (changed) {
|
if (changed) {
|
||||||
loop_tree_root()->set_child(NULL);
|
loop_tree_root()->set_child(nullptr);
|
||||||
for (Block* blk = _rpo_list; blk != NULL;) {
|
for (Block* blk = _rpo_list; blk != nullptr;) {
|
||||||
Block* next = blk->rpo_next();
|
Block* next = blk->rpo_next();
|
||||||
blk->df_init();
|
blk->df_init();
|
||||||
blk = next;
|
blk = next;
|
||||||
@ -2904,7 +2904,7 @@ void ciTypeFlow::flow_types() {
|
|||||||
//
|
//
|
||||||
// Create the block map, which indexes blocks in reverse post-order.
|
// Create the block map, which indexes blocks in reverse post-order.
|
||||||
void ciTypeFlow::map_blocks() {
|
void ciTypeFlow::map_blocks() {
|
||||||
assert(_block_map == NULL, "single initialization");
|
assert(_block_map == nullptr, "single initialization");
|
||||||
int block_ct = _next_pre_order;
|
int block_ct = _next_pre_order;
|
||||||
_block_map = NEW_ARENA_ARRAY(arena(), Block*, block_ct);
|
_block_map = NEW_ARENA_ARRAY(arena(), Block*, block_ct);
|
||||||
assert(block_ct == block_count(), "");
|
assert(block_ct == block_count(), "");
|
||||||
@ -2916,10 +2916,10 @@ void ciTypeFlow::map_blocks() {
|
|||||||
_block_map[rpo] = blk;
|
_block_map[rpo] = blk;
|
||||||
blk = blk->rpo_next();
|
blk = blk->rpo_next();
|
||||||
}
|
}
|
||||||
assert(blk == NULL, "should be done");
|
assert(blk == nullptr, "should be done");
|
||||||
|
|
||||||
for (int j = 0; j < block_ct; j++) {
|
for (int j = 0; j < block_ct; j++) {
|
||||||
assert(_block_map[j] != NULL, "must not drop any blocks");
|
assert(_block_map[j] != nullptr, "must not drop any blocks");
|
||||||
Block* block = _block_map[j];
|
Block* block = _block_map[j];
|
||||||
// Remove dead blocks from successor lists:
|
// Remove dead blocks from successor lists:
|
||||||
for (int e = 0; e <= 1; e++) {
|
for (int e = 0; e <= 1; e++) {
|
||||||
@ -2949,12 +2949,12 @@ void ciTypeFlow::map_blocks() {
|
|||||||
ciTypeFlow::Block* ciTypeFlow::get_block_for(int ciBlockIndex, ciTypeFlow::JsrSet* jsrs, CreateOption option) {
|
ciTypeFlow::Block* ciTypeFlow::get_block_for(int ciBlockIndex, ciTypeFlow::JsrSet* jsrs, CreateOption option) {
|
||||||
Arena* a = arena();
|
Arena* a = arena();
|
||||||
GrowableArray<Block*>* blocks = _idx_to_blocklist[ciBlockIndex];
|
GrowableArray<Block*>* blocks = _idx_to_blocklist[ciBlockIndex];
|
||||||
if (blocks == NULL) {
|
if (blocks == nullptr) {
|
||||||
// Query only?
|
// Query only?
|
||||||
if (option == no_create) return NULL;
|
if (option == no_create) return nullptr;
|
||||||
|
|
||||||
// Allocate the growable array.
|
// Allocate the growable array.
|
||||||
blocks = new (a) GrowableArray<Block*>(a, 4, 0, NULL);
|
blocks = new (a) GrowableArray<Block*>(a, 4, 0, nullptr);
|
||||||
_idx_to_blocklist[ciBlockIndex] = blocks;
|
_idx_to_blocklist[ciBlockIndex] = blocks;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2969,7 +2969,7 @@ ciTypeFlow::Block* ciTypeFlow::get_block_for(int ciBlockIndex, ciTypeFlow::JsrSe
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Query only?
|
// Query only?
|
||||||
if (option == no_create) return NULL;
|
if (option == no_create) return nullptr;
|
||||||
|
|
||||||
// We did not find a compatible block. Create one.
|
// We did not find a compatible block. Create one.
|
||||||
Block* new_block = new (a) Block(this, _method->get_method_blocks()->block(ciBlockIndex), jsrs);
|
Block* new_block = new (a) Block(this, _method->get_method_blocks()->block(ciBlockIndex), jsrs);
|
||||||
@ -2984,7 +2984,7 @@ ciTypeFlow::Block* ciTypeFlow::get_block_for(int ciBlockIndex, ciTypeFlow::JsrSe
|
|||||||
int ciTypeFlow::backedge_copy_count(int ciBlockIndex, ciTypeFlow::JsrSet* jsrs) const {
|
int ciTypeFlow::backedge_copy_count(int ciBlockIndex, ciTypeFlow::JsrSet* jsrs) const {
|
||||||
GrowableArray<Block*>* blocks = _idx_to_blocklist[ciBlockIndex];
|
GrowableArray<Block*>* blocks = _idx_to_blocklist[ciBlockIndex];
|
||||||
|
|
||||||
if (blocks == NULL) {
|
if (blocks == nullptr) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3061,7 +3061,7 @@ bool ciTypeFlow::is_dominated_by(int bci, int dom_bci) {
|
|||||||
while (changed) {
|
while (changed) {
|
||||||
changed = false;
|
changed = false;
|
||||||
// Use reverse postorder iteration
|
// Use reverse postorder iteration
|
||||||
for (Block* blk = _rpo_list; blk != NULL; blk = blk->rpo_next()) {
|
for (Block* blk = _rpo_list; blk != nullptr; blk = blk->rpo_next()) {
|
||||||
if (blk->is_start()) {
|
if (blk->is_start()) {
|
||||||
// Ignore start block
|
// Ignore start block
|
||||||
continue;
|
continue;
|
||||||
@ -3102,10 +3102,10 @@ bool ciTypeFlow::is_dominated_by(int bci, int dom_bci) {
|
|||||||
// requests are not optional; if they fail the requestor is responsible for
|
// requests are not optional; if they fail the requestor is responsible for
|
||||||
// copying the failure reason up to the ciEnv. (See Parse::Parse.)
|
// copying the failure reason up to the ciEnv. (See Parse::Parse.)
|
||||||
void ciTypeFlow::record_failure(const char* reason) {
|
void ciTypeFlow::record_failure(const char* reason) {
|
||||||
if (env()->log() != NULL) {
|
if (env()->log() != nullptr) {
|
||||||
env()->log()->elem("failure reason='%s' phase='typeflow'", reason);
|
env()->log()->elem("failure reason='%s' phase='typeflow'", reason);
|
||||||
}
|
}
|
||||||
if (_failure_reason == NULL) {
|
if (_failure_reason == nullptr) {
|
||||||
// Record the first failure reason.
|
// Record the first failure reason.
|
||||||
_failure_reason = reason;
|
_failure_reason = reason;
|
||||||
}
|
}
|
||||||
@ -3124,15 +3124,15 @@ void ciTypeFlow::print_on(outputStream* st) const {
|
|||||||
int limit_bci = code_size();
|
int limit_bci = code_size();
|
||||||
st->print_cr(" %d bytes", limit_bci);
|
st->print_cr(" %d bytes", limit_bci);
|
||||||
ciMethodBlocks* mblks = _method->get_method_blocks();
|
ciMethodBlocks* mblks = _method->get_method_blocks();
|
||||||
ciBlock* current = NULL;
|
ciBlock* current = nullptr;
|
||||||
for (int bci = 0; bci < limit_bci; bci++) {
|
for (int bci = 0; bci < limit_bci; bci++) {
|
||||||
ciBlock* blk = mblks->block_containing(bci);
|
ciBlock* blk = mblks->block_containing(bci);
|
||||||
if (blk != NULL && blk != current) {
|
if (blk != nullptr && blk != current) {
|
||||||
current = blk;
|
current = blk;
|
||||||
current->print_on(st);
|
current->print_on(st);
|
||||||
|
|
||||||
GrowableArray<Block*>* blocks = _idx_to_blocklist[blk->index()];
|
GrowableArray<Block*>* blocks = _idx_to_blocklist[blk->index()];
|
||||||
int num_blocks = (blocks == NULL) ? 0 : blocks->length();
|
int num_blocks = (blocks == nullptr) ? 0 : blocks->length();
|
||||||
|
|
||||||
if (num_blocks == 0) {
|
if (num_blocks == 0) {
|
||||||
st->print_cr(" No Blocks");
|
st->print_cr(" No Blocks");
|
||||||
@ -3156,7 +3156,7 @@ void ciTypeFlow::rpo_print_on(outputStream* st) const {
|
|||||||
method()->name()->print_symbol_on(st);
|
method()->name()->print_symbol_on(st);
|
||||||
int limit_bci = code_size();
|
int limit_bci = code_size();
|
||||||
st->print_cr(" %d bytes", limit_bci);
|
st->print_cr(" %d bytes", limit_bci);
|
||||||
for (Block* blk = _rpo_list; blk != NULL; blk = blk->rpo_next()) {
|
for (Block* blk = _rpo_list; blk != nullptr; blk = blk->rpo_next()) {
|
||||||
blk->print_on(st);
|
blk->print_on(st);
|
||||||
st->print_cr("--------------------------------------------------------");
|
st->print_cr("--------------------------------------------------------");
|
||||||
st->cr();
|
st->cr();
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -186,7 +186,7 @@ public:
|
|||||||
switch (t->basic_type()) {
|
switch (t->basic_type()) {
|
||||||
case T_LONG: return long2_type();
|
case T_LONG: return long2_type();
|
||||||
case T_DOUBLE: return double2_type();
|
case T_DOUBLE: return double2_type();
|
||||||
default: ShouldNotReachHere(); return NULL;
|
default: ShouldNotReachHere(); return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -333,16 +333,16 @@ public:
|
|||||||
}
|
}
|
||||||
// pop_objArray and pop_typeArray narrow the tos to ciObjArrayKlass
|
// pop_objArray and pop_typeArray narrow the tos to ciObjArrayKlass
|
||||||
// or ciTypeArrayKlass (resp.). In the rare case that an explicit
|
// or ciTypeArrayKlass (resp.). In the rare case that an explicit
|
||||||
// null is popped from the stack, we return NULL. Caller beware.
|
// null is popped from the stack, we return null. Caller beware.
|
||||||
ciObjArrayKlass* pop_objArray() {
|
ciObjArrayKlass* pop_objArray() {
|
||||||
ciType* array = pop_value();
|
ciType* array = pop_value();
|
||||||
if (array == null_type()) return NULL;
|
if (array == null_type()) return nullptr;
|
||||||
assert(array->is_obj_array_klass(), "must be object array type");
|
assert(array->is_obj_array_klass(), "must be object array type");
|
||||||
return array->as_obj_array_klass();
|
return array->as_obj_array_klass();
|
||||||
}
|
}
|
||||||
ciTypeArrayKlass* pop_typeArray() {
|
ciTypeArrayKlass* pop_typeArray() {
|
||||||
ciType* array = pop_value();
|
ciType* array = pop_value();
|
||||||
if (array == null_type()) return NULL;
|
if (array == null_type()) return nullptr;
|
||||||
assert(array->is_type_array_klass(), "must be prim array type");
|
assert(array->is_type_array_klass(), "must be prim array type");
|
||||||
return array->as_type_array_klass();
|
return array->as_type_array_klass();
|
||||||
}
|
}
|
||||||
@ -501,8 +501,8 @@ public:
|
|||||||
int _index;
|
int _index;
|
||||||
Block* _succ;
|
Block* _succ;
|
||||||
public:
|
public:
|
||||||
SuccIter() : _pred(NULL), _index(-1), _succ(NULL) {}
|
SuccIter() : _pred(nullptr), _index(-1), _succ(nullptr) {}
|
||||||
SuccIter(Block* pred) : _pred(pred), _index(-1), _succ(NULL) { next(); }
|
SuccIter(Block* pred) : _pred(pred), _index(-1), _succ(nullptr) { next(); }
|
||||||
int index() { return _index; }
|
int index() { return _index; }
|
||||||
Block* pred() { return _pred; } // Return predecessor
|
Block* pred() { return _pred; } // Return predecessor
|
||||||
bool done() { return _index < 0; } // Finished?
|
bool done() { return _index < 0; } // Finished?
|
||||||
@ -590,7 +590,7 @@ public:
|
|||||||
assert(is_loop_head(), "only loop heads");
|
assert(is_loop_head(), "only loop heads");
|
||||||
// Find outermost loop with same loop head
|
// Find outermost loop with same loop head
|
||||||
Loop* lp = loop();
|
Loop* lp = loop();
|
||||||
while (lp->parent() != NULL) {
|
while (lp->parent() != nullptr) {
|
||||||
if (lp->parent()->head() != lp->head()) break;
|
if (lp->parent()->head() != lp->head()) break;
|
||||||
lp = lp->parent();
|
lp = lp->parent();
|
||||||
}
|
}
|
||||||
@ -604,7 +604,7 @@ public:
|
|||||||
StateVector* state,
|
StateVector* state,
|
||||||
JsrSet* jsrs);
|
JsrSet* jsrs);
|
||||||
GrowableArray<Block*>* successors() {
|
GrowableArray<Block*>* successors() {
|
||||||
assert(_successors != NULL, "must be filled in");
|
assert(_successors != nullptr, "must be filled in");
|
||||||
return _successors;
|
return _successors;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -615,7 +615,7 @@ public:
|
|||||||
|
|
||||||
// Get the exceptional successors for this Block.
|
// Get the exceptional successors for this Block.
|
||||||
GrowableArray<Block*>* exceptions() {
|
GrowableArray<Block*>* exceptions() {
|
||||||
if (_exceptions == NULL) {
|
if (_exceptions == nullptr) {
|
||||||
compute_exceptions();
|
compute_exceptions();
|
||||||
}
|
}
|
||||||
return _exceptions;
|
return _exceptions;
|
||||||
@ -624,7 +624,7 @@ public:
|
|||||||
// Get the exception klasses corresponding to the
|
// Get the exception klasses corresponding to the
|
||||||
// exceptional successors for this Block.
|
// exceptional successors for this Block.
|
||||||
GrowableArray<ciInstanceKlass*>* exc_klasses() {
|
GrowableArray<ciInstanceKlass*>* exc_klasses() {
|
||||||
if (_exc_klasses == NULL) {
|
if (_exc_klasses == nullptr) {
|
||||||
compute_exceptions();
|
compute_exceptions();
|
||||||
}
|
}
|
||||||
return _exc_klasses;
|
return _exc_klasses;
|
||||||
@ -697,7 +697,7 @@ public:
|
|||||||
Block* looping_succ(Loop* lp); // Successor inside of loop
|
Block* looping_succ(Loop* lp); // Successor inside of loop
|
||||||
bool is_single_entry_loop_head() const {
|
bool is_single_entry_loop_head() const {
|
||||||
if (!is_loop_head()) return false;
|
if (!is_loop_head()) return false;
|
||||||
for (Loop* lp = loop(); lp != NULL && lp->head() == this; lp = lp->parent())
|
for (Loop* lp = loop(); lp != nullptr && lp->head() == this; lp = lp->parent())
|
||||||
if (lp->is_irreducible()) return false;
|
if (lp->is_irreducible()) return false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -723,7 +723,7 @@ public:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
Loop(Block* head, Block* tail) :
|
Loop(Block* head, Block* tail) :
|
||||||
_parent(NULL), _sibling(NULL), _child(NULL),
|
_parent(nullptr), _sibling(nullptr), _child(nullptr),
|
||||||
_head(head), _tail(tail),
|
_head(head), _tail(tail),
|
||||||
_irreducible(false), _def_locals(), _profiled_count(-1) {}
|
_irreducible(false), _def_locals(), _profiled_count(-1) {}
|
||||||
|
|
||||||
@ -773,7 +773,7 @@ public:
|
|||||||
Loop* _current;
|
Loop* _current;
|
||||||
public:
|
public:
|
||||||
PreorderLoops(Loop* root) : _root(root), _current(root) {}
|
PreorderLoops(Loop* root) : _root(root), _current(root) {}
|
||||||
bool done() { return _current == NULL; } // Finished iterating?
|
bool done() { return _current == nullptr; } // Finished iterating?
|
||||||
void next(); // Advance to next loop
|
void next(); // Advance to next loop
|
||||||
Loop* current() { return _current; } // Return current loop.
|
Loop* current() { return _current; } // Return current loop.
|
||||||
};
|
};
|
||||||
@ -818,11 +818,11 @@ public:
|
|||||||
int backedge_copy_count(int ciBlockIndex, JsrSet* jsrs) const;
|
int backedge_copy_count(int ciBlockIndex, JsrSet* jsrs) const;
|
||||||
|
|
||||||
// Return an existing block containing bci which has a JsrSet compatible
|
// Return an existing block containing bci which has a JsrSet compatible
|
||||||
// with jsrs, or NULL if there is none.
|
// with jsrs, or null if there is none.
|
||||||
Block* existing_block_at(int bci, JsrSet* set) { return block_at(bci, set, no_create); }
|
Block* existing_block_at(int bci, JsrSet* set) { return block_at(bci, set, no_create); }
|
||||||
|
|
||||||
// Tell whether the flow analysis has encountered an error of some sort.
|
// Tell whether the flow analysis has encountered an error of some sort.
|
||||||
bool failing() { return env()->failing() || _failure_reason != NULL; }
|
bool failing() { return env()->failing() || _failure_reason != nullptr; }
|
||||||
|
|
||||||
// Reason this compilation is failing, such as "too many basic blocks".
|
// Reason this compilation is failing, such as "too many basic blocks".
|
||||||
const char* failure_reason() { return _failure_reason; }
|
const char* failure_reason() { return _failure_reason; }
|
||||||
@ -831,7 +831,7 @@ public:
|
|||||||
void record_failure(const char* reason);
|
void record_failure(const char* reason);
|
||||||
|
|
||||||
// Return the block of a given pre-order number.
|
// Return the block of a given pre-order number.
|
||||||
int have_block_count() const { return _block_map != NULL; }
|
int have_block_count() const { return _block_map != nullptr; }
|
||||||
int block_count() const { assert(have_block_count(), "");
|
int block_count() const { assert(have_block_count(), "");
|
||||||
return _next_pre_order; }
|
return _next_pre_order; }
|
||||||
Block* pre_order_at(int po) const { assert(0 <= po && po < block_count(), "out of bounds");
|
Block* pre_order_at(int po) const { assert(0 <= po && po < block_count(), "out of bounds");
|
||||||
@ -853,7 +853,7 @@ private:
|
|||||||
int _next_pre_order;
|
int _next_pre_order;
|
||||||
|
|
||||||
// Are there more blocks on the work list?
|
// Are there more blocks on the work list?
|
||||||
bool work_list_empty() { return _work_list == NULL; }
|
bool work_list_empty() { return _work_list == nullptr; }
|
||||||
|
|
||||||
// Get the next basic block from our work list.
|
// Get the next basic block from our work list.
|
||||||
Block* work_list_next();
|
Block* work_list_next();
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -36,7 +36,7 @@
|
|||||||
// basictype_to_str
|
// basictype_to_str
|
||||||
const char* basictype_to_str(BasicType t) {
|
const char* basictype_to_str(BasicType t) {
|
||||||
const char* str = type2name(t);
|
const char* str = type2name(t);
|
||||||
if (str == NULL) return "illegal";
|
if (str == nullptr) return "illegal";
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user