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