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 "cds/aotArtifactFinder.hpp"
26 #include "cds/aotClassLinker.hpp"
27 #include "cds/aotLogging.hpp"
28 #include "cds/aotMapLogger.hpp"
29 #include "cds/aotMetaspace.hpp"
30 #include "cds/archiveBuilder.hpp"
31 #include "cds/archiveUtils.hpp"
32 #include "cds/cdsConfig.hpp"
33 #include "cds/cppVtables.hpp"
34 #include "cds/dumpAllocStats.hpp"
35 #include "cds/dynamicArchive.hpp"
36 #include "cds/heapShared.hpp"
37 #include "cds/regeneratedClasses.hpp"
38 #include "classfile/classLoader.hpp"
39 #include "classfile/classLoaderDataShared.hpp"
40 #include "classfile/javaClasses.hpp"
41 #include "classfile/symbolTable.hpp"
42 #include "classfile/systemDictionaryShared.hpp"
43 #include "classfile/vmClasses.hpp"
44 #include "code/aotCodeCache.hpp"
45 #include "interpreter/abstractInterpreter.hpp"
46 #include "jvm.h"
47 #include "logging/log.hpp"
48 #include "memory/allStatic.hpp"
49 #include "memory/memoryReserver.hpp"
50 #include "memory/memRegion.hpp"
51 #include "memory/resourceArea.hpp"
52 #include "oops/compressedKlass.inline.hpp"
53 #include "oops/instanceKlass.hpp"
54 #include "oops/methodCounters.hpp"
55 #include "oops/methodData.hpp"
56 #include "oops/objArrayKlass.hpp"
57 #include "oops/objArrayOop.inline.hpp"
58 #include "oops/oopHandle.inline.hpp"
59 #include "oops/trainingData.hpp"
60 #include "runtime/arguments.hpp"
61 #include "runtime/globals_extension.hpp"
62 #include "runtime/javaThread.hpp"
63 #include "runtime/sharedRuntime.hpp"
64 #include "utilities/align.hpp"
65 #include "utilities/bitMap.inline.hpp"
66 #include "utilities/formatBuffer.hpp"
67
68 ArchiveBuilder* ArchiveBuilder::_current = nullptr;
69
70 ArchiveBuilder::OtherROAllocMark::~OtherROAllocMark() {
71 char* newtop = ArchiveBuilder::current()->_ro_region.top();
72 ArchiveBuilder::alloc_stats()->record_other_type(int(newtop - _oldtop), true);
73 }
74
75 ArchiveBuilder::SourceObjList::SourceObjList() : _ptrmap(16 * K, mtClassShared) {
76 _total_bytes = 0;
77 _objs = new (mtClassShared) GrowableArray<SourceObjInfo*>(128 * K, mtClassShared);
78 }
79
80 ArchiveBuilder::SourceObjList::~SourceObjList() {
81 delete _objs;
82 }
165 _ptrmap.iterate(&relocator, start, end);
166 }
167
168 ArchiveBuilder::ArchiveBuilder() :
169 _current_dump_region(nullptr),
170 _buffer_bottom(nullptr),
171 _requested_static_archive_bottom(nullptr),
172 _requested_static_archive_top(nullptr),
173 _requested_dynamic_archive_bottom(nullptr),
174 _requested_dynamic_archive_top(nullptr),
175 _mapped_static_archive_bottom(nullptr),
176 _mapped_static_archive_top(nullptr),
177 _buffer_to_requested_delta(0),
178 _pz_region("pz", MAX_SHARED_DELTA), // protection zone -- used only during dumping; does NOT exist in cds archive.
179 _rw_region("rw", MAX_SHARED_DELTA),
180 _ro_region("ro", MAX_SHARED_DELTA),
181 _ac_region("ac", MAX_SHARED_DELTA),
182 _ptrmap(mtClassShared),
183 _rw_ptrmap(mtClassShared),
184 _ro_ptrmap(mtClassShared),
185 _rw_src_objs(),
186 _ro_src_objs(),
187 _src_obj_table(INITIAL_TABLE_SIZE, MAX_TABLE_SIZE),
188 _buffered_to_src_table(INITIAL_TABLE_SIZE, MAX_TABLE_SIZE),
189 _total_heap_region_size(0)
190 {
191 _klasses = new (mtClassShared) GrowableArray<Klass*>(4 * K, mtClassShared);
192 _symbols = new (mtClassShared) GrowableArray<Symbol*>(256 * K, mtClassShared);
193 _entropy_seed = 0x12345678;
194 _relocated_ptr_info._num_ptrs = 0;
195 _relocated_ptr_info._num_tagged_ptrs = 0;
196 _relocated_ptr_info._num_nulled_ptrs = 0;
197 assert(_current == nullptr, "must be");
198 _current = this;
199 }
200
201 ArchiveBuilder::~ArchiveBuilder() {
202 assert(_current == this, "must be");
203 _current = nullptr;
204
1167 patcher.doit();
1168 }
1169 }
1170
1171 void ArchiveBuilder::print_stats() {
1172 _alloc_stats.print_stats(int(_ro_region.used()), int(_rw_region.used()));
1173 }
1174
1175 void ArchiveBuilder::write_archive(FileMapInfo* mapinfo, ArchiveMappedHeapInfo* mapped_heap_info, ArchiveStreamedHeapInfo* streamed_heap_info) {
1176 // Make sure NUM_CDS_REGIONS (exported in cds.h) agrees with
1177 // AOTMetaspace::n_regions (internal to hotspot).
1178 assert(NUM_CDS_REGIONS == AOTMetaspace::n_regions, "sanity");
1179
1180 ResourceMark rm;
1181
1182 write_region(mapinfo, AOTMetaspace::rw, &_rw_region, /*read_only=*/false,/*allow_exec=*/false);
1183 write_region(mapinfo, AOTMetaspace::ro, &_ro_region, /*read_only=*/true, /*allow_exec=*/false);
1184 write_region(mapinfo, AOTMetaspace::ac, &_ac_region, /*read_only=*/false,/*allow_exec=*/false);
1185
1186 // Split pointer map into read-write and read-only bitmaps
1187 ArchivePtrMarker::initialize_rw_ro_maps(&_rw_ptrmap, &_ro_ptrmap);
1188
1189 size_t bitmap_size_in_bytes;
1190 char* bitmap = mapinfo->write_bitmap_region(ArchivePtrMarker::rw_ptrmap(),
1191 ArchivePtrMarker::ro_ptrmap(),
1192 mapped_heap_info,
1193 streamed_heap_info,
1194 bitmap_size_in_bytes);
1195
1196 if (mapped_heap_info != nullptr && mapped_heap_info->is_used()) {
1197 _total_heap_region_size = mapinfo->write_mapped_heap_region(mapped_heap_info);
1198 } else if (streamed_heap_info != nullptr && streamed_heap_info->is_used()) {
1199 _total_heap_region_size = mapinfo->write_streamed_heap_region(streamed_heap_info);
1200 }
1201
1202 print_region_stats(mapinfo, mapped_heap_info, streamed_heap_info);
1203
1204 mapinfo->set_requested_base((char*)AOTMetaspace::requested_base_address());
1205 mapinfo->set_header_crc(mapinfo->compute_header_crc());
1206 // After this point, we should not write any data into mapinfo->header() since this
1207 // would corrupt its checksum we have calculated before.
1208 mapinfo->write_header();
1209 mapinfo->close();
1210
1211 if (log_is_enabled(Info, aot)) {
1212 log_info(aot)("Full module graph = %s", CDSConfig::is_dumping_full_module_graph() ? "enabled" : "disabled");
1213 print_stats();
1214 }
1215
1216 if (log_is_enabled(Info, aot, map)) {
1217 AOTMapLogger::dumptime_log(this, mapinfo, mapped_heap_info, streamed_heap_info, bitmap, bitmap_size_in_bytes);
1218 }
1219 CDS_JAVA_HEAP_ONLY(HeapShared::destroy_archived_object_cache());
1220 FREE_C_HEAP_ARRAY(char, bitmap);
1221 }
1222
1223 void ArchiveBuilder::write_region(FileMapInfo* mapinfo, int region_idx, DumpRegion* dump_region, bool read_only, bool allow_exec) {
1224 mapinfo->write_region(region_idx, dump_region->base(), dump_region->used(), read_only, allow_exec);
1225 }
1226
1227 void ArchiveBuilder::count_relocated_pointer(bool tagged, bool nulled) {
1228 _relocated_ptr_info._num_ptrs ++;
1229 _relocated_ptr_info._num_tagged_ptrs += tagged ? 1 : 0;
1230 _relocated_ptr_info._num_nulled_ptrs += nulled ? 1 : 0;
1231 }
1232
|
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 "cds/aotArtifactFinder.hpp"
26 #include "cds/aotClassLinker.hpp"
27 #include "cds/aotLogging.hpp"
28 #include "cds/aotMapLogger.hpp"
29 #include "cds/aotMetaspace.hpp"
30 #include "cds/archiveBuilder.hpp"
31 #include "cds/archiveUtils.hpp"
32 #include "cds/cdsConfig.hpp"
33 #include "cds/cppVtables.hpp"
34 #include "cds/dumpAllocStats.hpp"
35 #include "cds/dynamicArchive.hpp"
36 #include "cds/finalImageRecipes.hpp"
37 #include "cds/heapShared.hpp"
38 #include "cds/regeneratedClasses.hpp"
39 #include "classfile/classLoader.hpp"
40 #include "classfile/classLoaderDataShared.hpp"
41 #include "classfile/javaClasses.hpp"
42 #include "classfile/symbolTable.hpp"
43 #include "classfile/systemDictionaryShared.hpp"
44 #include "classfile/vmClasses.hpp"
45 #include "code/aotCodeCache.hpp"
46 #include "interpreter/abstractInterpreter.hpp"
47 #include "jvm.h"
48 #include "logging/log.hpp"
49 #include "memory/allStatic.hpp"
50 #include "memory/memoryReserver.hpp"
51 #include "memory/memRegion.hpp"
52 #include "memory/resourceArea.hpp"
53 #include "oops/compressedKlass.inline.hpp"
54 #include "oops/instanceKlass.hpp"
55 #include "oops/methodCounters.hpp"
56 #include "oops/methodData.hpp"
57 #include "oops/objArrayKlass.hpp"
58 #include "oops/objArrayOop.inline.hpp"
59 #include "oops/oopHandle.inline.hpp"
60 #include "oops/trainingData.hpp"
61 #include "runtime/arguments.hpp"
62 #include "runtime/globals_extension.hpp"
63 #include "runtime/javaThread.hpp"
64 #include "runtime/safepointVerifiers.hpp"
65 #include "runtime/sharedRuntime.hpp"
66 #include "utilities/align.hpp"
67 #include "utilities/bitMap.inline.hpp"
68 #include "utilities/formatBuffer.hpp"
69
70 ArchiveBuilder* ArchiveBuilder::_current = nullptr;
71
72 ArchiveBuilder::OtherROAllocMark::~OtherROAllocMark() {
73 char* newtop = ArchiveBuilder::current()->_ro_region.top();
74 ArchiveBuilder::alloc_stats()->record_other_type(int(newtop - _oldtop), true);
75 }
76
77 ArchiveBuilder::SourceObjList::SourceObjList() : _ptrmap(16 * K, mtClassShared) {
78 _total_bytes = 0;
79 _objs = new (mtClassShared) GrowableArray<SourceObjInfo*>(128 * K, mtClassShared);
80 }
81
82 ArchiveBuilder::SourceObjList::~SourceObjList() {
83 delete _objs;
84 }
167 _ptrmap.iterate(&relocator, start, end);
168 }
169
170 ArchiveBuilder::ArchiveBuilder() :
171 _current_dump_region(nullptr),
172 _buffer_bottom(nullptr),
173 _requested_static_archive_bottom(nullptr),
174 _requested_static_archive_top(nullptr),
175 _requested_dynamic_archive_bottom(nullptr),
176 _requested_dynamic_archive_top(nullptr),
177 _mapped_static_archive_bottom(nullptr),
178 _mapped_static_archive_top(nullptr),
179 _buffer_to_requested_delta(0),
180 _pz_region("pz", MAX_SHARED_DELTA), // protection zone -- used only during dumping; does NOT exist in cds archive.
181 _rw_region("rw", MAX_SHARED_DELTA),
182 _ro_region("ro", MAX_SHARED_DELTA),
183 _ac_region("ac", MAX_SHARED_DELTA),
184 _ptrmap(mtClassShared),
185 _rw_ptrmap(mtClassShared),
186 _ro_ptrmap(mtClassShared),
187 _ac_ptrmap(mtClassShared),
188 _rw_src_objs(),
189 _ro_src_objs(),
190 _src_obj_table(INITIAL_TABLE_SIZE, MAX_TABLE_SIZE),
191 _buffered_to_src_table(INITIAL_TABLE_SIZE, MAX_TABLE_SIZE),
192 _total_heap_region_size(0)
193 {
194 _klasses = new (mtClassShared) GrowableArray<Klass*>(4 * K, mtClassShared);
195 _symbols = new (mtClassShared) GrowableArray<Symbol*>(256 * K, mtClassShared);
196 _entropy_seed = 0x12345678;
197 _relocated_ptr_info._num_ptrs = 0;
198 _relocated_ptr_info._num_tagged_ptrs = 0;
199 _relocated_ptr_info._num_nulled_ptrs = 0;
200 assert(_current == nullptr, "must be");
201 _current = this;
202 }
203
204 ArchiveBuilder::~ArchiveBuilder() {
205 assert(_current == this, "must be");
206 _current = nullptr;
207
1170 patcher.doit();
1171 }
1172 }
1173
1174 void ArchiveBuilder::print_stats() {
1175 _alloc_stats.print_stats(int(_ro_region.used()), int(_rw_region.used()));
1176 }
1177
1178 void ArchiveBuilder::write_archive(FileMapInfo* mapinfo, ArchiveMappedHeapInfo* mapped_heap_info, ArchiveStreamedHeapInfo* streamed_heap_info) {
1179 // Make sure NUM_CDS_REGIONS (exported in cds.h) agrees with
1180 // AOTMetaspace::n_regions (internal to hotspot).
1181 assert(NUM_CDS_REGIONS == AOTMetaspace::n_regions, "sanity");
1182
1183 ResourceMark rm;
1184
1185 write_region(mapinfo, AOTMetaspace::rw, &_rw_region, /*read_only=*/false,/*allow_exec=*/false);
1186 write_region(mapinfo, AOTMetaspace::ro, &_ro_region, /*read_only=*/true, /*allow_exec=*/false);
1187 write_region(mapinfo, AOTMetaspace::ac, &_ac_region, /*read_only=*/false,/*allow_exec=*/false);
1188
1189 // Split pointer map into read-write and read-only bitmaps
1190 ArchivePtrMarker::initialize_rw_ro_ac_maps(&_rw_ptrmap, &_ro_ptrmap, &_ac_ptrmap);
1191
1192 size_t bitmap_size_in_bytes;
1193 char* bitmap = mapinfo->write_bitmap_region(ArchivePtrMarker::rw_ptrmap(),
1194 ArchivePtrMarker::ro_ptrmap(),
1195 ArchivePtrMarker::ac_ptrmap(),
1196 mapped_heap_info,
1197 streamed_heap_info,
1198 bitmap_size_in_bytes);
1199
1200 if (mapped_heap_info != nullptr && mapped_heap_info->is_used()) {
1201 _total_heap_region_size = mapinfo->write_mapped_heap_region(mapped_heap_info);
1202 } else if (streamed_heap_info != nullptr && streamed_heap_info->is_used()) {
1203 _total_heap_region_size = mapinfo->write_streamed_heap_region(streamed_heap_info);
1204 }
1205
1206 print_region_stats(mapinfo, mapped_heap_info, streamed_heap_info);
1207
1208 mapinfo->set_requested_base((char*)AOTMetaspace::requested_base_address());
1209 mapinfo->set_header_crc(mapinfo->compute_header_crc());
1210 // After this point, we should not write any data into mapinfo->header() since this
1211 // would corrupt its checksum we have calculated before.
1212 mapinfo->write_header();
1213 mapinfo->close();
1214
1215 aot_log_info(aot)("Full module graph = %s", CDSConfig::is_dumping_full_module_graph() ? "enabled" : "disabled");
1216 if (log_is_enabled(Info, aot)) {
1217 print_stats();
1218 }
1219
1220 if (log_is_enabled(Info, aot, map)) {
1221 AOTMapLogger::dumptime_log(this, mapinfo, mapped_heap_info, streamed_heap_info, bitmap, bitmap_size_in_bytes);
1222 }
1223 CDS_JAVA_HEAP_ONLY(HeapShared::destroy_archived_object_cache());
1224 FREE_C_HEAP_ARRAY(char, bitmap);
1225 }
1226
1227 void ArchiveBuilder::write_region(FileMapInfo* mapinfo, int region_idx, DumpRegion* dump_region, bool read_only, bool allow_exec) {
1228 mapinfo->write_region(region_idx, dump_region->base(), dump_region->used(), read_only, allow_exec);
1229 }
1230
1231 void ArchiveBuilder::count_relocated_pointer(bool tagged, bool nulled) {
1232 _relocated_ptr_info._num_ptrs ++;
1233 _relocated_ptr_info._num_tagged_ptrs += tagged ? 1 : 0;
1234 _relocated_ptr_info._num_nulled_ptrs += nulled ? 1 : 0;
1235 }
1236
|