1 /*
  2  * Copyright (c) 1997, 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_INTERPRETER_INTERPRETERRUNTIME_HPP
 26 #define SHARE_INTERPRETER_INTERPRETERRUNTIME_HPP
 27 
 28 #include "interpreter/bytecode.hpp"
 29 #include "interpreter/linkResolver.hpp"
 30 #include "oops/method.hpp"
 31 #include "runtime/frame.hpp"
 32 #include "runtime/javaThread.hpp"
 33 #include "runtime/signature.hpp"
 34 #include "utilities/macros.hpp"
 35 
 36 class BufferBlob;
 37 class CodeBuffer;
 38 
 39 // The InterpreterRuntime is called by the interpreter for everything
 40 // that cannot/should not be dealt with in assembly and needs C support.
 41 
 42 class InterpreterRuntime: AllStatic {
 43  private:
 44 
 45   static void      set_bcp_and_mdp(address bcp, JavaThread* current);
 46   static void      note_trap_inner(JavaThread* current, int reason,
 47                                    const methodHandle& trap_method, int trap_bci);
 48   static void      note_trap(JavaThread* current, int reason);
 49 
 50   // Inner work method for Interpreter's frequency counter overflow.
 51   static nmethod* frequency_counter_overflow_inner(JavaThread* current, address branch_bcp);
 52 
 53  public:
 54   // Constants
 55   static void    ldc           (JavaThread* current, bool wide);
 56   static void    resolve_ldc   (JavaThread* current, Bytecodes::Code bytecode);
 57 
 58   // Allocation
 59   static void    _new          (JavaThread* current, ConstantPool* pool, int index);
 60   static void    newarray      (JavaThread* current, BasicType type, jint size);
 61   static void    anewarray     (JavaThread* current, ConstantPool* pool, int index, jint size);
 62   static void    multianewarray(JavaThread* current, jint* first_size_address);
 63   static void    register_finalizer(JavaThread* current, oopDesc* obj);
 64 
 65   // Quicken instance-of and check-cast bytecodes
 66   static void    quicken_io_cc(JavaThread* current);
 67 
 68   // Exceptions thrown by the interpreter
 69   static void    throw_AbstractMethodError(JavaThread* current);
 70   static void    throw_AbstractMethodErrorWithMethod(JavaThread* current, Method* oop);
 71   static void    throw_AbstractMethodErrorVerbose(JavaThread* current,
 72                                                   Klass* recvKlass,
 73                                                   Method* missingMethod);
 74 
 75   static void    throw_IncompatibleClassChangeError(JavaThread* current);
 76   static void    throw_IncompatibleClassChangeErrorVerbose(JavaThread* current,
 77                                                            Klass* resc,
 78                                                            Klass* interfaceKlass);
 79   static void    throw_StackOverflowError(JavaThread* current);
 80   static void    throw_delayed_StackOverflowError(JavaThread* current);
 81   static void    throw_ArrayIndexOutOfBoundsException(JavaThread* current, arrayOopDesc* a, jint index);
 82   static void    throw_ClassCastException(JavaThread* current, oopDesc* obj);
 83   static void    throw_NullPointerException(JavaThread* current);
 84 
 85   static void    create_exception(JavaThread* current, char* name, char* message);
 86   static void    create_klass_exception(JavaThread* current, char* name, oopDesc* obj);
 87   static address exception_handler_for_exception(JavaThread* current, oopDesc* exception);
 88 #if INCLUDE_JVMTI
 89   static void    member_name_arg_or_null(JavaThread* current, address dmh, Method* m, address bcp);
 90 #endif
 91   static void    throw_pending_exception(JavaThread* current);
 92 
 93   static void resolve_from_cache(JavaThread* current, Bytecodes::Code bytecode);
 94 
 95   // Used by ClassPrelinker
 96   static void resolve_get_put(Bytecodes::Code bytecode, int field_index,
 97                               methodHandle& m, constantPoolHandle& pool, bool initialize_holder, TRAPS);
 98   static void cds_resolve_invoke(Bytecodes::Code bytecode, int method_index,
 99                                  constantPoolHandle& pool, TRAPS);
100 
101 private:
102   // Statics & fields
103   static void resolve_get_put(JavaThread* current, Bytecodes::Code bytecode);
104 
105   // Calls
106   static void resolve_invoke(JavaThread* current, Bytecodes::Code bytecode);
107   static void resolve_invokehandle (JavaThread* current);
108   static void resolve_invokedynamic(JavaThread* current);
109 
110   static void update_invoke_cp_cache_entry(CallInfo& info, Bytecodes::Code bytecode,
111                                            methodHandle& resolved_method,
112                                            constantPoolHandle& pool, int method_index);
113  public:
114   // Synchronization
115   static void    monitorenter(JavaThread* current, BasicObjectLock* elem);
116   static void    monitorenter_obj(JavaThread* current, oopDesc* obj);
117   static void    monitorexit (BasicObjectLock* elem);
118 
119   static void    throw_illegal_monitor_state_exception(JavaThread* current);
120   static void    new_illegal_monitor_state_exception(JavaThread* current);
121 
122   // Breakpoints
123   static void _breakpoint(JavaThread* current, Method* method, address bcp);
124   static Bytecodes::Code get_original_bytecode_at(JavaThread* current, Method* method, address bcp);
125   static void            set_original_bytecode_at(JavaThread* current, Method* method, address bcp, Bytecodes::Code new_code);
126 
127   // Safepoints
128   static void    at_safepoint(JavaThread* current);
129   static void    at_unwind(JavaThread* current);
130 
131   // Debugger support
132   static void post_field_access(JavaThread* current, oopDesc* obj,
133     ResolvedFieldEntry* entry);
134   static void post_field_modification(JavaThread* current, oopDesc* obj,
135     ResolvedFieldEntry* entry, jvalue *value);
136   static void post_method_entry(JavaThread* current);
137   static void post_method_exit (JavaThread* current);
138   static int  interpreter_contains(address pc);
139 
140   // Native signature handlers
141   static void prepare_native_call(JavaThread* current, Method* method);
142   static address slow_signature_handler(JavaThread* current,
143                                         Method* method,
144                                         intptr_t* from, intptr_t* to);
145 
146 #if defined(IA32) || defined(AMD64) || defined(ARM)
147   // Popframe support (only needed on x86, AMD64 and ARM)
148   static void popframe_move_outgoing_args(JavaThread* current, void* src_address, void* dest_address);
149 #endif
150 
151   // bytecode tracing is only used by the TraceBytecodes
152   static intptr_t trace_bytecode(JavaThread* current, intptr_t preserve_this_value, intptr_t tos, intptr_t tos2) PRODUCT_RETURN0;
153 
154   // Platform dependent stuff
155 #include CPU_HEADER(interpreterRT)
156 
157   // optional normalization of fingerprints to reduce the number of adapters
158   static uint64_t normalize_fast_native_fingerprint(uint64_t fingerprint);
159 
160   // Interpreter's frequency counter overflow
161   static nmethod* frequency_counter_overflow(JavaThread* current, address branch_bcp);
162 
163   // Interpreter profiling support
164   static jint    bcp_to_di(Method* method, address cur_bcp);
165   static void    update_mdp_for_ret(JavaThread* current, int bci);
166 #ifdef ASSERT
167   static void    verify_mdp(Method* method, address bcp, address mdp);
168 #endif // ASSERT
169   static MethodCounters* build_method_counters(JavaThread* current, Method* m);
170 };
171 
172 
173 class SignatureHandlerLibrary: public AllStatic {
174  public:
175   enum { buffer_size =  1*K }; // the size of the temporary code buffer
176   enum { blob_size   = 32*K }; // the size of a handler code blob.
177 
178  private:
179   static BufferBlob*              _handler_blob; // the current buffer blob containing the generated handlers
180   static address                  _handler;      // next available address within _handler_blob;
181   static GrowableArray<uint64_t>* _fingerprints; // the fingerprint collection
182   static GrowableArray<address>*  _handlers;     // the corresponding handlers
183   static address                  _buffer;       // the temporary code buffer
184 
185   static address set_handler_blob();
186   static void initialize();
187   static address set_handler(CodeBuffer* buffer);
188   static void pd_set_handler(address handler);
189 
190  public:
191   static void add(const methodHandle& method);
192   static void add(uint64_t fingerprint, address handler);
193 };
194 
195 #endif // SHARE_INTERPRETER_INTERPRETERRUNTIME_HPP