374 ClassListParser::populate_cds_indy_info(pool, pool_index, &cii, CHECK);
375 GrowableArray<const char*>* indy_items = cii.items();
376 for (int i = 0; i < indy_items->length(); i++) {
377 w.stream()->print(" %s", indy_items->at(i));
378 }
379 w.stream()->cr();
380 }
381 }
382 }
383 }
384
385 bool ArchiveUtils::has_aot_initialized_mirror(InstanceKlass* src_ik) {
386 if (!ArchiveBuilder::current()->has_been_archived(src_ik)) {
387 return false;
388 }
389 return ArchiveBuilder::current()->get_buffered_addr(src_ik)->has_aot_initialized_mirror();
390 }
391
392 size_t HeapRootSegments::size_in_bytes(size_t seg_idx) {
393 assert(seg_idx < _count, "In range");
394 return objArrayOopDesc::object_size(size_in_elems(seg_idx)) * HeapWordSize;
395 }
396
397 int HeapRootSegments::size_in_elems(size_t seg_idx) {
398 assert(seg_idx < _count, "In range");
399 if (seg_idx != _count - 1) {
400 return _max_size_in_elems;
401 } else {
402 // Last slice, leftover
403 return _roots_count % _max_size_in_elems;
404 }
405 }
406
407 size_t HeapRootSegments::segment_offset(size_t seg_idx) {
408 assert(seg_idx < _count, "In range");
409 return _base_offset + seg_idx * _max_size_in_bytes;
410 }
411
412 ArchiveWorkers::ArchiveWorkers() :
413 _end_semaphore(0),
414 _num_workers(max_workers()),
|
374 ClassListParser::populate_cds_indy_info(pool, pool_index, &cii, CHECK);
375 GrowableArray<const char*>* indy_items = cii.items();
376 for (int i = 0; i < indy_items->length(); i++) {
377 w.stream()->print(" %s", indy_items->at(i));
378 }
379 w.stream()->cr();
380 }
381 }
382 }
383 }
384
385 bool ArchiveUtils::has_aot_initialized_mirror(InstanceKlass* src_ik) {
386 if (!ArchiveBuilder::current()->has_been_archived(src_ik)) {
387 return false;
388 }
389 return ArchiveBuilder::current()->get_buffered_addr(src_ik)->has_aot_initialized_mirror();
390 }
391
392 size_t HeapRootSegments::size_in_bytes(size_t seg_idx) {
393 assert(seg_idx < _count, "In range");
394 return refArrayOopDesc::object_size(size_in_elems(seg_idx)) * HeapWordSize;
395 }
396
397 int HeapRootSegments::size_in_elems(size_t seg_idx) {
398 assert(seg_idx < _count, "In range");
399 if (seg_idx != _count - 1) {
400 return _max_size_in_elems;
401 } else {
402 // Last slice, leftover
403 return _roots_count % _max_size_in_elems;
404 }
405 }
406
407 size_t HeapRootSegments::segment_offset(size_t seg_idx) {
408 assert(seg_idx < _count, "In range");
409 return _base_offset + seg_idx * _max_size_in_bytes;
410 }
411
412 ArchiveWorkers::ArchiveWorkers() :
413 _end_semaphore(0),
414 _num_workers(max_workers()),
|