From 015e6e58c51e489b3ba0221abe2de966bf05e0de Mon Sep 17 00:00:00 2001 From: Nils Eliasson Date: Tue, 1 Dec 2020 21:08:45 +0000 Subject: [PATCH] 8257460: Further CompilerOracle cleanup Reviewed-by: kvn, redestad, thartmann --- .../share/compiler/compilerDirectives.cpp | 2 +- src/hotspot/share/compiler/compilerOracle.cpp | 80 +++++++++---------- src/hotspot/share/compiler/compilerOracle.hpp | 6 +- src/hotspot/share/prims/whitebox.cpp | 5 +- 4 files changed, 49 insertions(+), 44 deletions(-) diff --git a/src/hotspot/share/compiler/compilerDirectives.cpp b/src/hotspot/share/compiler/compilerDirectives.cpp index ddef13ac6c5..830d63a94b5 100644 --- a/src/hotspot/share/compiler/compilerDirectives.cpp +++ b/src/hotspot/share/compiler/compilerDirectives.cpp @@ -359,7 +359,7 @@ DirectiveSet* DirectiveSet::compilecommand_compatibility_init(const methodHandle } // inline and dontinline (including exclude) are implemented in the directiveset accessors -#define init_default_cc(name, type, dvalue, cc_flag) { type v; if (!_modified[name##Index] && CompilerOracle::has_option_value(method, CompileCommand::cc_flag, v) && v != this->name##Option) { set.cloned()->name##Option = v; } } +#define init_default_cc(name, type, dvalue, cc_flag) { type v; if (!_modified[name##Index] && CompileCommand::cc_flag != CompileCommand::Unknown && CompilerOracle::has_option_value(method, CompileCommand::cc_flag, v) && v != this->name##Option) { set.cloned()->name##Option = v; } } compilerdirectives_common_flags(init_default_cc) compilerdirectives_c2_flags(init_default_cc) compilerdirectives_c1_flags(init_default_cc) diff --git a/src/hotspot/share/compiler/compilerOracle.cpp b/src/hotspot/share/compiler/compilerOracle.cpp index 878b6592170..193c791df74 100644 --- a/src/hotspot/share/compiler/compilerOracle.cpp +++ b/src/hotspot/share/compiler/compilerOracle.cpp @@ -104,7 +104,6 @@ class TypedMethodOptionMatcher : public MethodMatcher { private: TypedMethodOptionMatcher* _next; enum CompileCommand _option; - OptionType _type; public: union { @@ -117,18 +116,16 @@ class TypedMethodOptionMatcher : public MethodMatcher { TypedMethodOptionMatcher() : MethodMatcher(), _next(NULL), - _option(CompileCommand::Unknown), - _type(OptionType::Unknown) { + _option(CompileCommand::Unknown) { memset(&_u, 0, sizeof(_u)); } ~TypedMethodOptionMatcher(); static TypedMethodOptionMatcher* parse_method_pattern(char*& line, char* errorbuf, const int buf_size); - TypedMethodOptionMatcher* match(const methodHandle &method, enum CompileCommand option, OptionType type); + TypedMethodOptionMatcher* match(const methodHandle &method, enum CompileCommand option); - void init(enum CompileCommand option, OptionType type, TypedMethodOptionMatcher* next) { + void init(enum CompileCommand option, TypedMethodOptionMatcher* next) { _next = next; - _type = type; _option = option; } @@ -140,7 +137,6 @@ class TypedMethodOptionMatcher : public MethodMatcher { void set_next(TypedMethodOptionMatcher* next) {_next = next; } TypedMethodOptionMatcher* next() { return _next; } - OptionType type() { return _type; } enum CompileCommand option() { return _option; } template T value(); template void set_value(T value); @@ -194,8 +190,9 @@ void TypedMethodOptionMatcher::print() { ttyLocker ttyl; print_base(tty); const char* name = option2name(_option); - switch (_type) { - case OptionType::Intx: + enum OptionType type = option2type(_option); + switch (type) { + case OptionType::Intx: tty->print_cr(" intx %s = " INTX_FORMAT, name, value()); break; case OptionType::Uintx: @@ -208,6 +205,7 @@ void TypedMethodOptionMatcher::print() { tty->print_cr(" double %s = %f", name, value()); break; case OptionType::Ccstr: + case OptionType::Ccstrlist: tty->print_cr(" const char* %s = '%s'", name, value()); break; default: @@ -244,7 +242,8 @@ TypedMethodOptionMatcher* TypedMethodOptionMatcher::clone() { } TypedMethodOptionMatcher::~TypedMethodOptionMatcher() { - if (type() == OptionType::Ccstr) { + enum OptionType type = option2type(_option); + if (type == OptionType::Ccstr || type == OptionType::Ccstrlist) { ccstr v = value(); os::free((void*)v); } @@ -263,7 +262,7 @@ TypedMethodOptionMatcher* TypedMethodOptionMatcher::parse_method_pattern(char*& return tom; } -TypedMethodOptionMatcher* TypedMethodOptionMatcher::match(const methodHandle& method, enum CompileCommand option, OptionType type) { +TypedMethodOptionMatcher* TypedMethodOptionMatcher::match(const methodHandle& method, enum CompileCommand option) { TypedMethodOptionMatcher* current = this; while (current != NULL) { if (current->_option == option) { @@ -285,12 +284,9 @@ static void register_command(TypedMethodOptionMatcher* matcher, tty->print_cr("Warning: +LogCompilation must be enabled in order for individual methods to be logged with "); tty->print_cr(" CompileCommand=log,"); } - enum OptionType type = option2type(option); - if (type == OptionType::Ccstrlist) { - type = OptionType::Ccstr; // ccstrlists are stores as ccstr - } - assert(type == get_type_for(), "sanity"); - matcher->init(option, type, option_list); + assert(CompilerOracle::option_matches_type(option, value), "Value must match option type"); + + matcher->init(option, option_list); matcher->set_value(value); option_list = matcher; if ((option != CompileCommand::DontInline) && @@ -308,26 +304,10 @@ static void register_command(TypedMethodOptionMatcher* matcher, } template -bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, T& value, bool verify_type) { - enum OptionType type = option2type(option); - if (type == OptionType::Unknown) { - return false; // Can't query options with type Unknown. - } - if (type == OptionType::Ccstrlist) { - type = OptionType::Ccstr; // CCstrList type options are stored as Ccstr - } - if (verify_type) { - if (type != get_type_for()) { - // Whitebox API expects false if option and type doesn't match - return false; - } - } else { - assert(type == get_type_for(), "Value type (%s) must match option %s (%s)", - optiontype2name(get_type_for()), - option2name(option), optiontype2name(option2type(option))); - } +bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, T& value) { + assert(option_matches_type(option, value), "Value must match option type"); if (option_list != NULL) { - TypedMethodOptionMatcher* m = option_list->match(method, option, type); + TypedMethodOptionMatcher* m = option_list->match(method, option); if (m != NULL) { value = m->value(); return true; @@ -361,11 +341,29 @@ bool CompilerOracle::has_any_command_set() { } // Explicit instantiation for all OptionTypes supported. -template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, intx& value, bool verify_type); -template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, uintx& value, bool verify_type); -template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, bool& value, bool verify_type); -template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, ccstr& value, bool verify_type); -template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, double& value, bool verify_type); +template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, intx& value); +template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, uintx& value); +template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, bool& value); +template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, ccstr& value); +template bool CompilerOracle::has_option_value(const methodHandle& method, enum CompileCommand option, double& value); + +template +bool CompilerOracle::option_matches_type(enum CompileCommand option, T& value) { + enum OptionType option_type = option2type(option); + if (option_type == OptionType::Unknown) { + return false; // Can't query options with type Unknown. + } + if (option_type == OptionType::Ccstrlist) { + option_type = OptionType::Ccstr; // CCstrList type options are stored as Ccstr + } + return (get_type_for() == option_type); +} + +template bool CompilerOracle::option_matches_type(enum CompileCommand option, intx& value); +template bool CompilerOracle::option_matches_type(enum CompileCommand option, uintx& value); +template bool CompilerOracle::option_matches_type(enum CompileCommand option, bool& value); +template bool CompilerOracle::option_matches_type(enum CompileCommand option, ccstr& value); +template bool CompilerOracle::option_matches_type(enum CompileCommand option, double& value); bool CompilerOracle::has_option(const methodHandle& method, enum CompileCommand option) { bool value = false; diff --git a/src/hotspot/share/compiler/compilerOracle.hpp b/src/hotspot/share/compiler/compilerOracle.hpp index e834254f506..e8f7c2097a4 100644 --- a/src/hotspot/share/compiler/compilerOracle.hpp +++ b/src/hotspot/share/compiler/compilerOracle.hpp @@ -149,7 +149,11 @@ class CompilerOracle : AllStatic { // Check if method has option and value set. If yes, overwrite value and return true, // otherwise leave value unchanged and return false. template - static bool has_option_value(const methodHandle& method, enum CompileCommand option, T& value, bool verfiy_type = false); + static bool has_option_value(const methodHandle& method, enum CompileCommand option, T& value); + + // This check is currently only needed by whitebox API + template + static bool option_matches_type(enum CompileCommand option, T& value); // Reads from string instead of file static void parse_from_string(const char* option_string, void (*parser)(char*)); diff --git a/src/hotspot/share/prims/whitebox.cpp b/src/hotspot/share/prims/whitebox.cpp index 7e780990401..28a5162abd0 100644 --- a/src/hotspot/share/prims/whitebox.cpp +++ b/src/hotspot/share/prims/whitebox.cpp @@ -1814,7 +1814,10 @@ static bool GetMethodOption(JavaThread* thread, JNIEnv* env, jobject method, jst if (option == CompileCommand::Unknown) { return false; } - return CompilerOracle::has_option_value(mh, option, *value, true /* verify type*/); + if (!CompilerOracle::option_matches_type(option, *value)) { + return false; + } + return CompilerOracle::has_option_value(mh, option, *value); } WB_ENTRY(jobject, WB_GetMethodBooleaneOption(JNIEnv* env, jobject wb, jobject method, jstring name))