1 /*
   2  * Copyright (c) 2015, 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 #include "precompiled.hpp"
  26 #include "code/codeCache.hpp"
  27 #include "code/compiledIC.hpp"
  28 #include "compiler/compileBroker.hpp"
  29 #include "gc/shared/collectedHeap.hpp"
  30 #include "jvmci/jvmciCodeInstaller.hpp"
  31 #include "jvmci/jvmciCompilerToVM.hpp"
  32 #include "jvmci/jvmciRuntime.hpp"
  33 #include "jvmci/vmStructs_jvmci.hpp"
  34 #include "oops/klassVtable.hpp"
  35 #include "oops/methodCounters.hpp"
  36 #include "oops/objArrayKlass.hpp"
  37 #include "prims/jvmtiThreadState.hpp"
  38 #include "runtime/continuationEntry.hpp"
  39 #include "runtime/deoptimization.hpp"
  40 #include "runtime/flags/jvmFlag.hpp"
  41 #include "runtime/objectMonitor.hpp"
  42 #include "runtime/osThread.hpp"
  43 #include "runtime/sharedRuntime.hpp"
  44 #include "runtime/stubRoutines.hpp"
  45 #include "runtime/vm_version.hpp"
  46 #if INCLUDE_G1GC
  47 #include "gc/g1/g1BarrierSetRuntime.hpp"
  48 #include "gc/g1/g1CardTable.hpp"
  49 #include "gc/g1/g1HeapRegion.hpp"
  50 #include "gc/g1/g1ThreadLocalData.hpp"
  51 #endif
  52 #if INCLUDE_ZGC
  53 #include "gc/x/xBarrierSetRuntime.hpp"
  54 #include "gc/z/zBarrierSetAssembler.hpp"
  55 #include "gc/z/zBarrierSetRuntime.hpp"
  56 #include "gc/z/zThreadLocalData.hpp"
  57 #endif
  58 
  59 #define VM_STRUCTS(nonstatic_field, static_field, unchecked_nonstatic_field, volatile_nonstatic_field) \
  60   static_field(CompilerToVM::Data,             Klass_vtable_start_offset,              int)                                          \
  61   static_field(CompilerToVM::Data,             Klass_vtable_length_offset,             int)                                          \
  62                                                                                                                                      \
  63   static_field(CompilerToVM::Data,             Method_extra_stack_entries,             int)                                          \
  64                                                                                                                                      \
  65   static_field(CompilerToVM::Data,             SharedRuntime_ic_miss_stub,             address)                                      \
  66   static_field(CompilerToVM::Data,             SharedRuntime_handle_wrong_method_stub, address)                                      \
  67   static_field(CompilerToVM::Data,             SharedRuntime_deopt_blob_unpack,        address)                                      \
  68   static_field(CompilerToVM::Data,             SharedRuntime_deopt_blob_unpack_with_exception_in_tls,                                \
  69                                                                                        address)                                      \
  70   static_field(CompilerToVM::Data,             SharedRuntime_deopt_blob_uncommon_trap, address)                                      \
  71   static_field(CompilerToVM::Data,             SharedRuntime_polling_page_return_handler,                                            \
  72                                                                                        address)                                      \
  73   static_field(CompilerToVM::Data,             SharedRuntime_throw_delayed_StackOverflowError_entry,                                 \
  74                                                                                        address)                                      \
  75                                                                                                                                      \
  76   static_field(CompilerToVM::Data,             nmethod_entry_barrier, address)                                                       \
  77   static_field(CompilerToVM::Data,             thread_disarmed_guard_value_offset, int)                                              \
  78   static_field(CompilerToVM::Data,             thread_address_bad_mask_offset, int)                                                  \
  79   AARCH64_ONLY(static_field(CompilerToVM::Data, BarrierSetAssembler_nmethod_patching_type, int))                                     \
  80   AARCH64_ONLY(static_field(CompilerToVM::Data, BarrierSetAssembler_patching_epoch_addr, address))                                   \
  81                                                                                                                                      \
  82   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_load_barrier_on_oop_field_preloaded, address)                      \
  83   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_load_barrier_on_weak_oop_field_preloaded, address)                 \
  84   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_load_barrier_on_phantom_oop_field_preloaded, address)              \
  85   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_weak_load_barrier_on_oop_field_preloaded, address)                 \
  86   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_weak_load_barrier_on_weak_oop_field_preloaded, address)            \
  87   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_weak_load_barrier_on_phantom_oop_field_preloaded, address)         \
  88   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_load_barrier_on_oop_array, address)                                \
  89   static_field(CompilerToVM::Data,             ZBarrierSetRuntime_clone, address)                                                    \
  90                                                                                                                                      \
  91   static_field(CompilerToVM::Data,             ZPointerVectorLoadBadMask_address, address)                                           \
  92   static_field(CompilerToVM::Data,             ZPointerVectorStoreBadMask_address, address)                                          \
  93   static_field(CompilerToVM::Data,             ZPointerVectorStoreGoodMask_address, address)                                         \
  94                                                                                                                                      \
  95   static_field(CompilerToVM::Data,             continuations_enabled, bool)                                                          \
  96                                                                                                                                      \
  97   static_field(CompilerToVM::Data,             ThreadLocalAllocBuffer_alignment_reserve, size_t)                                     \
  98                                                                                                                                      \
  99   static_field(CompilerToVM::Data,             Universe_collectedHeap,                 CollectedHeap*)                               \
 100   static_field(CompilerToVM::Data,             Universe_base_vtable_size,              int)                                          \
 101   static_field(CompilerToVM::Data,             Universe_narrow_oop_base,               address)                                      \
 102   static_field(CompilerToVM::Data,             Universe_narrow_oop_shift,              int)                                          \
 103   static_field(CompilerToVM::Data,             Universe_narrow_klass_base,             address)                                      \
 104   static_field(CompilerToVM::Data,             Universe_narrow_klass_shift,            int)                                          \
 105   static_field(CompilerToVM::Data,             Universe_non_oop_bits,                  void*)                                        \
 106   static_field(CompilerToVM::Data,             Universe_verify_oop_mask,               uintptr_t)                                    \
 107   static_field(CompilerToVM::Data,             Universe_verify_oop_bits,               uintptr_t)                                    \
 108                                                                                                                                      \
 109   static_field(CompilerToVM::Data,             _supports_inline_contig_alloc,          bool)                                         \
 110   static_field(CompilerToVM::Data,             _heap_end_addr,                         HeapWord**)                                   \
 111   static_field(CompilerToVM::Data,             _heap_top_addr,                         HeapWord* volatile*)                          \
 112                                                                                                                                      \
 113   static_field(CompilerToVM::Data,             _max_oop_map_stack_offset,              int)                                          \
 114   static_field(CompilerToVM::Data,             _fields_annotations_base_offset,        int)                                          \
 115                                                                                                                                      \
 116   static_field(CompilerToVM::Data,             cardtable_start_address,                CardTable::CardValue*)                        \
 117   static_field(CompilerToVM::Data,             cardtable_shift,                        int)                                          \
 118                                                                                                                                      \
 119   X86_ONLY(static_field(CompilerToVM::Data,    L1_line_size,                           int))                                         \
 120                                                                                                                                      \
 121   static_field(CompilerToVM::Data,             vm_page_size,                           size_t)                                       \
 122                                                                                                                                      \
 123   static_field(CompilerToVM::Data,             sizeof_vtableEntry,                     int)                                          \
 124   static_field(CompilerToVM::Data,             sizeof_ExceptionTableElement,           int)                                          \
 125   static_field(CompilerToVM::Data,             sizeof_LocalVariableTableElement,       int)                                          \
 126   static_field(CompilerToVM::Data,             sizeof_ConstantPool,                    int)                                          \
 127   static_field(CompilerToVM::Data,             sizeof_narrowKlass,                     int)                                          \
 128   static_field(CompilerToVM::Data,             sizeof_arrayOopDesc,                    int)                                          \
 129   static_field(CompilerToVM::Data,             sizeof_BasicLock,                       int)                                          \
 130   ZGC_ONLY(static_field(CompilerToVM::Data,    sizeof_ZStoreBarrierEntry,              int))                                         \
 131                                                                                                                                      \
 132   static_field(CompilerToVM::Data,             dsin,                                   address)                                      \
 133   static_field(CompilerToVM::Data,             dcos,                                   address)                                      \
 134   static_field(CompilerToVM::Data,             dtan,                                   address)                                      \
 135   static_field(CompilerToVM::Data,             dexp,                                   address)                                      \
 136   static_field(CompilerToVM::Data,             dlog,                                   address)                                      \
 137   static_field(CompilerToVM::Data,             dlog10,                                 address)                                      \
 138   static_field(CompilerToVM::Data,             dpow,                                   address)                                      \
 139                                                                                                                                      \
 140   static_field(CompilerToVM::Data,             symbol_init,                            address)                                      \
 141   static_field(CompilerToVM::Data,             symbol_clinit,                          address)                                      \
 142                                                                                                                                      \
 143   static_field(CompilerToVM::Data,             data_section_item_alignment,            int)                                          \
 144                                                                                                                                      \
 145   JVMTI_ONLY(static_field(CompilerToVM::Data,  _should_notify_object_alloc,            int*))                                         \
 146                                                                                                                                      \
 147   static_field(Abstract_VM_Version,            _features,                              uint64_t)                                     \
 148                                                                                                                                      \
 149   nonstatic_field(Annotations,                 _class_annotations,                     AnnotationArray*)                             \
 150   nonstatic_field(Annotations,                 _fields_annotations,                    Array<AnnotationArray*>*)                     \
 151                                                                                                                                      \
 152   nonstatic_field(Array<int>,                  _length,                                int)                                          \
 153   unchecked_nonstatic_field(Array<u1>,         _data,                                  sizeof(u1))                                   \
 154   unchecked_nonstatic_field(Array<u2>,         _data,                                  sizeof(u2))                                   \
 155   nonstatic_field(Array<Klass*>,               _length,                                int)                                          \
 156   nonstatic_field(Array<Klass*>,               _data[0],                               Klass*)                                       \
 157                                                                                                                                      \
 158   volatile_nonstatic_field(BasicLock,          _metadata,                              uintptr_t)                                    \
 159                                                                                                                                      \
 160   static_field(CodeCache,                      _low_bound,                             address)                                      \
 161   static_field(CodeCache,                      _high_bound,                            address)                                      \
 162                                                                                                                                      \
 163   nonstatic_field(CollectedHeap,               _total_collections,                     unsigned int)                                 \
 164                                                                                                                                      \
 165   nonstatic_field(CompileTask,                 _num_inlined_bytecodes,                 int)                                          \
 166                                                                                                                                      \
 167   volatile_nonstatic_field(CompiledICData,     _speculated_method,                     Method*)                                      \
 168   volatile_nonstatic_field(CompiledICData,     _speculated_klass,                      uintptr_t)                                    \
 169   nonstatic_field(CompiledICData,              _itable_defc_klass,                     Klass*)                                       \
 170   nonstatic_field(CompiledICData,              _itable_refc_klass,                     Klass*)                                       \
 171                                                                                                                                      \
 172   nonstatic_field(ConstantPool,                _tags,                                  Array<u1>*)                                   \
 173   nonstatic_field(ConstantPool,                _pool_holder,                           InstanceKlass*)                               \
 174   nonstatic_field(ConstantPool,                _length,                                int)                                          \
 175   nonstatic_field(ConstantPool,                _flags,                                 u2)                                           \
 176   nonstatic_field(ConstantPool,                _source_file_name_index,                u2)                                           \
 177                                                                                                                                      \
 178   nonstatic_field(ConstMethod,                 _constants,                             ConstantPool*)                                \
 179   nonstatic_field(ConstMethod,                 _flags._flags,                          u4)                                           \
 180   nonstatic_field(ConstMethod,                 _code_size,                             u2)                                           \
 181   nonstatic_field(ConstMethod,                 _name_index,                            u2)                                           \
 182   nonstatic_field(ConstMethod,                 _signature_index,                       u2)                                           \
 183   nonstatic_field(ConstMethod,                 _method_idnum,                          u2)                                           \
 184   nonstatic_field(ConstMethod,                 _max_stack,                             u2)                                           \
 185   nonstatic_field(ConstMethod,                 _max_locals,                            u2)                                           \
 186                                                                                                                                      \
 187   nonstatic_field(DataLayout,                  _header._struct._tag,                   u1)                                           \
 188   nonstatic_field(DataLayout,                  _header._struct._flags,                 u1)                                           \
 189   nonstatic_field(DataLayout,                  _header._struct._bci,                   u2)                                           \
 190   nonstatic_field(DataLayout,                  _header._struct._traps,                 u4)                                           \
 191   nonstatic_field(DataLayout,                  _cells[0],                              intptr_t)                                     \
 192                                                                                                                                      \
 193   nonstatic_field(Deoptimization::UnrollBlock, _size_of_deoptimized_frame,             int)                                          \
 194   nonstatic_field(Deoptimization::UnrollBlock, _caller_adjustment,                     int)                                          \
 195   nonstatic_field(Deoptimization::UnrollBlock, _number_of_frames,                      int)                                          \
 196   nonstatic_field(Deoptimization::UnrollBlock, _total_frame_sizes,                     int)                                          \
 197   nonstatic_field(Deoptimization::UnrollBlock, _frame_sizes,                           intptr_t*)                                    \
 198   nonstatic_field(Deoptimization::UnrollBlock, _frame_pcs,                             address*)                                     \
 199   nonstatic_field(Deoptimization::UnrollBlock, _initial_info,                          intptr_t)                                     \
 200   nonstatic_field(Deoptimization::UnrollBlock, _unpack_kind,                           int)                                          \
 201                                                                                                                                      \
 202   nonstatic_field(ExceptionTableElement,       start_pc,                                      u2)                                    \
 203   nonstatic_field(ExceptionTableElement,       end_pc,                                        u2)                                    \
 204   nonstatic_field(ExceptionTableElement,       handler_pc,                                    u2)                                    \
 205   nonstatic_field(ExceptionTableElement,       catch_type_index,                              u2)                                    \
 206                                                                                                                                      \
 207   nonstatic_field(InstanceKlass,               _fieldinfo_stream,                             Array<u1>*)                            \
 208   nonstatic_field(InstanceKlass,               _constants,                                    ConstantPool*)                         \
 209   volatile_nonstatic_field(InstanceKlass,      _init_state,                                   InstanceKlass::ClassState)             \
 210   volatile_nonstatic_field(InstanceKlass,      _init_thread,                                  JavaThread*)                           \
 211   nonstatic_field(InstanceKlass,               _misc_flags._flags,                            u2)                                    \
 212   nonstatic_field(InstanceKlass,               _annotations,                                  Annotations*)                          \
 213                                                                                                                                      \
 214   volatile_nonstatic_field(JavaFrameAnchor,    _last_Java_sp,                                 intptr_t*)                             \
 215   volatile_nonstatic_field(JavaFrameAnchor,    _last_Java_pc,                                 address)                               \
 216                                                                                                                                      \
 217   nonstatic_field(JVMCICompileState,           _jvmti_can_hotswap_or_post_breakpoint,         jbyte)                                 \
 218   nonstatic_field(JVMCICompileState,           _jvmti_can_access_local_variables,             jbyte)                                 \
 219   nonstatic_field(JVMCICompileState,           _jvmti_can_post_on_exceptions,                 jbyte)                                 \
 220   nonstatic_field(JVMCICompileState,           _jvmti_can_pop_frame,                          jbyte)                                 \
 221   nonstatic_field(JVMCICompileState,           _compilation_ticks,                            jint)                                  \
 222                                                                                                                                      \
 223   nonstatic_field(JavaThread,                  _threadObj,                                    OopHandle)                             \
 224   nonstatic_field(JavaThread,                  _vthread,                                      OopHandle)                             \
 225   nonstatic_field(JavaThread,                  _scopedValueCache,                             OopHandle)                             \
 226   nonstatic_field(JavaThread,                  _anchor,                                       JavaFrameAnchor)                       \
 227   nonstatic_field(JavaThread,                  _vm_result,                                    oop)                                   \
 228   nonstatic_field(JavaThread,                  _stack_overflow_state._stack_overflow_limit,   address)                               \
 229   volatile_nonstatic_field(JavaThread,         _exception_oop,                                oop)                                   \
 230   volatile_nonstatic_field(JavaThread,         _exception_pc,                                 address)                               \
 231   volatile_nonstatic_field(JavaThread,         _is_method_handle_return,                      int)                                   \
 232   volatile_nonstatic_field(JavaThread,         _doing_unsafe_access,                          bool)                                  \
 233   nonstatic_field(JavaThread,                  _osthread,                                     OSThread*)                             \
 234   nonstatic_field(JavaThread,                  _saved_exception_pc,                           address)                               \
 235   nonstatic_field(JavaThread,                  _pending_deoptimization,                       int)                                   \
 236   nonstatic_field(JavaThread,                  _pending_failed_speculation,                   jlong)                                 \
 237   nonstatic_field(JavaThread,                  _pending_transfer_to_interpreter,              bool)                                  \
 238   nonstatic_field(JavaThread,                  _jvmci_counters,                               jlong*)                                \
 239   nonstatic_field(JavaThread,                  _jvmci_reserved0,                              jlong)                                 \
 240   nonstatic_field(JavaThread,                  _jvmci_reserved1,                              jlong)                                 \
 241   nonstatic_field(JavaThread,                  _jvmci_reserved_oop0,                          oop)                                   \
 242   nonstatic_field(JavaThread,                  _should_post_on_exceptions_flag,               int)                                   \
 243   nonstatic_field(JavaThread,                  _jni_environment,                              JNIEnv)                                \
 244   nonstatic_field(JavaThread,                  _poll_data,                                    SafepointMechanism::ThreadData)        \
 245   nonstatic_field(JavaThread,                  _stack_overflow_state._reserved_stack_activation, address)                            \
 246   nonstatic_field(JavaThread,                  _held_monitor_count,                           intx)                                  \
 247   nonstatic_field(JavaThread,                  _lock_stack,                                   LockStack)                             \
 248   nonstatic_field(JavaThread,                  _om_cache,                                     OMCache)                               \
 249   nonstatic_field(JavaThread,                  _cont_entry,                                   ContinuationEntry*)                    \
 250   nonstatic_field(JavaThread,                  _unlocked_inflated_monitor,                    ObjectMonitor*)                        \
 251   JVMTI_ONLY(nonstatic_field(JavaThread,       _is_in_VTMS_transition,                        bool))                                 \
 252   JVMTI_ONLY(nonstatic_field(JavaThread,       _is_in_tmp_VTMS_transition,                    bool))                                 \
 253   JVMTI_ONLY(nonstatic_field(JavaThread,       _is_disable_suspend,                           bool))                                 \
 254                                                                                                                                      \
 255   nonstatic_field(ContinuationEntry,           _pin_count,                                    uint32_t)                              \
 256   nonstatic_field(LockStack,                   _top,                                          uint32_t)                              \
 257                                                                                                                                      \
 258   JVMTI_ONLY(static_field(JvmtiVTMSTransitionDisabler, _VTMS_notify_jvmti_events,             bool))                                 \
 259                                                                                                                                      \
 260   static_field(java_lang_Class,                _klass_offset,                                 int)                                   \
 261   static_field(java_lang_Class,                _array_klass_offset,                           int)                                   \
 262                                                                                                                                      \
 263   nonstatic_field(InvocationCounter,           _counter,                                      unsigned int)                          \
 264                                                                                                                                      \
 265   nonstatic_field(Klass,                       _secondary_super_cache,                        Klass*)                                \
 266   nonstatic_field(Klass,                       _secondary_supers,                             Array<Klass*>*)                        \
 267   nonstatic_field(Klass,                       _super,                                        Klass*)                                \
 268   nonstatic_field(Klass,                       _super_check_offset,                           juint)                                 \
 269   volatile_nonstatic_field(Klass,              _subklass,                                     Klass*)                                \
 270   nonstatic_field(Klass,                       _layout_helper,                                jint)                                  \
 271   nonstatic_field(Klass,                       _name,                                         Symbol*)                               \
 272   volatile_nonstatic_field(Klass,              _next_sibling,                                 Klass*)                                \
 273   nonstatic_field(Klass,                       _java_mirror,                                  OopHandle)                             \
 274   nonstatic_field(Klass,                       _modifier_flags,                               jint)                                  \
 275   nonstatic_field(Klass,                       _access_flags,                                 AccessFlags)                           \
 276   nonstatic_field(Klass,                       _class_loader_data,                            ClassLoaderData*)                      \
 277   nonstatic_field(Klass,                       _bitmap,                                       uintx)                                 \
 278   nonstatic_field(Klass,                       _hash_slot,                                    uint8_t)                               \
 279   nonstatic_field(Klass,                       _misc_flags._flags,                            u1)                                    \
 280                                                                                                                                      \
 281   nonstatic_field(LocalVariableTableElement,   start_bci,                                     u2)                                    \
 282   nonstatic_field(LocalVariableTableElement,   length,                                        u2)                                    \
 283   nonstatic_field(LocalVariableTableElement,   name_cp_index,                                 u2)                                    \
 284   nonstatic_field(LocalVariableTableElement,   descriptor_cp_index,                           u2)                                    \
 285   nonstatic_field(LocalVariableTableElement,   signature_cp_index,                            u2)                                    \
 286   nonstatic_field(LocalVariableTableElement,   slot,                                          u2)                                    \
 287                                                                                                                                      \
 288   nonstatic_field(Method,                      _constMethod,                                  ConstMethod*)                          \
 289   nonstatic_field(Method,                      _method_data,                                  MethodData*)                           \
 290   nonstatic_field(Method,                      _method_counters,                              MethodCounters*)                       \
 291   nonstatic_field(Method,                      _access_flags,                                 AccessFlags)                           \
 292   nonstatic_field(Method,                      _vtable_index,                                 int)                                   \
 293   nonstatic_field(Method,                      _intrinsic_id,                                 u2)                                    \
 294   nonstatic_field(Method,                      _flags._status,                                u4)                                    \
 295   volatile_nonstatic_field(Method,             _code,                                         nmethod*)                              \
 296   volatile_nonstatic_field(Method,             _from_compiled_entry,                          address)                               \
 297                                                                                                                                      \
 298   nonstatic_field(MethodCounters,              _invoke_mask,                                  int)                                   \
 299   nonstatic_field(MethodCounters,              _backedge_mask,                                int)                                   \
 300   nonstatic_field(MethodCounters,              _interpreter_throwout_count,                   u2)                                    \
 301   JVMTI_ONLY(nonstatic_field(MethodCounters,   _number_of_breakpoints,                        u2))                                   \
 302   nonstatic_field(MethodCounters,              _invocation_counter,                           InvocationCounter)                     \
 303   nonstatic_field(MethodCounters,              _backedge_counter,                             InvocationCounter)                     \
 304                                                                                                                                      \
 305   nonstatic_field(MethodData,                  _size,                                         int)                                   \
 306   nonstatic_field(MethodData,                  _method,                                       Method*)                               \
 307   nonstatic_field(MethodData,                  _data_size,                                    int)                                   \
 308   nonstatic_field(MethodData,                  _data[0],                                      intptr_t)                              \
 309   nonstatic_field(MethodData,                  _parameters_type_data_di,                      int)                                   \
 310   nonstatic_field(MethodData,                  _compiler_counters._nof_decompiles,            uint)                                  \
 311   nonstatic_field(MethodData,                  _compiler_counters._nof_overflow_recompiles,   uint)                                  \
 312   nonstatic_field(MethodData,                  _compiler_counters._nof_overflow_traps,        uint)                                  \
 313   nonstatic_field(MethodData,                  _compiler_counters._trap_hist._array[0],       u1)                                    \
 314   nonstatic_field(MethodData,                  _eflags,                                       intx)                                  \
 315   nonstatic_field(MethodData,                  _arg_local,                                    intx)                                  \
 316   nonstatic_field(MethodData,                  _arg_stack,                                    intx)                                  \
 317   nonstatic_field(MethodData,                  _arg_returned,                                 intx)                                  \
 318   nonstatic_field(MethodData,                  _tenure_traps,                                 uint)                                  \
 319   nonstatic_field(MethodData,                  _invoke_mask,                                  int)                                   \
 320   nonstatic_field(MethodData,                  _backedge_mask,                                int)                                   \
 321   nonstatic_field(MethodData,                  _jvmci_ir_size,                                int)                                   \
 322                                                                                                                                      \
 323   nonstatic_field(nmethod,                     _verified_entry_offset,                        u2)                                    \
 324   nonstatic_field(nmethod,                     _comp_level,                                   CompLevel)                             \
 325                                                                                                                                      \
 326   nonstatic_field(ObjArrayKlass,               _element_klass,                                Klass*)                                \
 327                                                                                                                                      \
 328   unchecked_nonstatic_field(ObjectMonitor,     _owner,                                        sizeof(void *)) /* NOTE: no type */    \
 329   volatile_nonstatic_field(ObjectMonitor,      _recursions,                                   intptr_t)                              \
 330   volatile_nonstatic_field(ObjectMonitor,      _cxq,                                          ObjectWaiter*)                         \
 331   volatile_nonstatic_field(ObjectMonitor,      _EntryList,                                    ObjectWaiter*)                         \
 332   volatile_nonstatic_field(ObjectMonitor,      _succ,                                         JavaThread*)                           \
 333                                                                                                                                      \
 334   volatile_nonstatic_field(oopDesc,            _mark,                                         markWord)                              \
 335   volatile_nonstatic_field(oopDesc,            _metadata._klass,                              Klass*)                                \
 336                                                                                                                                      \
 337   static_field(StubRoutines,                _verify_oop_count,                                jint)                                  \
 338                                                                                                                                      \
 339   static_field(StubRoutines,                _jbyte_arraycopy,                                 address)                               \
 340   static_field(StubRoutines,                _jshort_arraycopy,                                address)                               \
 341   static_field(StubRoutines,                _jint_arraycopy,                                  address)                               \
 342   static_field(StubRoutines,                _jlong_arraycopy,                                 address)                               \
 343   static_field(StubRoutines,                _oop_arraycopy,                                   address)                               \
 344   static_field(StubRoutines,                _oop_arraycopy_uninit,                            address)                               \
 345   static_field(StubRoutines,                _jbyte_disjoint_arraycopy,                        address)                               \
 346   static_field(StubRoutines,                _jshort_disjoint_arraycopy,                       address)                               \
 347   static_field(StubRoutines,                _jint_disjoint_arraycopy,                         address)                               \
 348   static_field(StubRoutines,                _jlong_disjoint_arraycopy,                        address)                               \
 349   static_field(StubRoutines,                _oop_disjoint_arraycopy,                          address)                               \
 350   static_field(StubRoutines,                _oop_disjoint_arraycopy_uninit,                   address)                               \
 351   static_field(StubRoutines,                _arrayof_jbyte_arraycopy,                         address)                               \
 352   static_field(StubRoutines,                _arrayof_jshort_arraycopy,                        address)                               \
 353   static_field(StubRoutines,                _arrayof_jint_arraycopy,                          address)                               \
 354   static_field(StubRoutines,                _arrayof_jlong_arraycopy,                         address)                               \
 355   static_field(StubRoutines,                _arrayof_oop_arraycopy,                           address)                               \
 356   static_field(StubRoutines,                _arrayof_oop_arraycopy_uninit,                    address)                               \
 357   static_field(StubRoutines,                _arrayof_jbyte_disjoint_arraycopy,                address)                               \
 358   static_field(StubRoutines,                _arrayof_jshort_disjoint_arraycopy,               address)                               \
 359   static_field(StubRoutines,                _arrayof_jint_disjoint_arraycopy,                 address)                               \
 360   static_field(StubRoutines,                _arrayof_jlong_disjoint_arraycopy,                address)                               \
 361   static_field(StubRoutines,                _arrayof_oop_disjoint_arraycopy,                  address)                               \
 362   static_field(StubRoutines,                _arrayof_oop_disjoint_arraycopy_uninit,           address)                               \
 363   static_field(StubRoutines,                _checkcast_arraycopy,                             address)                               \
 364   static_field(StubRoutines,                _checkcast_arraycopy_uninit,                      address)                               \
 365   static_field(StubRoutines,                _unsafe_arraycopy,                                address)                               \
 366   static_field(StubRoutines,                _generic_arraycopy,                               address)                               \
 367   static_field(StubRoutines,                _array_sort,                                      address)                               \
 368   static_field(StubRoutines,                _array_partition,                                 address)                               \
 369   static_field(StubRoutines,                _unsafe_setmemory,                                address)                               \
 370                                                                                                                                      \
 371   static_field(StubRoutines,                _aescrypt_encryptBlock,                           address)                               \
 372   static_field(StubRoutines,                _aescrypt_decryptBlock,                           address)                               \
 373   static_field(StubRoutines,                _cipherBlockChaining_encryptAESCrypt,             address)                               \
 374   static_field(StubRoutines,                _cipherBlockChaining_decryptAESCrypt,             address)                               \
 375   static_field(StubRoutines,                _electronicCodeBook_encryptAESCrypt,              address)                               \
 376   static_field(StubRoutines,                _electronicCodeBook_decryptAESCrypt,              address)                               \
 377   static_field(StubRoutines,                _counterMode_AESCrypt,                            address)                               \
 378   static_field(StubRoutines,                _galoisCounterMode_AESCrypt,                      address)                               \
 379   static_field(StubRoutines,                _base64_encodeBlock,                              address)                               \
 380   static_field(StubRoutines,                _base64_decodeBlock,                              address)                               \
 381   static_field(StubRoutines,                _ghash_processBlocks,                             address)                               \
 382   static_field(StubRoutines,                _md5_implCompress,                                address)                               \
 383   static_field(StubRoutines,                _md5_implCompressMB,                              address)                               \
 384   static_field(StubRoutines,                _chacha20Block,                                   address)                               \
 385   static_field(StubRoutines,                _poly1305_processBlocks,                          address)                               \
 386   static_field(StubRoutines,                _intpoly_montgomeryMult_P256,                     address)                               \
 387   static_field(StubRoutines,                _intpoly_assign,                                  address)                               \
 388   static_field(StubRoutines,                _sha1_implCompress,                               address)                               \
 389   static_field(StubRoutines,                _sha1_implCompressMB,                             address)                               \
 390   static_field(StubRoutines,                _sha256_implCompress,                             address)                               \
 391   static_field(StubRoutines,                _sha256_implCompressMB,                           address)                               \
 392   static_field(StubRoutines,                _sha512_implCompress,                             address)                               \
 393   static_field(StubRoutines,                _sha512_implCompressMB,                           address)                               \
 394   static_field(StubRoutines,                _sha3_implCompress,                               address)                               \
 395   static_field(StubRoutines,                _sha3_implCompressMB,                             address)                               \
 396   static_field(StubRoutines,                _updateBytesCRC32,                                address)                               \
 397   static_field(StubRoutines,                _crc_table_adr,                                   address)                               \
 398   static_field(StubRoutines,                _crc32c_table_addr,                               address)                               \
 399   static_field(StubRoutines,                _updateBytesCRC32C,                               address)                               \
 400   static_field(StubRoutines,                _updateBytesAdler32,                              address)                               \
 401   static_field(StubRoutines,                _multiplyToLen,                                   address)                               \
 402   static_field(StubRoutines,                _squareToLen,                                     address)                               \
 403   static_field(StubRoutines,                _mulAdd,                                          address)                               \
 404   static_field(StubRoutines,                _montgomeryMultiply,                              address)                               \
 405   static_field(StubRoutines,                _montgomerySquare,                                address)                               \
 406   static_field(StubRoutines,                _vectorizedMismatch,                              address)                               \
 407   static_field(StubRoutines,                _bigIntegerRightShiftWorker,                      address)                               \
 408   static_field(StubRoutines,                _bigIntegerLeftShiftWorker,                       address)                               \
 409   static_field(StubRoutines,                _cont_thaw,                                       address)                               \
 410   static_field(StubRoutines,                _lookup_secondary_supers_table_slow_path_stub,    address)                               \
 411                                                                                                                                      \
 412   nonstatic_field(Thread,                   _tlab,                                            ThreadLocalAllocBuffer)                \
 413   nonstatic_field(Thread,                   _allocated_bytes,                                 jlong)                                 \
 414   JFR_ONLY(nonstatic_field(Thread,          _jfr_thread_local,                                JfrThreadLocal))                       \
 415                                                                                                                                      \
 416   static_field(java_lang_Thread,            _tid_offset,                                      int)                                   \
 417   static_field(java_lang_Thread,            _jvmti_is_in_VTMS_transition_offset,              int)                                   \
 418   JFR_ONLY(static_field(java_lang_Thread,   _jfr_epoch_offset,                                int))                                  \
 419                                                                                                                                      \
 420   JFR_ONLY(nonstatic_field(JfrThreadLocal,  _vthread_id,                                      traceid))                              \
 421   JFR_ONLY(nonstatic_field(JfrThreadLocal,  _vthread_epoch,                                   u2))                                   \
 422   JFR_ONLY(nonstatic_field(JfrThreadLocal,  _vthread_excluded,                                bool))                                 \
 423   JFR_ONLY(nonstatic_field(JfrThreadLocal,  _vthread,                                         bool))                                 \
 424                                                                                                                                      \
 425   nonstatic_field(ThreadLocalAllocBuffer,   _start,                                           HeapWord*)                             \
 426   nonstatic_field(ThreadLocalAllocBuffer,   _top,                                             HeapWord*)                             \
 427   nonstatic_field(ThreadLocalAllocBuffer,   _end,                                             HeapWord*)                             \
 428   nonstatic_field(ThreadLocalAllocBuffer,   _pf_top,                                          HeapWord*)                             \
 429   nonstatic_field(ThreadLocalAllocBuffer,   _desired_size,                                    size_t)                                \
 430   nonstatic_field(ThreadLocalAllocBuffer,   _refill_waste_limit,                              size_t)                                \
 431   nonstatic_field(ThreadLocalAllocBuffer,   _number_of_refills,                               unsigned)                              \
 432   nonstatic_field(ThreadLocalAllocBuffer,   _slow_allocations,                                unsigned)                              \
 433                                                                                                                                      \
 434   nonstatic_field(SafepointMechanism::ThreadData, _polling_word,                              volatile uintptr_t)                    \
 435   nonstatic_field(SafepointMechanism::ThreadData, _polling_page,                              volatile uintptr_t)                    \
 436                                                                                                                                      \
 437   nonstatic_field(ThreadShadow,             _pending_exception,                               oop)                                   \
 438                                                                                                                                      \
 439   static_field(Symbol,                      _vm_symbols[0],                                   Symbol*)                               \
 440                                                                                                                                      \
 441   nonstatic_field(vtableEntry,              _method,                                          Method*)                               \
 442 
 443 #define VM_TYPES(declare_type, declare_toplevel_type, declare_integer_type, declare_unsigned_integer_type) \
 444   declare_integer_type(bool)                                              \
 445   declare_unsigned_integer_type(size_t)                                   \
 446   declare_integer_type(intx)                                              \
 447   declare_unsigned_integer_type(uintx)                                    \
 448   declare_integer_type(CompLevel)                                         \
 449                                                                           \
 450   declare_toplevel_type(BasicLock)                                        \
 451   declare_toplevel_type(CompilerToVM)                                     \
 452   declare_toplevel_type(ExceptionTableElement)                            \
 453   declare_toplevel_type(JVMFlag)                                          \
 454   declare_toplevel_type(JVMFlag*)                                         \
 455   declare_toplevel_type(InvocationCounter)                                \
 456   declare_toplevel_type(JVMCICompileState)                                \
 457   declare_toplevel_type(JVMCIEnv)                                         \
 458   declare_toplevel_type(LocalVariableTableElement)                        \
 459   declare_toplevel_type(narrowKlass)                                      \
 460   declare_toplevel_type(ObjectWaiter)                                     \
 461   declare_toplevel_type(Symbol*)                                          \
 462   declare_toplevel_type(vtableEntry)                                      \
 463                                                                           \
 464   declare_toplevel_type(oopDesc)                                          \
 465     declare_type(arrayOopDesc, oopDesc)                                   \
 466                                                                           \
 467   declare_toplevel_type(CompiledICData)                                   \
 468   declare_toplevel_type(MetaspaceObj)                                     \
 469     declare_type(Metadata, MetaspaceObj)                                  \
 470     declare_type(Klass, Metadata)                                         \
 471       declare_type(InstanceKlass, Klass)                                  \
 472     declare_type(ConstantPool, Metadata)                                  \
 473 
 474 #define VM_INT_CONSTANTS(declare_constant, declare_constant_with_value, declare_preprocessor_constant) \
 475   declare_preprocessor_constant("ASSERT", DEBUG_ONLY(1) NOT_DEBUG(0))     \
 476                                                                           \
 477   declare_constant(CompLevel_none)                                        \
 478   declare_constant(CompLevel_simple)                                      \
 479   declare_constant(CompLevel_limited_profile)                             \
 480   declare_constant(CompLevel_full_profile)                                \
 481   declare_constant(CompLevel_full_optimization)                           \
 482   declare_constant(HeapWordSize)                                          \
 483   declare_constant(InvocationEntryBci)                                    \
 484   declare_constant(LogKlassAlignmentInBytes)                              \
 485   declare_constant(JVMCINMethodData::SPECULATION_LENGTH_BITS)             \
 486                                                                           \
 487   declare_constant(JVM_ACC_WRITTEN_FLAGS)                                 \
 488   declare_constant(FieldInfo::FieldFlags::_ff_injected)                   \
 489   declare_constant(FieldInfo::FieldFlags::_ff_stable)                     \
 490   declare_preprocessor_constant("JVM_ACC_VARARGS", JVM_ACC_VARARGS)       \
 491   declare_preprocessor_constant("JVM_ACC_BRIDGE", JVM_ACC_BRIDGE)         \
 492   declare_preprocessor_constant("JVM_ACC_ANNOTATION", JVM_ACC_ANNOTATION) \
 493   declare_preprocessor_constant("JVM_ACC_ENUM", JVM_ACC_ENUM)             \
 494   declare_preprocessor_constant("JVM_ACC_SYNTHETIC", JVM_ACC_SYNTHETIC)   \
 495   declare_preprocessor_constant("JVM_ACC_INTERFACE", JVM_ACC_INTERFACE)   \
 496                                                                           \
 497   declare_constant(JVM_CONSTANT_Utf8)                                     \
 498   declare_constant(JVM_CONSTANT_Unicode)                                  \
 499   declare_constant(JVM_CONSTANT_Integer)                                  \
 500   declare_constant(JVM_CONSTANT_Float)                                    \
 501   declare_constant(JVM_CONSTANT_Long)                                     \
 502   declare_constant(JVM_CONSTANT_Double)                                   \
 503   declare_constant(JVM_CONSTANT_Class)                                    \
 504   declare_constant(JVM_CONSTANT_String)                                   \
 505   declare_constant(JVM_CONSTANT_Fieldref)                                 \
 506   declare_constant(JVM_CONSTANT_Methodref)                                \
 507   declare_constant(JVM_CONSTANT_InterfaceMethodref)                       \
 508   declare_constant(JVM_CONSTANT_NameAndType)                              \
 509   declare_constant(JVM_CONSTANT_MethodHandle)                             \
 510   declare_constant(JVM_CONSTANT_MethodType)                               \
 511   declare_constant(JVM_CONSTANT_InvokeDynamic)                            \
 512   declare_constant(JVM_CONSTANT_Dynamic)                                  \
 513   declare_constant(JVM_CONSTANT_Module)                                   \
 514   declare_constant(JVM_CONSTANT_Package)                                  \
 515   declare_constant(JVM_CONSTANT_ExternalMax)                              \
 516                                                                           \
 517   declare_constant(JVM_CONSTANT_Invalid)                                  \
 518   declare_constant(JVM_CONSTANT_InternalMin)                              \
 519   declare_constant(JVM_CONSTANT_UnresolvedClass)                          \
 520   declare_constant(JVM_CONSTANT_ClassIndex)                               \
 521   declare_constant(JVM_CONSTANT_StringIndex)                              \
 522   declare_constant(JVM_CONSTANT_UnresolvedClassInError)                   \
 523   declare_constant(JVM_CONSTANT_MethodHandleInError)                      \
 524   declare_constant(JVM_CONSTANT_MethodTypeInError)                        \
 525   declare_constant(JVM_CONSTANT_DynamicInError)                           \
 526   declare_constant(JVM_CONSTANT_InternalMax)                              \
 527                                                                           \
 528   declare_constant(ArrayData::array_len_off_set)                          \
 529   declare_constant(ArrayData::array_start_off_set)                        \
 530                                                                           \
 531   declare_constant(BitData::exception_seen_flag)                          \
 532   declare_constant(BitData::null_seen_flag)                               \
 533   declare_constant(BranchData::not_taken_off_set)                         \
 534                                                                           \
 535   declare_constant_with_value("CardTable::dirty_card", CardTable::dirty_card_val()) \
 536   declare_constant_with_value("LockStack::_end_offset", LockStack::end_offset()) \
 537   declare_constant_with_value("OMCache::oop_to_oop_difference", OMCache::oop_to_oop_difference()) \
 538   declare_constant_with_value("OMCache::oop_to_monitor_difference", OMCache::oop_to_monitor_difference()) \
 539                                                                           \
 540   declare_constant(CodeInstaller::VERIFIED_ENTRY)                         \
 541   declare_constant(CodeInstaller::UNVERIFIED_ENTRY)                       \
 542   declare_constant(CodeInstaller::OSR_ENTRY)                              \
 543   declare_constant(CodeInstaller::EXCEPTION_HANDLER_ENTRY)                \
 544   declare_constant(CodeInstaller::DEOPT_HANDLER_ENTRY)                    \
 545   declare_constant(CodeInstaller::FRAME_COMPLETE)                         \
 546   declare_constant(CodeInstaller::ENTRY_BARRIER_PATCH)                    \
 547   declare_constant(CodeInstaller::INVOKEINTERFACE)                        \
 548   declare_constant(CodeInstaller::INVOKEVIRTUAL)                          \
 549   declare_constant(CodeInstaller::INVOKESTATIC)                           \
 550   declare_constant(CodeInstaller::INVOKESPECIAL)                          \
 551   declare_constant(CodeInstaller::INLINE_INVOKE)                          \
 552   declare_constant(CodeInstaller::POLL_NEAR)                              \
 553   declare_constant(CodeInstaller::POLL_RETURN_NEAR)                       \
 554   declare_constant(CodeInstaller::POLL_FAR)                               \
 555   declare_constant(CodeInstaller::POLL_RETURN_FAR)                        \
 556   declare_constant(CodeInstaller::CARD_TABLE_SHIFT)                       \
 557   declare_constant(CodeInstaller::CARD_TABLE_ADDRESS)                     \
 558   declare_constant(CodeInstaller::HEAP_TOP_ADDRESS)                       \
 559   declare_constant(CodeInstaller::HEAP_END_ADDRESS)                       \
 560   declare_constant(CodeInstaller::NARROW_KLASS_BASE_ADDRESS)              \
 561   declare_constant(CodeInstaller::NARROW_OOP_BASE_ADDRESS)                \
 562   declare_constant(CodeInstaller::CRC_TABLE_ADDRESS)                      \
 563   declare_constant(CodeInstaller::LOG_OF_HEAP_REGION_GRAIN_BYTES)         \
 564   declare_constant(CodeInstaller::INLINE_CONTIGUOUS_ALLOCATION_SUPPORTED) \
 565   declare_constant(CodeInstaller::DEOPT_MH_HANDLER_ENTRY)                 \
 566   declare_constant(CodeInstaller::VERIFY_OOP_COUNT_ADDRESS)               \
 567   declare_constant(CodeInstaller::VERIFY_OOPS)                            \
 568   declare_constant(CodeInstaller::VERIFY_OOP_BITS)                        \
 569   declare_constant(CodeInstaller::VERIFY_OOP_MASK)                        \
 570   declare_constant(CodeInstaller::INVOKE_INVALID)                         \
 571                                                                           \
 572   declare_constant(CodeInstaller::ILLEGAL)                                \
 573   declare_constant(CodeInstaller::REGISTER_PRIMITIVE)                     \
 574   declare_constant(CodeInstaller::REGISTER_OOP)                           \
 575   declare_constant(CodeInstaller::REGISTER_NARROW_OOP)                    \
 576   declare_constant(CodeInstaller::REGISTER_VECTOR)                        \
 577   declare_constant(CodeInstaller::STACK_SLOT_PRIMITIVE)                   \
 578   declare_constant(CodeInstaller::STACK_SLOT_OOP)                         \
 579   declare_constant(CodeInstaller::STACK_SLOT_NARROW_OOP)                  \
 580   declare_constant(CodeInstaller::STACK_SLOT_VECTOR)                      \
 581   declare_constant(CodeInstaller::VIRTUAL_OBJECT_ID)                      \
 582   declare_constant(CodeInstaller::VIRTUAL_OBJECT_ID2)                     \
 583   declare_constant(CodeInstaller::NULL_CONSTANT)                          \
 584   declare_constant(CodeInstaller::RAW_CONSTANT)                           \
 585   declare_constant(CodeInstaller::PRIMITIVE_0)                            \
 586   declare_constant(CodeInstaller::PRIMITIVE4)                             \
 587   declare_constant(CodeInstaller::PRIMITIVE8)                             \
 588   declare_constant(CodeInstaller::JOBJECT)                                \
 589   declare_constant(CodeInstaller::OBJECT_ID)                              \
 590   declare_constant(CodeInstaller::OBJECT_ID2)                             \
 591                                                                           \
 592   declare_constant(CodeInstaller::NO_FINALIZABLE_SUBCLASS)                \
 593   declare_constant(CodeInstaller::CONCRETE_SUBTYPE)                       \
 594   declare_constant(CodeInstaller::LEAF_TYPE)                              \
 595   declare_constant(CodeInstaller::CONCRETE_METHOD)                        \
 596   declare_constant(CodeInstaller::CALLSITE_TARGET_VALUE)                  \
 597                                                                           \
 598   declare_constant(CodeInstaller::PATCH_OBJECT_ID)                        \
 599   declare_constant(CodeInstaller::PATCH_OBJECT_ID2)                       \
 600   declare_constant(CodeInstaller::PATCH_NARROW_OBJECT_ID)                 \
 601   declare_constant(CodeInstaller::PATCH_NARROW_OBJECT_ID2)                \
 602   declare_constant(CodeInstaller::PATCH_JOBJECT)                          \
 603   declare_constant(CodeInstaller::PATCH_NARROW_JOBJECT)                   \
 604   declare_constant(CodeInstaller::PATCH_KLASS)                            \
 605   declare_constant(CodeInstaller::PATCH_NARROW_KLASS)                     \
 606   declare_constant(CodeInstaller::PATCH_METHOD)                           \
 607   declare_constant(CodeInstaller::PATCH_DATA_SECTION_REFERENCE)           \
 608                                                                           \
 609   declare_constant(CodeInstaller::SITE_CALL)                              \
 610   declare_constant(CodeInstaller::SITE_FOREIGN_CALL)                      \
 611   declare_constant(CodeInstaller::SITE_FOREIGN_CALL_NO_DEBUG_INFO)        \
 612   declare_constant(CodeInstaller::SITE_SAFEPOINT)                         \
 613   declare_constant(CodeInstaller::SITE_INFOPOINT)                         \
 614   declare_constant(CodeInstaller::SITE_IMPLICIT_EXCEPTION)                \
 615   declare_constant(CodeInstaller::SITE_IMPLICIT_EXCEPTION_DISPATCH)       \
 616   declare_constant(CodeInstaller::SITE_MARK)                              \
 617   declare_constant(CodeInstaller::SITE_DATA_PATCH)                        \
 618   declare_constant(CodeInstaller::SITE_EXCEPTION_HANDLER)                 \
 619                                                                           \
 620   declare_constant(CodeInstaller::DI_HAS_REFERENCE_MAP)                   \
 621   declare_constant(CodeInstaller::DI_HAS_CALLEE_SAVE_INFO)                \
 622   declare_constant(CodeInstaller::DI_HAS_FRAMES)                          \
 623                                                                           \
 624   declare_constant(CodeInstaller::DIF_HAS_LOCALS)                         \
 625   declare_constant(CodeInstaller::DIF_HAS_STACK)                          \
 626   declare_constant(CodeInstaller::DIF_HAS_LOCKS)                          \
 627   declare_constant(CodeInstaller::DIF_DURING_CALL)                        \
 628   declare_constant(CodeInstaller::DIF_RETHROW_EXCEPTION)                  \
 629                                                                           \
 630   declare_constant(CodeInstaller::HCC_IS_NMETHOD)                         \
 631   declare_constant(CodeInstaller::HCC_HAS_ASSUMPTIONS)                    \
 632   declare_constant(CodeInstaller::HCC_HAS_METHODS)                        \
 633   declare_constant(CodeInstaller::HCC_HAS_DEOPT_RESCUE_SLOT)              \
 634   declare_constant(CodeInstaller::HCC_HAS_COMMENTS)                       \
 635                                                                           \
 636   declare_constant(CodeInstaller::NO_REGISTER)                            \
 637                                                                           \
 638   declare_constant(CollectedHeap::None)                                   \
 639   declare_constant(CollectedHeap::Serial)                                 \
 640   declare_constant(CollectedHeap::Parallel)                               \
 641   declare_constant(CollectedHeap::G1)                                     \
 642   declare_constant(CollectedHeap::Epsilon)                                \
 643   declare_constant(CollectedHeap::Z)                                      \
 644   declare_constant(CollectedHeap::Shenandoah)                             \
 645                                                                           \
 646   declare_constant(vmIntrinsics::FIRST_MH_SIG_POLY)                       \
 647   declare_constant(vmIntrinsics::LAST_MH_SIG_POLY)                        \
 648   declare_constant(vmIntrinsics::_invokeGeneric)                          \
 649   declare_constant(vmIntrinsics::_compiledLambdaForm)                     \
 650                                                                           \
 651   declare_constant(ConstantPool::_has_dynamic_constant)                   \
 652                                                                           \
 653   declare_constant(ConstMethodFlags::_misc_has_linenumber_table)          \
 654   declare_constant(ConstMethodFlags::_misc_has_localvariable_table)       \
 655   declare_constant(ConstMethodFlags::_misc_has_exception_table)           \
 656   declare_constant(ConstMethodFlags::_misc_has_method_annotations)        \
 657   declare_constant(ConstMethodFlags::_misc_has_parameter_annotations)     \
 658   declare_constant(ConstMethodFlags::_misc_caller_sensitive)              \
 659   declare_constant(ConstMethodFlags::_misc_is_hidden)                     \
 660   declare_constant(ConstMethodFlags::_misc_intrinsic_candidate)           \
 661   declare_constant(ConstMethodFlags::_misc_reserved_stack_access)         \
 662   declare_constant(ConstMethodFlags::_misc_changes_current_thread)        \
 663   declare_constant(ConstMethodFlags::_misc_is_scoped)                     \
 664                                                                           \
 665   declare_constant(CounterData::count_off)                                \
 666                                                                           \
 667   declare_constant(DataLayout::cell_size)                                 \
 668   declare_constant(DataLayout::no_tag)                                    \
 669   declare_constant(DataLayout::bit_data_tag)                              \
 670   declare_constant(DataLayout::counter_data_tag)                          \
 671   declare_constant(DataLayout::jump_data_tag)                             \
 672   declare_constant(DataLayout::receiver_type_data_tag)                    \
 673   declare_constant(DataLayout::virtual_call_data_tag)                     \
 674   declare_constant(DataLayout::ret_data_tag)                              \
 675   declare_constant(DataLayout::branch_data_tag)                           \
 676   declare_constant(DataLayout::multi_branch_data_tag)                     \
 677   declare_constant(DataLayout::arg_info_data_tag)                         \
 678   declare_constant(DataLayout::call_type_data_tag)                        \
 679   declare_constant(DataLayout::virtual_call_type_data_tag)                \
 680   declare_constant(DataLayout::parameters_type_data_tag)                  \
 681   declare_constant(DataLayout::speculative_trap_data_tag)                 \
 682                                                                           \
 683   declare_constant(Deoptimization::Unpack_deopt)                          \
 684   declare_constant(Deoptimization::Unpack_exception)                      \
 685   declare_constant(Deoptimization::Unpack_uncommon_trap)                  \
 686   declare_constant(Deoptimization::Unpack_reexecute)                      \
 687                                                                           \
 688   declare_constant(Deoptimization::_action_bits)                          \
 689   declare_constant(Deoptimization::_reason_bits)                          \
 690   declare_constant(Deoptimization::_debug_id_bits)                        \
 691   declare_constant(Deoptimization::_action_shift)                         \
 692   declare_constant(Deoptimization::_reason_shift)                         \
 693   declare_constant(Deoptimization::_debug_id_shift)                       \
 694                                                                           \
 695   declare_constant(Deoptimization::Action_none)                           \
 696   declare_constant(Deoptimization::Action_maybe_recompile)                \
 697   declare_constant(Deoptimization::Action_reinterpret)                    \
 698   declare_constant(Deoptimization::Action_make_not_entrant)               \
 699   declare_constant(Deoptimization::Action_make_not_compilable)            \
 700                                                                           \
 701   declare_constant(Deoptimization::Reason_none)                           \
 702   declare_constant(Deoptimization::Reason_null_check)                     \
 703   declare_constant(Deoptimization::Reason_range_check)                    \
 704   declare_constant(Deoptimization::Reason_class_check)                    \
 705   declare_constant(Deoptimization::Reason_array_check)                    \
 706   declare_constant(Deoptimization::Reason_unreached0)                     \
 707   declare_constant(Deoptimization::Reason_constraint)                     \
 708   declare_constant(Deoptimization::Reason_div0_check)                     \
 709   declare_constant(Deoptimization::Reason_loop_limit_check)               \
 710   declare_constant(Deoptimization::Reason_type_checked_inlining)          \
 711   declare_constant(Deoptimization::Reason_optimized_type_check)           \
 712   declare_constant(Deoptimization::Reason_aliasing)                       \
 713   declare_constant(Deoptimization::Reason_transfer_to_interpreter)        \
 714   declare_constant(Deoptimization::Reason_not_compiled_exception_handler) \
 715   declare_constant(Deoptimization::Reason_unresolved)                     \
 716   declare_constant(Deoptimization::Reason_jsr_mismatch)                   \
 717   declare_constant(Deoptimization::Reason_TRAP_HISTORY_LENGTH)            \
 718   declare_constant(Deoptimization::_support_large_access_byte_array_virtualization) \
 719                                                                           \
 720                                                                           \
 721   declare_constant(InstanceKlass::linked)                                 \
 722   declare_constant(InstanceKlass::being_initialized)                      \
 723   declare_constant(InstanceKlass::fully_initialized)                      \
 724                                                                           \
 725   declare_constant(LockingMode::LM_MONITOR)                               \
 726   declare_constant(LockingMode::LM_LEGACY)                                \
 727   declare_constant(LockingMode::LM_LIGHTWEIGHT)                           \
 728                                                                           \
 729   /*********************************/                                     \
 730   /* InstanceKlass _misc_flags */                                         \
 731   /*********************************/                                     \
 732                                                                           \
 733   declare_constant(InstanceKlassFlags::_misc_has_nonstatic_concrete_methods)   \
 734   declare_constant(InstanceKlassFlags::_misc_declares_nonstatic_concrete_methods) \
 735   declare_constant(KlassFlags::_misc_is_hidden_class)                     \
 736   declare_constant(KlassFlags::_misc_is_value_based_class)                \
 737   declare_constant(KlassFlags::_misc_has_finalizer)                       \
 738   declare_constant(KlassFlags::_misc_is_cloneable_fast)                   \
 739                                                                           \
 740   declare_constant(JumpData::taken_off_set)                               \
 741   declare_constant(JumpData::displacement_off_set)                        \
 742                                                                           \
 743   declare_preprocessor_constant("JVMCI::ok",                      JVMCI::ok)                      \
 744   declare_preprocessor_constant("JVMCI::dependencies_failed",     JVMCI::dependencies_failed)     \
 745   declare_preprocessor_constant("JVMCI::cache_full",              JVMCI::cache_full)              \
 746   declare_preprocessor_constant("JVMCI::code_too_large",          JVMCI::code_too_large)          \
 747   declare_preprocessor_constant("JVMCI::nmethod_reclaimed",       JVMCI::nmethod_reclaimed)       \
 748   declare_preprocessor_constant("JVMCI::first_permanent_bailout", JVMCI::first_permanent_bailout) \
 749                                                                           \
 750   declare_constant(JVMCIRuntime::none)                                    \
 751   declare_constant(JVMCIRuntime::by_holder)                               \
 752   declare_constant(JVMCIRuntime::by_full_signature)                       \
 753                                                                           \
 754   declare_constant(Klass::_lh_neutral_value)                              \
 755   declare_constant(Klass::_lh_instance_slow_path_bit)                     \
 756   declare_constant(Klass::_lh_log2_element_size_shift)                    \
 757   declare_constant(Klass::_lh_log2_element_size_mask)                     \
 758   declare_constant(Klass::_lh_element_type_shift)                         \
 759   declare_constant(Klass::_lh_element_type_mask)                          \
 760   declare_constant(Klass::_lh_header_size_shift)                          \
 761   declare_constant(Klass::_lh_header_size_mask)                           \
 762   declare_constant(Klass::_lh_array_tag_shift)                            \
 763   declare_constant(Klass::_lh_array_tag_type_value)                       \
 764   declare_constant(Klass::_lh_array_tag_obj_value)                        \
 765                                                                           \
 766   declare_constant(markWord::no_hash)                                     \
 767                                                                           \
 768   declare_constant(MethodFlags::_misc_force_inline)                       \
 769   declare_constant(MethodFlags::_misc_dont_inline)                        \
 770                                                                           \
 771   declare_constant(Method::nonvirtual_vtable_index)                       \
 772   declare_constant(Method::invalid_vtable_index)                          \
 773                                                                           \
 774   declare_constant(MultiBranchData::per_case_cell_count)                  \
 775                                                                           \
 776   AARCH64_ONLY(declare_constant(NMethodPatchingType::stw_instruction_and_data_patch))  \
 777   AARCH64_ONLY(declare_constant(NMethodPatchingType::conc_instruction_and_data_patch)) \
 778   AARCH64_ONLY(declare_constant(NMethodPatchingType::conc_data_patch))                 \
 779                                                                           \
 780   declare_constant(ObjectMonitor::ANONYMOUS_OWNER)                        \
 781                                                                           \
 782   declare_constant(ReceiverTypeData::receiver_type_row_cell_count)        \
 783   declare_constant(ReceiverTypeData::receiver0_offset)                    \
 784   declare_constant(ReceiverTypeData::count0_offset)                       \
 785                                                                           \
 786   declare_constant(vmIntrinsics::_invokeBasic)                            \
 787   declare_constant(vmIntrinsics::_linkToVirtual)                          \
 788   declare_constant(vmIntrinsics::_linkToStatic)                           \
 789   declare_constant(vmIntrinsics::_linkToSpecial)                          \
 790   declare_constant(vmIntrinsics::_linkToInterface)                        \
 791   declare_constant(vmIntrinsics::_linkToNative)                           \
 792                                                                           \
 793   declare_constant(vmSymbols::FIRST_SID)                                  \
 794   declare_constant(vmSymbols::SID_LIMIT)                                  \
 795 
 796 #define VM_LONG_CONSTANTS(declare_constant, declare_preprocessor_constant) \
 797   declare_constant(InvocationCounter::count_increment)                    \
 798   declare_constant(InvocationCounter::count_shift)                        \
 799                                                                           \
 800   declare_constant(markWord::hash_shift)                                  \
 801   declare_constant(markWord::monitor_value)                               \
 802                                                                           \
 803   declare_constant(markWord::lock_mask_in_place)                          \
 804   declare_constant(markWord::age_mask_in_place)                           \
 805   declare_constant(markWord::hash_mask)                                   \
 806   declare_constant(markWord::hash_mask_in_place)                          \
 807                                                                           \
 808   declare_constant(markWord::unlocked_value)                              \
 809                                                                           \
 810   declare_constant(markWord::no_hash_in_place)                            \
 811   declare_constant(markWord::no_lock_in_place)                            \
 812 
 813 // Helper macro to support ZGC pattern where the function itself isn't exported
 814 #define DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, name) \
 815   declare_function_with_value(name, name##_addr())
 816 
 817 
 818 #define VM_ADDRESSES(declare_address, declare_preprocessor_address, declare_function, declare_function_with_value) \
 819   declare_function(SharedRuntime::register_finalizer)                     \
 820   declare_function(SharedRuntime::exception_handler_for_return_address)   \
 821   declare_function(SharedRuntime::OSR_migration_end)                      \
 822   declare_function(SharedRuntime::enable_stack_reserved_zone)             \
 823   declare_function(SharedRuntime::frem)                                   \
 824   declare_function(SharedRuntime::drem)                                   \
 825   JVMTI_ONLY(declare_function(SharedRuntime::notify_jvmti_vthread_start)) \
 826   JVMTI_ONLY(declare_function(SharedRuntime::notify_jvmti_vthread_end))   \
 827   JVMTI_ONLY(declare_function(SharedRuntime::notify_jvmti_vthread_mount)) \
 828   JVMTI_ONLY(declare_function(SharedRuntime::notify_jvmti_vthread_unmount)) \
 829                                                                           \
 830   declare_function(os::dll_load)                                          \
 831   declare_function(os::dll_lookup)                                        \
 832   declare_function(os::javaTimeMillis)                                    \
 833   declare_function(os::javaTimeNanos)                                     \
 834                                                                           \
 835   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::load_barrier_on_oop_field_preloaded))                      \
 836   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::load_barrier_on_weak_oop_field_preloaded))                 \
 837   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::load_barrier_on_phantom_oop_field_preloaded))              \
 838   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::weak_load_barrier_on_oop_field_preloaded))                 \
 839   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::weak_load_barrier_on_weak_oop_field_preloaded))            \
 840   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::weak_load_barrier_on_phantom_oop_field_preloaded))         \
 841   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::load_barrier_on_oop_array))                                \
 842   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, XBarrierSetRuntime::clone))                                                    \
 843                                                                                                                       \
 844   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::load_barrier_on_oop_field_preloaded))                      \
 845   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::load_barrier_on_weak_oop_field_preloaded))                 \
 846   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::load_barrier_on_phantom_oop_field_preloaded))              \
 847   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::load_barrier_on_oop_field_preloaded_store_good))           \
 848   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::no_keepalive_load_barrier_on_weak_oop_field_preloaded))    \
 849   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::no_keepalive_load_barrier_on_phantom_oop_field_preloaded)) \
 850   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::store_barrier_on_native_oop_field_without_healing))        \
 851   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::store_barrier_on_oop_field_with_healing))                  \
 852   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::store_barrier_on_oop_field_without_healing))               \
 853   ZGC_ONLY(DECLARE_FUNCTION_FROM_ADDR(declare_function_with_value, ZBarrierSetRuntime::load_barrier_on_oop_array))                                \
 854                                                                           \
 855   declare_function(Deoptimization::fetch_unroll_info)                     \
 856   declare_function(Deoptimization::uncommon_trap)                         \
 857   declare_function(Deoptimization::unpack_frames)                         \
 858                                                                           \
 859   declare_function(JVMCIRuntime::new_instance_or_null)                    \
 860   declare_function(JVMCIRuntime::new_array_or_null)                       \
 861   declare_function(JVMCIRuntime::new_multi_array_or_null)                 \
 862   declare_function(JVMCIRuntime::dynamic_new_array_or_null)               \
 863   declare_function(JVMCIRuntime::dynamic_new_instance_or_null)            \
 864                                                                           \
 865   declare_function(JVMCIRuntime::invoke_static_method_one_arg)            \
 866                                                                           \
 867   declare_function(JVMCIRuntime::vm_message)                              \
 868   declare_function(JVMCIRuntime::identity_hash_code)                      \
 869   declare_function(JVMCIRuntime::exception_handler_for_pc)                \
 870   declare_function(JVMCIRuntime::monitorenter)                            \
 871   declare_function(JVMCIRuntime::monitorexit)                             \
 872   declare_function(JVMCIRuntime::object_notify)                           \
 873   declare_function(JVMCIRuntime::object_notifyAll)                        \
 874   declare_function(JVMCIRuntime::throw_and_post_jvmti_exception)          \
 875   declare_function(JVMCIRuntime::throw_klass_external_name_exception)     \
 876   declare_function(JVMCIRuntime::throw_class_cast_exception)              \
 877   declare_function(JVMCIRuntime::log_primitive)                           \
 878   declare_function(JVMCIRuntime::log_object)                              \
 879   declare_function(JVMCIRuntime::log_printf)                              \
 880   declare_function(JVMCIRuntime::vm_error)                                \
 881   declare_function(JVMCIRuntime::load_and_clear_exception)                \
 882   G1GC_ONLY(declare_function(JVMCIRuntime::write_barrier_pre))            \
 883   G1GC_ONLY(declare_function(JVMCIRuntime::write_barrier_post))           \
 884   declare_function(JVMCIRuntime::validate_object)                         \
 885                                                                           \
 886   declare_function(JVMCIRuntime::test_deoptimize_call_int)
 887 
 888 
 889 #if INCLUDE_G1GC
 890 
 891 #define VM_STRUCTS_JVMCI_G1GC(nonstatic_field, static_field) \
 892   static_field(G1HeapRegion, LogOfHRGrainBytes, uint)
 893 
 894 #define VM_INT_CONSTANTS_JVMCI_G1GC(declare_constant, declare_constant_with_value, declare_preprocessor_constant) \
 895   declare_constant_with_value("G1CardTable::g1_young_gen", G1CardTable::g1_young_card_val()) \
 896   declare_constant_with_value("G1ThreadLocalData::satb_mark_queue_active_offset", in_bytes(G1ThreadLocalData::satb_mark_queue_active_offset())) \
 897   declare_constant_with_value("G1ThreadLocalData::satb_mark_queue_index_offset", in_bytes(G1ThreadLocalData::satb_mark_queue_index_offset())) \
 898   declare_constant_with_value("G1ThreadLocalData::satb_mark_queue_buffer_offset", in_bytes(G1ThreadLocalData::satb_mark_queue_buffer_offset())) \
 899   declare_constant_with_value("G1ThreadLocalData::dirty_card_queue_index_offset", in_bytes(G1ThreadLocalData::dirty_card_queue_index_offset())) \
 900   declare_constant_with_value("G1ThreadLocalData::dirty_card_queue_buffer_offset", in_bytes(G1ThreadLocalData::dirty_card_queue_buffer_offset()))
 901 
 902 #endif // INCLUDE_G1GC
 903 
 904 
 905 #if INCLUDE_ZGC
 906 
 907 #define VM_INT_CONSTANTS_JVMCI_ZGC(declare_constant, declare_constant_with_value, declare_preprocessor_constant)                           \
 908   declare_constant_with_value("ZThreadLocalData::store_good_mask_offset" , in_bytes(ZThreadLocalData::store_good_mask_offset()))           \
 909   declare_constant_with_value("ZThreadLocalData::store_bad_mask_offset" , in_bytes(ZThreadLocalData::store_bad_mask_offset()))             \
 910   declare_constant_with_value("ZThreadLocalData::store_barrier_buffer_offset" , in_bytes(ZThreadLocalData::store_barrier_buffer_offset())) \
 911   declare_constant_with_value("ZStoreBarrierBuffer::current_offset" , in_bytes(ZStoreBarrierBuffer::current_offset()))                     \
 912   declare_constant_with_value("ZStoreBarrierBuffer::buffer_offset" , in_bytes(ZStoreBarrierBuffer::buffer_offset()))                       \
 913   declare_constant_with_value("ZStoreBarrierEntry::p_offset" , in_bytes(ZStoreBarrierEntry::p_offset()))                                   \
 914   declare_constant_with_value("ZStoreBarrierEntry::prev_offset" , in_bytes(ZStoreBarrierEntry::prev_offset()))                             \
 915   AMD64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_LOAD_GOOD_BEFORE_SHL))                                            \
 916   AMD64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_LOAD_BAD_AFTER_TEST))                                             \
 917   AMD64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_MARK_BAD_AFTER_TEST))                                             \
 918   AMD64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_STORE_GOOD_AFTER_CMP))                                            \
 919   AMD64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_STORE_BAD_AFTER_TEST))                                            \
 920   AMD64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_STORE_GOOD_AFTER_OR))                                             \
 921   AMD64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_STORE_GOOD_AFTER_MOV))                                            \
 922   AARCH64_ONLY(declare_constant(ZPointerLoadShift))                                                                                        \
 923   AARCH64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_LOAD_GOOD_BEFORE_TB_X))                                         \
 924   AARCH64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_MARK_BAD_BEFORE_MOV))                                           \
 925   AARCH64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_STORE_GOOD_BEFORE_MOV))                                         \
 926   AARCH64_ONLY(declare_constant(CodeInstaller::Z_BARRIER_RELOCATION_FORMAT_STORE_BAD_BEFORE_MOV))
 927 
 928 #endif // INCLUDE_ZGC
 929 
 930 
 931 #ifdef LINUX
 932 
 933 #define VM_ADDRESSES_OS(declare_address, declare_preprocessor_address, declare_function, declare_function_with_value) \
 934   declare_preprocessor_address("RTLD_DEFAULT", RTLD_DEFAULT)
 935 
 936 #endif
 937 
 938 
 939 #ifdef BSD
 940 
 941 #define VM_ADDRESSES_OS(declare_address, declare_preprocessor_address, declare_function, declare_function_with_value) \
 942   declare_preprocessor_address("RTLD_DEFAULT", RTLD_DEFAULT)
 943 
 944 #endif
 945 
 946 #ifdef AARCH64
 947 
 948 #define VM_STRUCTS_CPU(nonstatic_field, static_field, unchecked_nonstatic_field, volatile_nonstatic_field, nonproduct_nonstatic_field, c2_nonstatic_field, unchecked_c1_static_field, unchecked_c2_static_field) \
 949   static_field(VM_Version, _zva_length, int)                            \
 950   static_field(StubRoutines::aarch64, _count_positives, address)        \
 951   static_field(StubRoutines::aarch64, _count_positives_long, address)   \
 952   static_field(VM_Version, _rop_protection, bool)                       \
 953   volatile_nonstatic_field(JavaFrameAnchor, _last_Java_fp, intptr_t*)
 954 
 955 #define DECLARE_INT_CPU_FEATURE_CONSTANT(id, name, bit) GENERATE_VM_INT_CONSTANT_ENTRY(VM_Version::CPU_##id)
 956 #define VM_INT_CPU_FEATURE_CONSTANTS CPU_FEATURE_FLAGS(DECLARE_INT_CPU_FEATURE_CONSTANT)
 957 
 958 #endif
 959 
 960 #ifdef X86
 961 
 962 #define VM_STRUCTS_CPU(nonstatic_field, static_field, unchecked_nonstatic_field, volatile_nonstatic_field, nonproduct_nonstatic_field, c2_nonstatic_field, unchecked_c1_static_field, unchecked_c2_static_field) \
 963   volatile_nonstatic_field(JavaFrameAnchor, _last_Java_fp, intptr_t*) \
 964   static_field(VM_Version, _has_intel_jcc_erratum, bool)
 965 
 966 #define VM_INT_CONSTANTS_CPU(declare_constant, declare_preprocessor_constant, declare_c1_constant, declare_c2_constant, declare_c2_preprocessor_constant) \
 967   LP64_ONLY(declare_constant(frame::arg_reg_save_area_bytes))       \
 968   declare_constant(frame::interpreter_frame_sender_sp_offset)       \
 969   declare_constant(frame::interpreter_frame_last_sp_offset)
 970 
 971 #define DECLARE_LONG_CPU_FEATURE_CONSTANT(id, name, bit) GENERATE_VM_LONG_CONSTANT_ENTRY(VM_Version::CPU_##id)
 972 #define VM_LONG_CPU_FEATURE_CONSTANTS CPU_FEATURE_FLAGS(DECLARE_LONG_CPU_FEATURE_CONSTANT)
 973 
 974 #endif
 975 
 976 /*
 977  * Dummy defines for architectures that don't use these.
 978  */
 979 #ifndef VM_STRUCTS_CPU
 980 #define VM_STRUCTS_CPU(nonstatic_field, static_field, unchecked_nonstatic_field, volatile_nonstatic_field, nonproduct_nonstatic_field, c2_nonstatic_field, unchecked_c1_static_field, unchecked_c2_static_field)
 981 #endif
 982 
 983 #ifndef VM_INT_CONSTANTS_CPU
 984 #define VM_INT_CONSTANTS_CPU(declare_constant, declare_preprocessor_constant, declare_c1_constant, declare_c2_constant, declare_c2_preprocessor_constant)
 985 #endif
 986 
 987 #ifndef VM_LONG_CONSTANTS_CPU
 988 #define VM_LONG_CONSTANTS_CPU(declare_constant, declare_preprocessor_constant, declare_c1_constant, declare_c2_constant, declare_c2_preprocessor_constant)
 989 #endif
 990 
 991 #ifndef VM_ADDRESSES_OS
 992 #define VM_ADDRESSES_OS(declare_address, declare_preprocessor_address, declare_function, declare_function_with_value)
 993 #endif
 994 
 995 //
 996 // Instantiation of VMStructEntries, VMTypeEntries and VMIntConstantEntries
 997 //
 998 
 999 #define GENERATE_VM_FUNCTION_WITH_VALUE_ENTRY(name, value) \
1000   { QUOTE(name), CAST_FROM_FN_PTR(void*, value) },
1001 
1002 
1003 // These initializers are allowed to access private fields in classes
1004 // as long as class VMStructs is a friend
1005 VMStructEntry JVMCIVMStructs::localHotSpotVMStructs[] = {
1006   VM_STRUCTS(GENERATE_NONSTATIC_VM_STRUCT_ENTRY,
1007              GENERATE_STATIC_VM_STRUCT_ENTRY,
1008              GENERATE_UNCHECKED_NONSTATIC_VM_STRUCT_ENTRY,
1009              GENERATE_NONSTATIC_VM_STRUCT_ENTRY)
1010 
1011   VM_STRUCTS_CPU(GENERATE_NONSTATIC_VM_STRUCT_ENTRY,
1012                  GENERATE_STATIC_VM_STRUCT_ENTRY,
1013                  GENERATE_UNCHECKED_NONSTATIC_VM_STRUCT_ENTRY,
1014                  GENERATE_NONSTATIC_VM_STRUCT_ENTRY,
1015                  GENERATE_NONPRODUCT_NONSTATIC_VM_STRUCT_ENTRY,
1016                  GENERATE_C2_NONSTATIC_VM_STRUCT_ENTRY,
1017                  GENERATE_C1_UNCHECKED_STATIC_VM_STRUCT_ENTRY,
1018                  GENERATE_C2_UNCHECKED_STATIC_VM_STRUCT_ENTRY)
1019 
1020 #if INCLUDE_G1GC
1021   VM_STRUCTS_JVMCI_G1GC(GENERATE_NONSTATIC_VM_STRUCT_ENTRY,
1022                         GENERATE_STATIC_VM_STRUCT_ENTRY)
1023 #endif
1024 
1025   GENERATE_VM_STRUCT_LAST_ENTRY()
1026 };
1027 
1028 VMTypeEntry JVMCIVMStructs::localHotSpotVMTypes[] = {
1029   VM_TYPES(GENERATE_VM_TYPE_ENTRY,
1030            GENERATE_TOPLEVEL_VM_TYPE_ENTRY,
1031            GENERATE_INTEGER_VM_TYPE_ENTRY,
1032            GENERATE_UNSIGNED_INTEGER_VM_TYPE_ENTRY)
1033 
1034   GENERATE_VM_TYPE_LAST_ENTRY()
1035 };
1036 
1037 VMIntConstantEntry JVMCIVMStructs::localHotSpotVMIntConstants[] = {
1038   VM_INT_CONSTANTS(GENERATE_VM_INT_CONSTANT_ENTRY,
1039                    GENERATE_VM_INT_CONSTANT_WITH_VALUE_ENTRY,
1040                    GENERATE_PREPROCESSOR_VM_INT_CONSTANT_ENTRY)
1041 
1042   VM_INT_CONSTANTS_CPU(GENERATE_VM_INT_CONSTANT_ENTRY,
1043                        GENERATE_PREPROCESSOR_VM_INT_CONSTANT_ENTRY,
1044                        GENERATE_C1_VM_INT_CONSTANT_ENTRY,
1045                        GENERATE_C2_VM_INT_CONSTANT_ENTRY,
1046                        GENERATE_C2_PREPROCESSOR_VM_INT_CONSTANT_ENTRY)
1047 
1048 #if INCLUDE_G1GC
1049   VM_INT_CONSTANTS_JVMCI_G1GC(GENERATE_VM_INT_CONSTANT_ENTRY,
1050                               GENERATE_VM_INT_CONSTANT_WITH_VALUE_ENTRY,
1051                               GENERATE_PREPROCESSOR_VM_INT_CONSTANT_ENTRY)
1052 #endif
1053 #if INCLUDE_ZGC
1054   VM_INT_CONSTANTS_JVMCI_ZGC(GENERATE_VM_INT_CONSTANT_ENTRY,
1055                               GENERATE_VM_INT_CONSTANT_WITH_VALUE_ENTRY,
1056                               GENERATE_PREPROCESSOR_VM_INT_CONSTANT_ENTRY)
1057 #endif
1058 #ifdef VM_INT_CPU_FEATURE_CONSTANTS
1059   VM_INT_CPU_FEATURE_CONSTANTS
1060 #endif
1061   GENERATE_VM_INT_CONSTANT_LAST_ENTRY()
1062 };
1063 
1064 VMLongConstantEntry JVMCIVMStructs::localHotSpotVMLongConstants[] = {
1065   VM_LONG_CONSTANTS(GENERATE_VM_LONG_CONSTANT_ENTRY,
1066                     GENERATE_PREPROCESSOR_VM_LONG_CONSTANT_ENTRY)
1067 
1068   VM_LONG_CONSTANTS_CPU(GENERATE_VM_LONG_CONSTANT_ENTRY,
1069                         GENERATE_PREPROCESSOR_VM_LONG_CONSTANT_ENTRY,
1070                         GENERATE_C1_VM_LONG_CONSTANT_ENTRY,
1071                         GENERATE_C2_VM_LONG_CONSTANT_ENTRY,
1072                         GENERATE_C2_PREPROCESSOR_VM_LONG_CONSTANT_ENTRY)
1073 #ifdef VM_LONG_CPU_FEATURE_CONSTANTS
1074   VM_LONG_CPU_FEATURE_CONSTANTS
1075 #endif
1076   GENERATE_VM_LONG_CONSTANT_LAST_ENTRY()
1077 };
1078 #undef DECLARE_CPU_FEATURE_FLAG
1079 
1080 VMAddressEntry JVMCIVMStructs::localHotSpotVMAddresses[] = {
1081   VM_ADDRESSES(GENERATE_VM_ADDRESS_ENTRY,
1082                GENERATE_PREPROCESSOR_VM_ADDRESS_ENTRY,
1083                GENERATE_VM_FUNCTION_ENTRY,
1084                GENERATE_VM_FUNCTION_WITH_VALUE_ENTRY)
1085   VM_ADDRESSES_OS(GENERATE_VM_ADDRESS_ENTRY,
1086                   GENERATE_PREPROCESSOR_VM_ADDRESS_ENTRY,
1087                   GENERATE_VM_FUNCTION_ENTRY,
1088                   GENERATE_VM_FUNCTION_WITH_VALUE_ENTRY)
1089 
1090   GENERATE_VM_ADDRESS_LAST_ENTRY()
1091 };
1092 
1093 int JVMCIVMStructs::localHotSpotVMStructs_count() {
1094   // Ignore sentinel entry at the end
1095   return (sizeof(localHotSpotVMStructs) / sizeof(VMStructEntry)) - 1;
1096 }
1097 int JVMCIVMStructs::localHotSpotVMTypes_count() {
1098   // Ignore sentinel entry at the end
1099   return (sizeof(localHotSpotVMTypes) / sizeof(VMTypeEntry)) - 1;
1100 }
1101 int JVMCIVMStructs::localHotSpotVMIntConstants_count() {
1102   // Ignore sentinel entry at the end
1103   return (sizeof(localHotSpotVMIntConstants) / sizeof(VMIntConstantEntry)) - 1;
1104 }
1105 int JVMCIVMStructs::localHotSpotVMLongConstants_count() {
1106   // Ignore sentinel entry at the end
1107   return (sizeof(localHotSpotVMLongConstants) / sizeof(VMLongConstantEntry)) - 1;
1108 }
1109 int JVMCIVMStructs::localHotSpotVMAddresses_count() {
1110   // Ignore sentinel entry at the end
1111   return (sizeof(localHotSpotVMAddresses) / sizeof(VMAddressEntry)) - 1;
1112 }
1113 
1114 #ifdef ASSERT
1115 // This is used both to check the types of referenced fields and
1116 // to ensure that all of the field types are present.
1117 void JVMCIVMStructs::init() {
1118   VM_STRUCTS(CHECK_NONSTATIC_VM_STRUCT_ENTRY,
1119              CHECK_STATIC_VM_STRUCT_ENTRY,
1120              CHECK_NO_OP,
1121              CHECK_VOLATILE_NONSTATIC_VM_STRUCT_ENTRY);
1122 
1123 
1124   VM_STRUCTS_CPU(CHECK_NONSTATIC_VM_STRUCT_ENTRY,
1125                  CHECK_STATIC_VM_STRUCT_ENTRY,
1126                  CHECK_NO_OP,
1127                  CHECK_VOLATILE_NONSTATIC_VM_STRUCT_ENTRY,
1128                  CHECK_NONPRODUCT_NONSTATIC_VM_STRUCT_ENTRY,
1129                  CHECK_C2_NONSTATIC_VM_STRUCT_ENTRY,
1130                  CHECK_NO_OP,
1131                  CHECK_NO_OP);
1132 
1133 #if INCLUDE_G1GC
1134   VM_STRUCTS_JVMCI_G1GC(CHECK_NONSTATIC_VM_STRUCT_ENTRY,
1135                         CHECK_STATIC_VM_STRUCT_ENTRY)
1136 #endif
1137 
1138   VM_TYPES(CHECK_VM_TYPE_ENTRY,
1139            CHECK_SINGLE_ARG_VM_TYPE_NO_OP,
1140            CHECK_SINGLE_ARG_VM_TYPE_NO_OP,
1141            CHECK_SINGLE_ARG_VM_TYPE_NO_OP);
1142 }
1143 
1144 void jvmci_vmStructs_init() {
1145   JVMCIVMStructs::init();
1146 }
1147 #endif // ASSERT