1 /* 2 * Copyright (c) 2023, 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_CDS_AOTCACHEACCESS_HPP 26 #define SHARE_CDS_AOTCACHEACCESS_HPP 27 28 #include "cds/archiveBuilder.hpp" 29 #include "cds/archiveUtils.hpp" 30 #include "memory/allStatic.hpp" 31 #include "oops/oopsHierarchy.hpp" 32 #include "utilities/globalDefinitions.hpp" 33 34 class InstanceKlass; 35 class Klass; 36 class Method; 37 class ReservedSpace; 38 39 class AOTCacheAccess : AllStatic { 40 private: 41 static bool can_generate_aot_code(address addr) NOT_CDS_RETURN_(false); 42 public: 43 static bool can_generate_aot_code(Method* m) { 44 return can_generate_aot_code((address)m); 45 } 46 static bool can_generate_aot_code(Klass* k) { 47 assert(!k->is_instance_klass(), "other method should be called"); 48 return can_generate_aot_code((address)k); 49 } 50 static bool can_generate_aot_code_for(InstanceKlass* ik) NOT_CDS_RETURN_(false); 51 52 /* 53 * Used during an assembly run to compute the offset of the metadata object in the AOT Cache. 54 * The input argument is the "source" address of a metadata object (Method/Klass) loaded by the assembly JVM. 55 * Computation of the offset requires mapping the supplied metadata object to its "requested" address 56 * and subtracting that address from the requested base address. 57 * See ArchiveBuilder.hpp for definition of "source" and "requested" address. 58 */ 59 static uint delta_from_base_address(address addr); 60 61 /* 62 * Used during a production run to materialize a pointer to a Klass located in a loaded AOT Cache. 63 * The offset argument identifies a delta from the AOT Cache's currently mapped base address to the start of the Klass object. 64 * The offset is normally obtained by reading a value embedded in some other AOT-ed entry, like an AOT compiled code. 65 */ 66 static Klass* convert_offset_to_klass(uint offset_from_base_addr) { 67 Metadata* metadata = (Metadata*)((address)SharedBaseAddress + offset_from_base_addr); 68 assert(metadata->is_klass(), "sanity check"); 69 return (Klass*)metadata; 70 } 71 72 /* 73 * Used during a production run to materialize a pointer to a Method located in a loaded AOT Cache. 74 * The offset argument identifies a delta from the AOT Cache's currently mapped base address to the start of the Method object. 75 * The offset is normally obtained by reading a value embedded in some other AOT-ed entry, like an AOT compiled code. 76 */ 77 static Method* convert_offset_to_method(uint offset_from_base_addr) { 78 Metadata* metadata = (Metadata*)((address)SharedBaseAddress + offset_from_base_addr); 79 assert(metadata->is_method(), "sanity check"); 80 return (Method*)metadata; 81 } 82 83 static int get_archived_object_permanent_index(oop obj) NOT_CDS_JAVA_HEAP_RETURN_(-1); 84 static oop get_archived_object(int permanent_index) NOT_CDS_JAVA_HEAP_RETURN_(nullptr); 85 86 static void test_heap_access_api() NOT_CDS_JAVA_HEAP_RETURN; 87 88 static void* allocate_aot_code_region(size_t size) NOT_CDS_RETURN_(nullptr); 89 90 static size_t get_aot_code_region_size() NOT_CDS_RETURN_(0); 91 static void set_aot_code_region_size(size_t sz) NOT_CDS_RETURN; 92 93 static bool map_aot_code_region(ReservedSpace rs) NOT_CDS_RETURN_(false); 94 95 static bool is_aot_code_region_empty() NOT_CDS_RETURN_(true); 96 97 template <typename T> 98 static void set_pointer(T** ptr, T* value) { 99 set_pointer((address*)ptr, (address)value); 100 } 101 static void set_pointer(address* ptr, address value); 102 }; 103 104 #endif // SHARE_CDS_AOTCACHEACCESS_HPP