1 /* 2 * Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 * 23 */ 24 25 #ifndef SHARE_COMPILER_COMPILERORACLE_HPP 26 #define SHARE_COMPILER_COMPILERORACLE_HPP 27 28 #include "memory/allStatic.hpp" 29 #include "oops/oopsHierarchy.hpp" 30 #include "utilities/istream.hpp" 31 32 class methodHandle; 33 34 35 // CompilerOracle is an interface for turning on and off compilation 36 // for some methods 37 38 // OPTION_TYPES: type, name 39 #define OPTION_TYPES(type) \ 40 type(Intx, "intx") \ 41 type(Uintx, "uintx") \ 42 type(Bool, "bool") \ 43 type(Ccstr, "ccstr") \ 44 type(Ccstrlist, "ccstrlist") \ 45 type(Double, "double") 46 47 // COMPILECOMMAND_OPTIONS: option, name, variant, type 48 #define COMPILECOMMAND_OPTIONS(option) \ 49 option(Help, "help", Unknown) \ 50 option(Quiet, "quiet", Unknown) \ 51 option(Log, "log", Bool) \ 52 option(Print, "print", Bool) \ 53 option(Inline, "inline", Bool) \ 54 option(DontInline, "dontinline", Bool) \ 55 option(Blackhole, "blackhole", Bool) \ 56 option(CompileOnly, "compileonly", Bool)\ 57 option(Exclude, "exclude", Bool) \ 58 option(Break, "break", Bool) \ 59 option(BreakAtExecute, "BreakAtExecute", Bool) \ 60 option(BreakAtCompile, "BreakAtCompile", Bool) \ 61 option(MemLimit, "MemLimit", Intx) \ 62 option(MemStat, "MemStat", Uintx) \ 63 option(PrintAssembly, "PrintAssembly", Bool) \ 64 option(PrintCompilation, "PrintCompilation", Bool) \ 65 option(PrintInlining, "PrintInlining", Bool) \ 66 option(PrintIntrinsics, "PrintIntrinsics", Bool) \ 67 option(PrintNMethods, "PrintNMethods", Bool) \ 68 option(PrintOptoAssembly, "PrintOptoAssembly", Bool) \ 69 option(PrintDebugInfo, "PrintDebugInfo", Bool) \ 70 option(PrintRelocations, "PrintRelocations", Bool) \ 71 option(PrintDependencies, "PrintDependencies", Bool) \ 72 option(BackgroundCompilation, "BackgroundCompilation", Bool) \ 73 option(RepeatCompilation, "RepeatCompilation", Intx) \ 74 option(ReplayInline, "ReplayInline", Bool) \ 75 option(DumpReplay, "DumpReplay", Bool) \ 76 option(DumpInline, "DumpInline", Bool) \ 77 option(CompileThresholdScaling, "CompileThresholdScaling", Double) \ 78 option(ControlIntrinsic, "ControlIntrinsic", Ccstrlist) \ 79 option(DisableIntrinsic, "DisableIntrinsic", Ccstrlist) \ 80 option(BlockLayoutByFrequency, "BlockLayoutByFrequency", Bool) \ 81 option(TraceOptoPipelining, "TraceOptoPipelining", Bool) \ 82 option(TraceOptoOutput, "TraceOptoOutput", Bool) \ 83 option(TraceSpilling, "TraceSpilling", Bool) \ 84 NOT_PRODUCT(option(TraceEscapeAnalysis, "TraceEscapeAnalysis", Bool)) \ 85 NOT_PRODUCT(option(PrintIdeal, "PrintIdeal", Bool)) \ 86 NOT_PRODUCT(option(PrintIdealPhase, "PrintIdealPhase", Ccstrlist)) \ 87 NOT_PRODUCT(option(IGVPrintLevel, "IGVPrintLevel", Intx)) \ 88 NOT_PRODUCT(option(TraceAutoVectorization, "TraceAutoVectorization", Ccstrlist)) \ 89 NOT_PRODUCT(option(TraceMergeStores, "TraceMergeStores", Ccstrlist)) \ 90 option(Vectorize, "Vectorize", Bool) \ 91 option(CloneMapDebug, "CloneMapDebug", Bool) \ 92 option(IncrementalInlineForceCleanup, "IncrementalInlineForceCleanup", Bool) \ 93 option(MaxNodeLimit, "MaxNodeLimit", Intx) \ 94 NOT_PRODUCT(option(TestOptionInt, "TestOptionInt", Intx)) \ 95 NOT_PRODUCT(option(TestOptionUint, "TestOptionUint", Uintx)) \ 96 NOT_PRODUCT(option(TestOptionBool, "TestOptionBool", Bool)) \ 97 NOT_PRODUCT(option(TestOptionBool2, "TestOptionBool2", Bool)) \ 98 NOT_PRODUCT(option(TestOptionStr, "TestOptionStr", Ccstr)) \ 99 NOT_PRODUCT(option(TestOptionList, "TestOptionList", Ccstrlist)) \ 100 NOT_PRODUCT(option(TestOptionDouble, "TestOptionDouble", Double)) \ 101 option(Option, "option", Unknown) \ 102 option(Unknown, "unknown", Unknown) 103 104 enum class CompileCommandEnum : int { 105 #define enum_of_options(option, name, ctype) option, 106 COMPILECOMMAND_OPTIONS(enum_of_options) 107 #undef enum_of_options 108 Count 109 }; 110 111 enum class OptionType { 112 #define enum_of_types(type, name) type, 113 OPTION_TYPES(enum_of_types) 114 #undef enum_of_types 115 Unknown 116 }; 117 118 enum class MemStatAction { 119 collect = 1, print = 2 120 }; 121 122 class CompilerOracle : AllStatic { 123 public: 124 typedef bool parse_from_line_fn_t(char*); 125 126 private: 127 static bool _quiet; 128 static void print_parse_error(char* error_msg, char* original_line); 129 static void print_command(CompileCommandEnum option, const char* name, enum OptionType type); 130 131 // The core parser. 132 static bool parse_from_input(inputStream::Input* input, 133 parse_from_line_fn_t* parse_from_line); 134 135 public: 136 // True if the command file has been specified or is implicit 137 static bool has_command_file(); 138 139 // Reads from file and adds to lists 140 static bool parse_from_file(); 141 142 // Tells whether we to exclude compilation of method 143 static bool should_exclude(const methodHandle& method); 144 static bool be_quiet() { return _quiet; } 145 146 // Tells whether we want to inline this method 147 static bool should_inline(const methodHandle& method); 148 149 // Tells whether we want to disallow inlining of this method 150 static bool should_not_inline(const methodHandle& method); 151 152 // Tells whether this method changes Thread.currentThread() 153 static bool changes_current_thread(const methodHandle& method); 154 155 // Tells whether we should print the assembly for this method 156 static bool should_print(const methodHandle& method); 157 158 // Tells whether we should log the compilation data for this method 159 static bool should_log(const methodHandle& method); 160 161 // Tells whether to break when compiling method 162 static bool should_break_at(const methodHandle& method); 163 164 // Tells whether there are any methods to print for print_method_statistics() 165 static bool should_print_methods(); 166 167 // Tells whether there are any methods to (collect|collect+print) memory statistics for 168 static bool should_collect_memstat(); 169 static bool should_print_final_memstat_report(); 170 171 // Tags the method as blackhole candidate, if possible. 172 static void tag_blackhole_if_possible(const methodHandle& method); 173 174 // A wrapper for checking bool options 175 static bool has_option(const methodHandle& method, CompileCommandEnum option); 176 177 // Check if method has option and value set. If yes, overwrite value and return true, 178 // otherwise leave value unchanged and return false. 179 template<typename T> 180 static bool has_option_value(const methodHandle& method, CompileCommandEnum option, T& value); 181 182 // This check is currently only needed by whitebox API 183 template<typename T> 184 static bool option_matches_type(CompileCommandEnum option, T& value); 185 186 // Reads from string instead of file 187 static bool parse_from_string(const char* option_string, 188 parse_from_line_fn_t* parser); 189 static bool parse_from_line(char* line); 190 static bool parse_from_line_quietly(char* line); 191 static bool parse_compile_only(char* line); 192 193 // Fast check if there is any option set that compile control needs to know about 194 static bool has_any_command_set(); 195 196 // convert a string to a proper compilecommand option - used from whitebox. 197 // returns CompileCommandEnum::Unknown on names not matching an option. 198 static CompileCommandEnum string_to_option(const char* name); 199 200 // convert a string to a proper compilecommand option 201 // returns CompileCommandEnum::Unknown if name is not an option. 202 static CompileCommandEnum parse_option_name(const char* name); 203 204 // convert a string to a proper option type 205 // returns OptionType::Unknown on strings not matching an option type. 206 static enum OptionType parse_option_type(const char* type_str); 207 }; 208 209 #endif // SHARE_COMPILER_COMPILERORACLE_HPP