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