1 /*
  2  * Copyright (c) 1997, 2025, Oracle and/or its affiliates. All rights reserved.
  3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  4  *
  5  * This code is free software; you can redistribute it and/or modify it
  6  * under the terms of the GNU General Public License version 2 only, as
  7  * published by the Free Software Foundation.
  8  *
  9  * This code is distributed in the hope that it will be useful, but WITHOUT
 10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 12  * version 2 for more details (a copy is included in the LICENSE file that
 13  * accompanied this code).
 14  *
 15  * You should have received a copy of the GNU General Public License version
 16  * 2 along with this work; if not, write to the Free Software Foundation,
 17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 18  *
 19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 20  * or visit www.oracle.com if you need additional information or have any
 21  * questions.
 22  *
 23  */
 24 
 25 #ifndef SHARE_MEMORY_UNIVERSE_HPP
 26 #define SHARE_MEMORY_UNIVERSE_HPP
 27 
 28 #include "gc/shared/verifyOption.hpp"
 29 #include "memory/reservedSpace.hpp"
 30 #include "oops/array.hpp"
 31 #include "oops/oopHandle.hpp"
 32 #include "runtime/handles.hpp"
 33 #include "utilities/growableArray.hpp"
 34 
 35 // Universe is a name space holding known system classes and objects in the VM.
 36 //
 37 // Loaded classes are accessible through the SystemDictionary.
 38 //
 39 // The object heap is allocated and accessed through Universe, and various allocation
 40 // support is provided. Allocation by the interpreter and compiled code is done inline
 41 // and bails out to Scavenge::invoke_and_allocate.
 42 
 43 class CollectedHeap;
 44 class DeferredObjAllocEvent;
 45 class OopStorage;
 46 class SerializeClosure;
 47 
 48 class Universe: AllStatic {
 49   // Ugh.  Universe is much too friendly.
 50   friend class SerialFullGC;
 51   friend class oopDesc;
 52   friend class ClassLoader;
 53   friend class SystemDictionary;
 54   friend class VMStructs;
 55   friend class VM_PopulateDumpSharedSpace;
 56   friend class Metaspace;
 57   friend class AOTMetaspace;
 58   friend class vmClasses;
 59 
 60   friend jint  universe_init();
 61   friend void  universe2_init();
 62   friend bool  universe_post_init();
 63   friend void  universe_post_module_init();
 64 
 65  private:
 66   // Known classes in the VM
 67   static TypeArrayKlass* _typeArrayKlasses[T_LONG+1];
 68   static ObjArrayKlass* _objectArrayKlass;
 69   // Special int-Array that represents filler objects that are used by GC to overwrite
 70   // dead objects. References to them are generally an error.
 71   static Klass* _fillerArrayKlass;
 72 
 73   // Known objects in the VM
 74   static OopHandle    _main_thread_group;             // Reference to the main thread group object
 75   static OopHandle    _system_thread_group;           // Reference to the system thread group object
 76 
 77   static OopHandle    _the_empty_class_array;         // Canonicalized obj array of type java.lang.Class
 78   static OopHandle    _the_null_string;               // A cache of "null" as a Java string
 79   static OopHandle    _the_min_jint_string;           // A cache of "-2147483648" as a Java string
 80 
 81   static OopHandle    _the_null_sentinel;             // A unique object pointer unused except as a sentinel for null.
 82 
 83   // preallocated error objects (no backtrace)
 84   static OopHandle    _out_of_memory_errors;
 85   static OopHandle    _class_init_stack_overflow_error;
 86 
 87   // preallocated cause message for delayed StackOverflowError
 88   static OopHandle    _delayed_stack_overflow_error_message;
 89 
 90   static Array<int>*            _the_empty_int_array;            // Canonicalized int array
 91   static Array<u2>*             _the_empty_short_array;          // Canonicalized short array
 92   static Array<Klass*>*         _the_empty_klass_array;          // Canonicalized klass array
 93   static Array<InstanceKlass*>* _the_empty_instance_klass_array; // Canonicalized instance klass array
 94   static Array<Method*>*        _the_empty_method_array;         // Canonicalized method array
 95 
 96   static Array<Klass*>*  _the_array_interfaces_array;
 97 
 98   static uintx _the_array_interfaces_bitmap;
 99   static uintx _the_empty_klass_bitmap;
100 
101   // array of preallocated error objects with backtrace
102   static OopHandle     _preallocated_out_of_memory_error_array;
103 
104   // number of preallocated error objects available for use
105   static volatile jint _preallocated_out_of_memory_error_avail_count;
106 
107   // preallocated message detail strings for error objects
108   static OopHandle _msg_metaspace;
109   static OopHandle _msg_class_metaspace;
110 
111   // References waiting to be transferred to the ReferenceHandler
112   static OopHandle    _reference_pending_list;
113 
114   // The particular choice of collected heap.
115   static CollectedHeap* _collectedHeap;
116 
117   static intptr_t _non_oop_bits;
118 
119   // array of dummy objects used with +FullGCAlot
120   DEBUG_ONLY(static OopHandle   _fullgc_alot_dummy_array;)
121   DEBUG_ONLY(static int         _fullgc_alot_dummy_next;)
122 
123   // Compiler/dispatch support
124   static int  _base_vtable_size;                      // Java vtbl size of klass Object (in words)
125 
126   // Initialization
127   static bool _bootstrapping;                         // true during genesis
128   static bool _module_initialized;                    // true after call_initPhase2 called
129   static bool _fully_initialized;                     // true after universe_init and initialize_vtables called
130 
131   // the array of preallocated errors with backtraces
132   static objArrayOop  preallocated_out_of_memory_errors();
133 
134   static objArrayOop out_of_memory_errors();
135   // generate an out of memory error; if possible using an error with preallocated backtrace;
136   // otherwise return the given default error.
137   static oop        gen_out_of_memory_error(oop default_err);
138 
139   static OopStorage* _vm_weak;
140   static OopStorage* _vm_global;
141 
142   static jint initialize_heap();
143   static void initialize_tlab();
144   static void initialize_basic_type_mirrors(TRAPS);
145   static void fixup_mirrors(TRAPS);
146 
147   static void compute_base_vtable_size();             // compute vtable size of class Object
148 
149   static void genesis(TRAPS);                         // Create the initial world
150 
151   // Mirrors for primitive classes (created eagerly)
152   static oop check_mirror(oop m) {
153     assert(m != nullptr, "mirror not initialized");
154     return m;
155   }
156 
157   // Debugging
158   static int _verify_count;                           // number of verifies done
159   static long verify_flags;
160 
161   static uintptr_t _verify_oop_mask;
162   static uintptr_t _verify_oop_bits;
163 
164   // Table of primitive type mirrors, excluding T_OBJECT and T_ARRAY
165   // but including T_VOID, hence the index including T_VOID
166   static OopHandle _basic_type_mirrors[T_VOID+1];
167 
168 #if INCLUDE_CDS_JAVA_HEAP
169   // Each slot i stores an index that can be used to restore _basic_type_mirrors[i]
170   // from the archive heap using HeapShared::get_root(int)
171   static int _archived_basic_type_mirror_indices[T_VOID+1];
172 #endif
173 
174  public:
175   static void calculate_verify_data(HeapWord* low_boundary, HeapWord* high_boundary) PRODUCT_RETURN;
176   static void set_verify_data(uintptr_t mask, uintptr_t bits) PRODUCT_RETURN;
177 
178   // Known classes in the VM
179   static TypeArrayKlass* boolArrayKlass()        { return typeArrayKlass(T_BOOLEAN); }
180   static TypeArrayKlass* byteArrayKlass()        { return typeArrayKlass(T_BYTE); }
181   static TypeArrayKlass* charArrayKlass()        { return typeArrayKlass(T_CHAR); }
182   static TypeArrayKlass* intArrayKlass()         { return typeArrayKlass(T_INT); }
183   static TypeArrayKlass* shortArrayKlass()       { return typeArrayKlass(T_SHORT); }
184   static TypeArrayKlass* longArrayKlass()        { return typeArrayKlass(T_LONG); }
185   static TypeArrayKlass* floatArrayKlass()       { return typeArrayKlass(T_FLOAT); }
186   static TypeArrayKlass* doubleArrayKlass()      { return typeArrayKlass(T_DOUBLE); }
187 
188   static ObjArrayKlass* objectArrayKlass() {
189     ObjArrayKlass* k = _objectArrayKlass;
190     assert(k != nullptr, "Object array klass should be initialized; too early?");
191     return k;
192   }
193 
194   static Klass* fillerArrayKlass() {
195     Klass* k = _fillerArrayKlass;
196     assert(k != nullptr, "Filler array class should be initialized; too early?");
197     return k;
198   }
199 
200   static TypeArrayKlass* typeArrayKlass(BasicType t) {
201     assert((uint)t >= T_BOOLEAN, "range check for type: %s", type2name(t));
202     assert((uint)t < T_LONG+1,   "range check for type: %s", type2name(t));
203     TypeArrayKlass* k = _typeArrayKlasses[t];
204     assert(k != nullptr, "Type array class should be initialized; too early?");
205     return k;
206   }
207 
208   // Known objects in the VM
209   static oop int_mirror();
210   static oop float_mirror();
211   static oop double_mirror();
212   static oop byte_mirror();
213   static oop bool_mirror();
214   static oop char_mirror();
215   static oop long_mirror();
216   static oop short_mirror();
217   static oop void_mirror();
218 
219   static oop java_mirror(BasicType t);
220 
221   static void load_archived_object_instances() NOT_CDS_JAVA_HEAP_RETURN;
222 #if INCLUDE_CDS_JAVA_HEAP
223   static void set_archived_basic_type_mirror_index(BasicType t, int index);
224   static void archive_exception_instances();
225 #endif
226 
227   static oop      main_thread_group();
228   static void set_main_thread_group(oop group);
229 
230   static oop      system_thread_group();
231   static void set_system_thread_group(oop group);
232 
233   static objArrayOop  the_empty_class_array ();
234 
235   static oop          the_null_string();
236   static oop          the_min_jint_string();
237 
238   static oop          null_ptr_exception_instance();
239   static oop          arithmetic_exception_instance();
240   static oop          internal_error_instance();
241   static oop          array_index_out_of_bounds_exception_instance();
242   static oop          array_store_exception_instance();
243   static oop          class_cast_exception_instance();
244   static oop          vm_exception()                  { return internal_error_instance(); }
245 
246   static Array<Klass*>* the_array_interfaces_array()  { return _the_array_interfaces_array; }
247   static uintx        the_array_interfaces_bitmap()   { return _the_array_interfaces_bitmap; }
248 
249   static Method*      finalizer_register_method();
250   static Method*      loader_addClass_method();
251   static Method*      throw_illegal_access_error();
252   static Method*      throw_no_such_method_error();
253   static Method*      do_stack_walk_method();
254 
255   static oop          the_null_sentinel();
256   static address      the_null_sentinel_addr()        { return (address) &_the_null_sentinel;  }
257 
258   // Function to initialize these
259   static void initialize_known_methods(JavaThread* current);
260 
261   static void create_preallocated_out_of_memory_errors(TRAPS);
262 
263   // Reference pending list manipulation.  Access is protected by
264   // Heap_lock.  The getter, setter and predicate require the caller
265   // owns the lock.  Swap is used by parallel non-concurrent reference
266   // processing threads, where some higher level controller owns
267   // Heap_lock, so requires the lock is locked, but not necessarily by
268   // the current thread.
269   static oop          reference_pending_list();
270   static void         clear_reference_pending_list();
271   static bool         has_reference_pending_list();
272   static oop          swap_reference_pending_list(oop list);
273 
274   static Array<int>*             the_empty_int_array()    { return _the_empty_int_array; }
275   static Array<u2>*              the_empty_short_array()  { return _the_empty_short_array; }
276   static Array<Method*>*         the_empty_method_array() { return _the_empty_method_array; }
277   static Array<Klass*>*          the_empty_klass_array()  { return _the_empty_klass_array; }
278   static Array<InstanceKlass*>*  the_empty_instance_klass_array() { return _the_empty_instance_klass_array; }
279 
280   static uintx                   the_empty_klass_bitmap() { return _the_empty_klass_bitmap; }
281 
282   // OutOfMemoryError support. Returns an error with the required message. The returned error
283   // may or may not have a backtrace. If error has a backtrace then the stack trace is already
284   // filled in.
285   static oop out_of_memory_error_java_heap();
286   static oop out_of_memory_error_java_heap_without_backtrace();
287   static oop out_of_memory_error_c_heap();
288   static oop out_of_memory_error_metaspace();
289   static oop out_of_memory_error_class_metaspace();
290   static oop out_of_memory_error_array_size();
291   static oop out_of_memory_error_gc_overhead_limit();
292   static oop out_of_memory_error_realloc_objects();
293 
294   static oop delayed_stack_overflow_error_message();
295 
296   // Saved StackOverflowError and OutOfMemoryError for use when
297   // class initialization can't create ExceptionInInitializerError.
298   static oop class_init_stack_overflow_error();
299   static oop class_init_out_of_memory_error();
300 
301   // If it's a certain type of OOME object
302   static bool is_out_of_memory_error_metaspace(oop ex_obj);
303   static bool is_out_of_memory_error_class_metaspace(oop ex_obj);
304 
305   // The particular choice of collected heap.
306   static CollectedHeap* heap() { return _collectedHeap; }
307 
308   static void before_exit();
309 
310   DEBUG_ONLY(static bool is_stw_gc_active();)
311   DEBUG_ONLY(static bool is_in_heap(const void* p);)
312   DEBUG_ONLY(static bool is_in_heap_or_null(const void* p) { return p == nullptr || is_in_heap(p); })
313 
314   // Reserve Java heap and determine CompressedOops mode
315   static ReservedHeapSpace reserve_heap(size_t heap_size, size_t alignment);
316 
317   // Global OopStorages
318   static OopStorage* vm_weak();
319   static OopStorage* vm_global();
320   static void oopstorage_init();
321 
322   // Testers
323   static bool is_bootstrapping()                      { return _bootstrapping; }
324   static bool is_module_initialized()                 { return _module_initialized; }
325   static bool is_fully_initialized()                  { return _fully_initialized; }
326 
327   static bool        on_page_boundary(void* addr);
328   static bool        should_fill_in_stack_trace(Handle throwable);
329   static void check_alignment(uintx size, uintx alignment, const char* name);
330 
331   // CDS support
332   static void serialize(SerializeClosure* f);
333 
334   // Apply the closure to all klasses for basic types (classes not present in
335   // SystemDictionary).
336   static void basic_type_classes_do(KlassClosure* closure);
337   static void metaspace_pointers_do(MetaspaceClosure* it);
338 
339   // Debugging
340   enum VERIFY_FLAGS {
341     Verify_Threads = 1,
342     Verify_Heap = 2,
343     Verify_SymbolTable = 4,
344     Verify_StringTable = 8,
345     Verify_CodeCache = 16,
346     Verify_SystemDictionary = 32,
347     Verify_ClassLoaderDataGraph = 64,
348     Verify_MetaspaceUtils = 128,
349     Verify_JNIHandles = 256,
350     Verify_CodeCacheOops = 512,
351     Verify_ResolvedMethodTable = 1024,
352     Verify_StringDedup = 2048,
353     Verify_All = -1
354   };
355   static void initialize_verify_flags();
356   static bool should_verify_subset(uint subset);
357   static void verify(VerifyOption option, const char* prefix);
358   static void verify(const char* prefix) {
359     verify(VerifyOption::Default, prefix);
360   }
361   static void verify() {
362     verify("");
363   }
364 
365   static int  verify_count()       { return _verify_count; }
366   static void print_on(outputStream* st);
367   static void print_heap_at_SIGBREAK();
368 
369   // Change the number of dummy objects kept reachable by the full gc dummy
370   // array; this should trigger relocation in a sliding compaction collector.
371   DEBUG_ONLY(static bool release_fullgc_alot_dummy();)
372   // The non-oop pattern (see compiledIC.hpp, etc)
373   static void*         non_oop_word();
374   static bool contains_non_oop_word(void* p);
375 
376   // Oop verification (see MacroAssembler::verify_oop)
377   static uintptr_t verify_oop_mask()          PRODUCT_RETURN0;
378   static uintptr_t verify_oop_bits()          PRODUCT_RETURN0;
379   static uintptr_t verify_mark_bits()         PRODUCT_RETURN0;
380   static uintptr_t verify_mark_mask()         PRODUCT_RETURN0;
381 
382   // Compiler support
383   static int base_vtable_size()               { return _base_vtable_size; }
384 };
385 
386 #endif // SHARE_MEMORY_UNIVERSE_HPP