1 /*
  2  * Copyright (c) 1997, 2023, 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  private:
 95   // Statics & fields
 96   static void resolve_get_put(JavaThread* current, Bytecodes::Code bytecode);
 97 
 98   // Calls
 99   static void resolve_invoke(JavaThread* current, Bytecodes::Code bytecode);
100   static void resolve_invokehandle (JavaThread* current);
101   static void resolve_invokedynamic(JavaThread* current);
102 
103  public:
104   // Synchronization
105   static void    monitorenter(JavaThread* current, BasicObjectLock* elem);
106   static void    monitorenter_obj(JavaThread* current, oopDesc* obj);
107   static void    monitorexit (BasicObjectLock* elem);
108 
109   static void    throw_illegal_monitor_state_exception(JavaThread* current);
110   static void    new_illegal_monitor_state_exception(JavaThread* current);
111 
112   // Breakpoints
113   static void _breakpoint(JavaThread* current, Method* method, address bcp);
114   static Bytecodes::Code get_original_bytecode_at(JavaThread* current, Method* method, address bcp);
115   static void            set_original_bytecode_at(JavaThread* current, Method* method, address bcp, Bytecodes::Code new_code);
116 
117   // Safepoints
118   static void    at_safepoint(JavaThread* current);
119   static void    at_unwind(JavaThread* current);
120 
121   // Debugger support
122   static void post_field_access(JavaThread* current, oopDesc* obj,
123     ResolvedFieldEntry* entry);
124   static void post_field_modification(JavaThread* current, oopDesc* obj,
125     ResolvedFieldEntry* entry, jvalue *value);
126   static void post_method_entry(JavaThread* current);
127   static void post_method_exit (JavaThread* current);
128   static int  interpreter_contains(address pc);
129 
130   // Native signature handlers
131   static void prepare_native_call(JavaThread* current, Method* method);
132   static address slow_signature_handler(JavaThread* current,
133                                         Method* method,
134                                         intptr_t* from, intptr_t* to);
135 
136 #if defined(IA32) || defined(AMD64) || defined(ARM)
137   // Popframe support (only needed on x86, AMD64 and ARM)
138   static void popframe_move_outgoing_args(JavaThread* current, void* src_address, void* dest_address);
139 #endif
140 
141   // bytecode tracing is only used by the TraceBytecodes
142   static intptr_t trace_bytecode(JavaThread* current, intptr_t preserve_this_value, intptr_t tos, intptr_t tos2) PRODUCT_RETURN0;
143 
144   // Platform dependent stuff
145 #include CPU_HEADER(interpreterRT)
146 
147   // optional normalization of fingerprints to reduce the number of adapters
148   static uint64_t normalize_fast_native_fingerprint(uint64_t fingerprint);
149 
150   // Interpreter's frequency counter overflow
151   static nmethod* frequency_counter_overflow(JavaThread* current, address branch_bcp);
152 
153   // Interpreter profiling support
154   static jint    bcp_to_di(Method* method, address cur_bcp);
155   static void    update_mdp_for_ret(JavaThread* current, int bci);
156 #ifdef ASSERT
157   static void    verify_mdp(Method* method, address bcp, address mdp);
158 #endif // ASSERT
159   static MethodCounters* build_method_counters(JavaThread* current, Method* m);
160 };
161 
162 
163 class SignatureHandlerLibrary: public AllStatic {
164  public:
165   enum { buffer_size =  1*K }; // the size of the temporary code buffer
166   enum { blob_size   = 32*K }; // the size of a handler code blob.
167 
168  private:
169   static BufferBlob*              _handler_blob; // the current buffer blob containing the generated handlers
170   static address                  _handler;      // next available address within _handler_blob;
171   static GrowableArray<uint64_t>* _fingerprints; // the fingerprint collection
172   static GrowableArray<address>*  _handlers;     // the corresponding handlers
173   static address                  _buffer;       // the temporary code buffer
174 
175   static address set_handler_blob();
176   static void initialize();
177   static address set_handler(CodeBuffer* buffer);
178   static void pd_set_handler(address handler);
179 
180  public:
181   static void add(const methodHandle& method);
182   static void add(uint64_t fingerprint, address handler);
183 };
184 
185 #endif // SHARE_INTERPRETER_INTERPRETERRUNTIME_HPP