src/hotspot/share/memory/dynamicArchive.cpp
author iklam
Fri, 22 Nov 2019 14:48:40 -0800
changeset 59234 ee0030a2a306
parent 59070 22ee476cc664
permissions -rw-r--r--
8234429: appcds/dynamicArchive tests crashing with Graal Reviewed-by: ccheung
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     1
/*
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     2
 * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     4
 *
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     8
 *
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    13
 * accompanied this code).
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    14
 *
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    18
 *
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    21
 * questions.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    22
 *
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    23
 */
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    24
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    25
#include "precompiled.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    26
#include "jvm.h"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    27
#include "classfile/classLoaderData.inline.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    28
#include "classfile/symbolTable.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    29
#include "classfile/systemDictionary.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    30
#include "classfile/systemDictionaryShared.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    31
#include "logging/log.hpp"
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
    32
#include "memory/archiveUtils.inline.hpp"
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
    33
#include "memory/dynamicArchive.hpp"
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    34
#include "memory/metadataFactory.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    35
#include "memory/metaspace.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    36
#include "memory/metaspaceClosure.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    37
#include "memory/metaspaceShared.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    38
#include "memory/resourceArea.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    39
#include "oops/compressedOops.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    40
#include "oops/objArrayKlass.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    41
#include "prims/jvmtiRedefineClasses.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    42
#include "runtime/handles.inline.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    43
#include "runtime/os.inline.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    44
#include "runtime/sharedRuntime.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    45
#include "runtime/vmThread.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    46
#include "runtime/vmOperations.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    47
#include "utilities/bitMap.inline.hpp"
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    48
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    49
#ifndef O_BINARY       // if defined (Win32) use binary files.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    50
#define O_BINARY 0     // otherwise do nothing.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    51
#endif
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    52
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    53
class DynamicArchiveBuilder : ResourceObj {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    54
  static unsigned my_hash(const address& a) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    55
    return primitive_hash<address>(a);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    56
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    57
  static bool my_equals(const address& a0, const address& a1) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    58
    return primitive_equals<address>(a0, a1);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    59
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    60
  typedef ResourceHashtable<
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    61
      address, address,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    62
      DynamicArchiveBuilder::my_hash,   // solaris compiler doesn't like: primitive_hash<address>
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    63
      DynamicArchiveBuilder::my_equals, // solaris compiler doesn't like: primitive_equals<address>
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    64
      16384, ResourceObj::C_HEAP> RelocationTable;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    65
  RelocationTable _new_loc_table;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    66
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
    67
  static intx _buffer_to_target_delta;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    68
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    69
  DumpRegion* _current_dump_space;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    70
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    71
  static size_t reserve_alignment() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    72
    return Metaspace::reserve_alignment();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    73
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    74
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    75
  static const int _total_dump_regions = 3;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    76
  int _num_dump_regions_used;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    77
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    78
public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    79
  void mark_pointer(address* ptr_loc) {
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
    80
    ArchivePtrMarker::mark_pointer(ptr_loc);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    81
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    82
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    83
  DumpRegion* current_dump_space() const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    84
    return _current_dump_space;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    85
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    86
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    87
  bool is_in_buffer_space(address p) const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    88
    return (_alloc_bottom <= p && p < (address)current_dump_space()->top());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    89
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    90
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    91
  template <typename T> bool is_in_target_space(T target_obj) const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    92
    address buff_obj = address(target_obj) - _buffer_to_target_delta;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    93
    return is_in_buffer_space(buff_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    94
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    95
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    96
  template <typename T> bool is_in_buffer_space(T obj) const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    97
    return is_in_buffer_space(address(obj));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    98
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
    99
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   100
  template <typename T> T to_target_no_check(T obj) const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   101
    return (T)(address(obj) + _buffer_to_target_delta);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   102
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   103
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   104
  template <typename T> T to_target(T obj) const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   105
    assert(is_in_buffer_space(obj), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   106
    return (T)(address(obj) + _buffer_to_target_delta);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   107
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   108
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   109
  template <typename T> T get_new_loc(T obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   110
    address* pp = _new_loc_table.get((address)obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   111
    if (pp == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   112
      // Excluded klasses are not copied
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   113
      return NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   114
    } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   115
      return (T)*pp;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   116
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   117
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   118
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   119
  address get_new_loc(MetaspaceClosure::Ref* ref) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   120
    return get_new_loc(ref->obj());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   121
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   122
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   123
  template <typename T> bool has_new_loc(T obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   124
    address* pp = _new_loc_table.get((address)obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   125
    return pp != NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   126
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   127
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   128
  static int dynamic_dump_method_comparator(Method* a, Method* b) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   129
    Symbol* a_name = a->name();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   130
    Symbol* b_name = b->name();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   131
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   132
    if (a_name == b_name) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   133
      return 0;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   134
    }
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   135
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   136
    if (!MetaspaceShared::is_in_shared_metaspace(a_name)) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   137
      // a_name points to a Symbol in the top archive.
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   138
      // When this method is called, a_name is still pointing to the output space.
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   139
      // Translate it to point to the output space, so that it can be compared with
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   140
      // Symbols in the base archive.
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   141
      a_name = (Symbol*)(address(a_name) + _buffer_to_target_delta);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   142
    }
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   143
    if (!MetaspaceShared::is_in_shared_metaspace(b_name)) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   144
      b_name = (Symbol*)(address(b_name) + _buffer_to_target_delta);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   145
    }
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   146
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   147
    return a_name->fast_compare(b_name);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   148
  }
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   149
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   150
protected:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   151
  enum FollowMode {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   152
    make_a_copy, point_to_it, set_to_null
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   153
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   154
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   155
public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   156
  void copy(MetaspaceClosure::Ref* ref, bool read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   157
    int bytes = ref->size() * BytesPerWord;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   158
    address old_obj = ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   159
    address new_obj = copy_impl(ref, read_only, bytes);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   160
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   161
    assert(new_obj != NULL, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   162
    assert(new_obj != old_obj, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   163
    bool isnew = _new_loc_table.put(old_obj, new_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   164
    assert(isnew, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   165
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   166
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   167
  // Make a shallow copy of each eligible MetaspaceObj into the buffer.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   168
  class ShallowCopier: public UniqueMetaspaceClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   169
    DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   170
    bool _read_only;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   171
  public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   172
    ShallowCopier(DynamicArchiveBuilder* shuffler, bool read_only)
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   173
      : _builder(shuffler), _read_only(read_only) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   174
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   175
    virtual bool do_unique_ref(Ref* orig_obj, bool read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   176
      // This method gets called on each *original* object
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   177
      // reachable from _builder->iterate_roots(). Each orig_obj is
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   178
      // called exactly once.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   179
      FollowMode mode = _builder->follow_ref(orig_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   180
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   181
      if (mode == point_to_it) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   182
        if (read_only == _read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   183
          log_debug(cds, dynamic)("ptr : " PTR_FORMAT " %s", p2i(orig_obj->obj()),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   184
                                  MetaspaceObj::type_name(orig_obj->msotype()));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   185
          address p = orig_obj->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   186
          bool isnew = _builder->_new_loc_table.put(p, p);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   187
          assert(isnew, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   188
        }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   189
        return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   190
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   191
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   192
      if (mode == set_to_null) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   193
        log_debug(cds, dynamic)("nul : " PTR_FORMAT " %s", p2i(orig_obj->obj()),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   194
                                MetaspaceObj::type_name(orig_obj->msotype()));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   195
        return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   196
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   197
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   198
      if (read_only == _read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   199
        // Make a shallow copy of orig_obj in a buffer (maintained
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   200
        // by copy_impl in a subclass of DynamicArchiveBuilder).
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   201
        _builder->copy(orig_obj, read_only);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   202
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   203
      return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   204
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   205
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   206
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   207
  // Relocate all embedded pointer fields within a MetaspaceObj's shallow copy
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   208
  class ShallowCopyEmbeddedRefRelocator: public UniqueMetaspaceClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   209
    DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   210
  public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   211
    ShallowCopyEmbeddedRefRelocator(DynamicArchiveBuilder* shuffler)
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   212
      : _builder(shuffler) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   213
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   214
    // This method gets called on each *original* object reachable
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   215
    // from _builder->iterate_roots(). Each orig_obj is
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   216
    // called exactly once.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   217
    virtual bool do_unique_ref(Ref* orig_ref, bool read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   218
      FollowMode mode = _builder->follow_ref(orig_ref);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   219
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   220
      if (mode == point_to_it) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   221
        // We did not make a copy of this object
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   222
        // and we have nothing to update
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   223
        assert(_builder->get_new_loc(orig_ref) == NULL ||
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   224
               _builder->get_new_loc(orig_ref) == orig_ref->obj(), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   225
        return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   226
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   227
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   228
      if (mode == set_to_null) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   229
        // We did not make a copy of this object
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   230
        // and we have nothing to update
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   231
        assert(!_builder->has_new_loc(orig_ref->obj()), "must not be copied or pointed to");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   232
        return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   233
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   234
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   235
      // - orig_obj points to the original object.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   236
      // - new_obj points to the shallow copy (created by ShallowCopier)
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   237
      //   of orig_obj. new_obj is NULL if the orig_obj is excluded
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   238
      address orig_obj = orig_ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   239
      address new_obj  = _builder->get_new_loc(orig_ref);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   240
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   241
      assert(new_obj != orig_obj, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   242
#ifdef ASSERT
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   243
      if (new_obj == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   244
        if (orig_ref->msotype() == MetaspaceObj::ClassType) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   245
          Klass* k = (Klass*)orig_obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   246
          assert(k->is_instance_klass() &&
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   247
                 SystemDictionaryShared::is_excluded_class(InstanceKlass::cast(k)),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   248
                 "orig_obj must be excluded Class");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   249
        }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   250
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   251
#endif
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   252
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   253
      log_debug(cds, dynamic)("Relocating " PTR_FORMAT " %s", p2i(new_obj),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   254
                              MetaspaceObj::type_name(orig_ref->msotype()));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   255
      if (new_obj != NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   256
        EmbeddedRefUpdater updater(_builder, orig_obj, new_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   257
        orig_ref->metaspace_pointers_do(&updater);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   258
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   259
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   260
      return true; // keep recursing until every object is visited exactly once.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   261
    }
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   262
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   263
    virtual void push_special(SpecialRef type, Ref* ref, intptr_t* p) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   264
      assert(type == _method_entry_ref, "only special type allowed for now");
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   265
      address obj = ref->obj();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   266
      address new_obj = _builder->get_new_loc(ref);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   267
      size_t offset = pointer_delta(p, obj,  sizeof(u1));
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   268
      intptr_t* new_p = (intptr_t*)(new_obj + offset);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   269
      assert(*p == *new_p, "must be a copy");
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   270
      ArchivePtrMarker::mark_pointer((address*)new_p);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   271
    }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   272
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   273
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   274
  class EmbeddedRefUpdater: public MetaspaceClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   275
    DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   276
    address _orig_obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   277
    address _new_obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   278
  public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   279
    EmbeddedRefUpdater(DynamicArchiveBuilder* shuffler, address orig_obj, address new_obj) :
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   280
      _builder(shuffler), _orig_obj(orig_obj), _new_obj(new_obj) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   281
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   282
    // This method gets called once for each pointer field F of orig_obj.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   283
    // We update new_obj->F to point to the new location of orig_obj->F.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   284
    //
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   285
    // Example: Klass*  0x100 is copied to 0x400
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   286
    //          Symbol* 0x200 is copied to 0x500
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   287
    //
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   288
    // Let orig_obj == 0x100; and
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   289
    //     new_obj  == 0x400; and
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   290
    //     ((Klass*)orig_obj)->_name == 0x200;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   291
    // Then this function effectively assigns
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   292
    //     ((Klass*)new_obj)->_name = 0x500;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   293
    virtual bool do_ref(Ref* ref, bool read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   294
      address new_pointee = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   295
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   296
      if (ref->not_null()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   297
        address old_pointee = ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   298
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   299
        FollowMode mode = _builder->follow_ref(ref);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   300
        if (mode == point_to_it) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   301
          new_pointee = old_pointee;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   302
        } else if (mode == set_to_null) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   303
          new_pointee = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   304
        } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   305
          new_pointee = _builder->get_new_loc(old_pointee);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   306
        }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   307
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   308
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   309
      const char* kind = MetaspaceObj::type_name(ref->msotype());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   310
      // offset of this field inside the original object
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   311
      intx offset = (address)ref->addr() - _orig_obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   312
      _builder->update_pointer((address*)(_new_obj + offset), new_pointee, kind, offset);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   313
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   314
      // We can't mark the pointer here, because DynamicArchiveBuilder::sort_methods
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   315
      // may re-layout the [iv]tables, which would change the offset(s) in an InstanceKlass
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   316
      // that would contain pointers. Therefore, we must mark the pointers after
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   317
      // sort_methods(), using PointerMarker.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   318
      return false; // Do not recurse.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   319
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   320
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   321
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   322
  class ExternalRefUpdater: public MetaspaceClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   323
    DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   324
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   325
  public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   326
    ExternalRefUpdater(DynamicArchiveBuilder* shuffler) : _builder(shuffler) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   327
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   328
    virtual bool do_ref(Ref* ref, bool read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   329
      // ref is a pointer that lives OUTSIDE of the buffer, but points to an object inside the buffer
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   330
      if (ref->not_null()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   331
        address new_loc = _builder->get_new_loc(ref);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   332
        const char* kind = MetaspaceObj::type_name(ref->msotype());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   333
        _builder->update_pointer(ref->addr(), new_loc, kind, 0);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   334
        _builder->mark_pointer(ref->addr());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   335
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   336
      return false; // Do not recurse.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   337
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   338
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   339
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   340
  class PointerMarker: public UniqueMetaspaceClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   341
    DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   342
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   343
  public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   344
    PointerMarker(DynamicArchiveBuilder* shuffler) : _builder(shuffler) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   345
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   346
    virtual bool do_unique_ref(Ref* ref, bool read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   347
      if (_builder->is_in_buffer_space(ref->obj())) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   348
        EmbeddedRefMarker ref_marker(_builder);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   349
        ref->metaspace_pointers_do(&ref_marker);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   350
        return true; // keep recursing until every buffered object is visited exactly once.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   351
      } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   352
        return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   353
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   354
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   355
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   356
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   357
  class EmbeddedRefMarker: public MetaspaceClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   358
    DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   359
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   360
  public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   361
    EmbeddedRefMarker(DynamicArchiveBuilder* shuffler) : _builder(shuffler) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   362
    virtual bool do_ref(Ref* ref, bool read_only) {
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   363
      if (ref->not_null()) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   364
        _builder->mark_pointer(ref->addr());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   365
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   366
      return false; // Do not recurse.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   367
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   368
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   369
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   370
  void update_pointer(address* addr, address value, const char* kind, uintx offset, bool is_mso_pointer=true) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   371
    // Propagate the the mask bits to the new value -- see comments above MetaspaceClosure::obj()
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   372
    if (is_mso_pointer) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   373
      const uintx FLAG_MASK = 0x03;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   374
      uintx mask_bits = uintx(*addr) & FLAG_MASK;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   375
      value = (address)(uintx(value) | mask_bits);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   376
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   377
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   378
    if (*addr != value) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   379
      log_debug(cds, dynamic)("Update (%18s*) %3d [" PTR_FORMAT "] " PTR_FORMAT " -> " PTR_FORMAT,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   380
                              kind, int(offset), p2i(addr), p2i(*addr), p2i(value));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   381
      *addr = value;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   382
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   383
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   384
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   385
private:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   386
  GrowableArray<Symbol*>* _symbols; // symbols to dump
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   387
  GrowableArray<InstanceKlass*>* _klasses; // klasses to dump
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   388
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   389
  void append(InstanceKlass* k) { _klasses->append(k); }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   390
  void append(Symbol* s)        { _symbols->append(s); }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   391
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   392
  class GatherKlassesAndSymbols : public UniqueMetaspaceClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   393
    DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   394
    bool _read_only;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   395
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   396
  public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   397
    GatherKlassesAndSymbols(DynamicArchiveBuilder* builder)
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   398
      : _builder(builder) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   399
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   400
    virtual bool do_unique_ref(Ref* ref, bool read_only) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   401
      if (_builder->follow_ref(ref) != make_a_copy) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   402
        return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   403
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   404
      if (ref->msotype() == MetaspaceObj::ClassType) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   405
        Klass* klass = (Klass*)ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   406
        assert(klass->is_klass(), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   407
        if (klass->is_instance_klass()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   408
          InstanceKlass* ik = InstanceKlass::cast(klass);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   409
          assert(!SystemDictionaryShared::is_excluded_class(ik), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   410
          _builder->append(ik);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   411
          _builder->_estimated_metsapceobj_bytes += BytesPerWord; // See RunTimeSharedClassInfo::get_for()
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   412
        }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   413
      } else if (ref->msotype() == MetaspaceObj::SymbolType) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   414
        _builder->append((Symbol*)ref->obj());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   415
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   416
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   417
      int bytes = ref->size() * BytesPerWord;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   418
      _builder->_estimated_metsapceobj_bytes += bytes;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   419
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   420
      return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   421
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   422
  };
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   423
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   424
  FollowMode follow_ref(MetaspaceClosure::Ref *ref) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   425
    address obj = ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   426
    if (MetaspaceShared::is_in_shared_metaspace(obj)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   427
      // Don't dump existing shared metadata again.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   428
      return point_to_it;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   429
    } else if (ref->msotype() == MetaspaceObj::MethodDataType) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   430
      return set_to_null;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   431
    } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   432
      if (ref->msotype() == MetaspaceObj::ClassType) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   433
        Klass* klass = (Klass*)ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   434
        assert(klass->is_klass(), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   435
        if (klass->is_instance_klass()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   436
          InstanceKlass* ik = InstanceKlass::cast(klass);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   437
          if (SystemDictionaryShared::is_excluded_class(ik)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   438
            ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   439
            log_debug(cds, dynamic)("Skipping class (excluded): %s", klass->external_name());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   440
            return set_to_null;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   441
          }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   442
        } else if (klass->is_array_klass()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   443
          // Don't support archiving of array klasses for now.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   444
          ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   445
          log_debug(cds, dynamic)("Skipping class (array): %s", klass->external_name());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   446
          return set_to_null;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   447
        }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   448
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   449
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   450
      return make_a_copy;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   451
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   452
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   453
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   454
  address copy_impl(MetaspaceClosure::Ref* ref, bool read_only, int bytes) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   455
    if (ref->msotype() == MetaspaceObj::ClassType) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   456
      // Save a pointer immediate in front of an InstanceKlass, so
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   457
      // we can do a quick lookup from InstanceKlass* -> RunTimeSharedClassInfo*
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   458
      // without building another hashtable. See RunTimeSharedClassInfo::get_for()
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   459
      // in systemDictionaryShared.cpp.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   460
      address obj = ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   461
      Klass* klass = (Klass*)obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   462
      if (klass->is_instance_klass()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   463
        SystemDictionaryShared::validate_before_archiving(InstanceKlass::cast(klass));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   464
        current_dump_space()->allocate(sizeof(address), BytesPerWord);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   465
      }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   466
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   467
    address p = (address)current_dump_space()->allocate(bytes);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   468
    address obj = ref->obj();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   469
    log_debug(cds, dynamic)("COPY: " PTR_FORMAT " ==> " PTR_FORMAT " %5d %s",
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   470
                            p2i(obj), p2i(p), bytes,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   471
                            MetaspaceObj::type_name(ref->msotype()));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   472
    memcpy(p, obj, bytes);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   473
    intptr_t* cloned_vtable = MetaspaceShared::fix_cpp_vtable_for_dynamic_archive(ref->msotype(), p);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   474
    if (cloned_vtable != NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   475
      update_pointer((address*)p, (address)cloned_vtable, "vtb", 0, /*is_mso_pointer*/false);
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   476
      mark_pointer((address*)p);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   477
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   478
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   479
    return (address)p;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   480
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   481
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   482
  DynamicArchiveHeader *_header;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   483
  address _alloc_bottom;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   484
  address _last_verified_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   485
  size_t _other_region_used_bytes;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   486
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   487
  // Conservative estimate for number of bytes needed for:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   488
  size_t _estimated_metsapceobj_bytes;   // all archived MetsapceObj's.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   489
  size_t _estimated_hashtable_bytes;     // symbol table and dictionaries
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   490
  size_t _estimated_trampoline_bytes;    // method entry trampolines
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   491
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   492
  size_t estimate_archive_size();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   493
  size_t estimate_trampoline_size();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   494
  size_t estimate_class_file_size();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   495
  address reserve_space_and_init_buffer_to_target_delta();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   496
  void init_header(address addr);
59234
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   497
  void release_header();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   498
  void make_trampolines();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   499
  void make_klasses_shareable();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   500
  void sort_methods(InstanceKlass* ik) const;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   501
  void set_symbols_permanent();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   502
  void relocate_buffer_to_target();
58278
e47b459b315c 8231278: Rename FileMapHeader::_read_only_tables_start to _serialized_data_start
iklam
parents: 58277
diff changeset
   503
  void write_archive(char* serialized_data_start);
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58096
diff changeset
   504
  void write_regions(FileMapInfo* dynamic_info);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   505
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   506
  void init_first_dump_space(address reserved_bottom) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   507
    address first_space_base = reserved_bottom;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   508
    DumpRegion* rw_space = MetaspaceShared::read_write_dump_space();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   509
    MetaspaceShared::init_shared_dump_space(rw_space, first_space_base);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   510
    _current_dump_space = rw_space;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   511
    _last_verified_top = first_space_base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   512
    _num_dump_regions_used = 1;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   513
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   514
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   515
public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   516
  DynamicArchiveBuilder() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   517
    _klasses = new (ResourceObj::C_HEAP, mtClass) GrowableArray<InstanceKlass*>(100, true, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   518
    _symbols = new (ResourceObj::C_HEAP, mtClass) GrowableArray<Symbol*>(1000, true, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   519
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   520
    _estimated_metsapceobj_bytes = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   521
    _estimated_hashtable_bytes = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   522
    _estimated_trampoline_bytes = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   523
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   524
    _num_dump_regions_used = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   525
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   526
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   527
  void start_dump_space(DumpRegion* next) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   528
    address bottom = _last_verified_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   529
    address top = (address)(current_dump_space()->top());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   530
    _other_region_used_bytes += size_t(top - bottom);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   531
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   532
    MetaspaceShared::pack_dump_space(current_dump_space(), next, MetaspaceShared::shared_rs());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   533
    _current_dump_space = next;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   534
    _num_dump_regions_used ++;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   535
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   536
    _last_verified_top = (address)(current_dump_space()->top());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   537
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   538
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   539
  void verify_estimate_size(size_t estimate, const char* which) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   540
    address bottom = _last_verified_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   541
    address top = (address)(current_dump_space()->top());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   542
    size_t used = size_t(top - bottom) + _other_region_used_bytes;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   543
    int diff = int(estimate) - int(used);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   544
54932
0f934da77390 8224170: Build failures after JDK-8207812 (Implement Dynamic CDS Archive)
shade
parents: 54927
diff changeset
   545
    log_info(cds)("%s estimate = " SIZE_FORMAT " used = " SIZE_FORMAT "; diff = %d bytes", which, estimate, used, diff);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   546
    assert(diff >= 0, "Estimate is too small");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   547
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   548
    _last_verified_top = top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   549
    _other_region_used_bytes = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   550
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   551
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   552
  // Do this before and after the archive dump to see if any corruption
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   553
  // is caused by dynamic dumping.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   554
  void verify_universe(const char* info) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   555
    if (VerifyBeforeExit) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   556
      log_info(cds)("Verify %s", info);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   557
      HandleMark hm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   558
      // Among other things, this ensures that Eden top is correct.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   559
      Universe::heap()->prepare_for_verify();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   560
      Universe::verify(info);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   561
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   562
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   563
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   564
  void doit() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   565
    verify_universe("Before CDS dynamic dump");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   566
    DEBUG_ONLY(SystemDictionaryShared::NoClassLoadingMark nclm);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   567
    SystemDictionaryShared::check_excluded_classes();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   568
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   569
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   570
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   571
      GatherKlassesAndSymbols gatherer(this);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   572
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   573
      SystemDictionaryShared::dumptime_classes_do(&gatherer);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   574
      SymbolTable::metaspace_pointers_do(&gatherer);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   575
      FileMapInfo::metaspace_pointers_do(&gatherer);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   576
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   577
      gatherer.finish();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   578
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   579
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   580
    // rw space starts ...
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   581
    address reserved_bottom = reserve_space_and_init_buffer_to_target_delta();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   582
    init_header(reserved_bottom);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   583
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   584
    CHeapBitMap ptrmap;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   585
    ArchivePtrMarker::initialize(&ptrmap, (address*)reserved_bottom, (address*)current_dump_space()->top());
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   586
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   587
    verify_estimate_size(sizeof(DynamicArchiveHeader), "header");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   588
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   589
    log_info(cds, dynamic)("Copying %d klasses and %d symbols",
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   590
                           _klasses->length(), _symbols->length());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   591
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   592
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   593
      assert(current_dump_space() == MetaspaceShared::read_write_dump_space(),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   594
             "Current dump space is not rw space");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   595
      // shallow-copy RW objects, if necessary
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   596
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   597
      ShallowCopier rw_copier(this, false);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   598
      iterate_roots(&rw_copier);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   599
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   600
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   601
    // ro space starts ...
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   602
    DumpRegion* ro_space = MetaspaceShared::read_only_dump_space();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   603
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   604
      start_dump_space(ro_space);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   605
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   606
      // shallow-copy RO objects, if necessary
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   607
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   608
      ShallowCopier ro_copier(this, true);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   609
      iterate_roots(&ro_copier);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   610
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   611
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   612
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   613
      log_info(cds)("Relocating embedded pointers ... ");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   614
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   615
      ShallowCopyEmbeddedRefRelocator emb_reloc(this);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   616
      iterate_roots(&emb_reloc);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   617
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   618
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   619
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   620
      log_info(cds)("Relocating external roots ... ");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   621
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   622
      ExternalRefUpdater ext_reloc(this);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   623
      iterate_roots(&ext_reloc);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   624
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   625
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   626
    verify_estimate_size(_estimated_metsapceobj_bytes, "MetaspaceObjs");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   627
58278
e47b459b315c 8231278: Rename FileMapHeader::_read_only_tables_start to _serialized_data_start
iklam
parents: 58277
diff changeset
   628
    char* serialized_data_start;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   629
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   630
      set_symbols_permanent();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   631
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   632
      // Write the symbol table and system dictionaries to the RO space.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   633
      // Note that these tables still point to the *original* objects
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   634
      // (because they were not processed by ExternalRefUpdater), so
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   635
      // they would need to call DynamicArchive::original_to_target() to
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   636
      // get the correct addresses.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   637
      assert(current_dump_space() == ro_space, "Must be RO space");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   638
      SymbolTable::write_to_archive(false);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   639
      SystemDictionaryShared::write_to_archive(false);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   640
58278
e47b459b315c 8231278: Rename FileMapHeader::_read_only_tables_start to _serialized_data_start
iklam
parents: 58277
diff changeset
   641
      serialized_data_start = ro_space->top();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   642
      WriteClosure wc(ro_space);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   643
      SymbolTable::serialize_shared_table_header(&wc, false);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   644
      SystemDictionaryShared::serialize_dictionary_headers(&wc, false);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   645
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   646
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   647
    verify_estimate_size(_estimated_hashtable_bytes, "Hashtables");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   648
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   649
    // mc space starts ...
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   650
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   651
      start_dump_space(MetaspaceShared::misc_code_dump_space());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   652
      make_trampolines();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   653
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   654
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   655
    verify_estimate_size(_estimated_trampoline_bytes, "Trampolines");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   656
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   657
    make_klasses_shareable();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   658
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   659
    {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   660
      log_info(cds)("Final relocation of pointers ... ");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   661
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   662
      PointerMarker marker(this);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   663
      iterate_roots(&marker);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   664
      relocate_buffer_to_target();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   665
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   666
58278
e47b459b315c 8231278: Rename FileMapHeader::_read_only_tables_start to _serialized_data_start
iklam
parents: 58277
diff changeset
   667
    write_archive(serialized_data_start);
59234
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   668
    release_header();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   669
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   670
    assert(_num_dump_regions_used == _total_dump_regions, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   671
    verify_universe("After CDS dynamic dump");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   672
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   673
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   674
  void iterate_roots(MetaspaceClosure* it) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   675
    int i;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   676
    int num_klasses = _klasses->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   677
    for (i = 0; i < num_klasses; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   678
      it->push(&_klasses->at(i));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   679
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   680
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   681
    int num_symbols = _symbols->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   682
    for (i = 0; i < num_symbols; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   683
      it->push(&_symbols->at(i));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   684
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   685
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   686
    FileMapInfo::metaspace_pointers_do(it);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   687
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   688
    // Do not call these again, as we have already collected all the classes and symbols
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   689
    // that we want to archive. Also, these calls would corrupt the tables when
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   690
    // ExternalRefUpdater is used.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   691
    //
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   692
    // SystemDictionaryShared::dumptime_classes_do(it);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   693
    // SymbolTable::metaspace_pointers_do(it);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   694
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   695
    it->finish();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   696
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   697
};
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   698
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   699
intx DynamicArchiveBuilder::_buffer_to_target_delta;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   700
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   701
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   702
size_t DynamicArchiveBuilder::estimate_archive_size() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   703
  // size of the symbol table and two dictionaries, plus the RunTimeSharedClassInfo's
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   704
  _estimated_hashtable_bytes = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   705
  _estimated_hashtable_bytes += SymbolTable::estimate_size_for_archive();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   706
  _estimated_hashtable_bytes += SystemDictionaryShared::estimate_size_for_archive();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   707
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   708
  _estimated_trampoline_bytes = estimate_trampoline_size();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   709
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   710
  size_t total = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   711
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   712
  total += _estimated_metsapceobj_bytes;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   713
  total += _estimated_hashtable_bytes;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   714
  total += _estimated_trampoline_bytes;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   715
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   716
  // allow fragmentation at the end of each dump region
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   717
  total += _total_dump_regions * reserve_alignment();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   718
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   719
  return align_up(total, reserve_alignment());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   720
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   721
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   722
address DynamicArchiveBuilder::reserve_space_and_init_buffer_to_target_delta() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   723
  size_t total = estimate_archive_size();
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   724
  ReservedSpace rs = MetaspaceShared::reserve_shared_space(total);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   725
  if (!rs.is_reserved()) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   726
    log_error(cds, dynamic)("Failed to reserve %d bytes of output buffer.", (int)total);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   727
    vm_direct_exit(0);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   728
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   729
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   730
  address buffer_base = (address)rs.base();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   731
  log_info(cds, dynamic)("Reserved output buffer space at    : " PTR_FORMAT " [%d bytes]",
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   732
                         p2i(buffer_base), (int)total);
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   733
  MetaspaceShared::set_shared_rs(rs);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   734
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   735
  // At run time, we will mmap the dynamic archive at target_space_bottom.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   736
  // However, at dump time, we may not be able to write into the target_space,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   737
  // as it's occupied by dynamically loaded Klasses. So we allocate a buffer
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   738
  // at an arbitrary location chosen by the OS. We will write all the dynamically
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   739
  // archived classes into this buffer. At the final stage of dumping, we relocate
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   740
  // all pointers that are inside the buffer_space to point to their (runtime)
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   741
  // target location inside thetarget_space.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   742
  address target_space_bottom =
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   743
    (address)align_up(MetaspaceShared::shared_metaspace_top(), reserve_alignment());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   744
  _buffer_to_target_delta = intx(target_space_bottom) - intx(buffer_base);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   745
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   746
  log_info(cds, dynamic)("Target archive space at            : " PTR_FORMAT, p2i(target_space_bottom));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   747
  log_info(cds, dynamic)("Buffer-space to target-space delta : " PTR_FORMAT, p2i((address)_buffer_to_target_delta));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   748
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   749
  return buffer_base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   750
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   751
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   752
void DynamicArchiveBuilder::init_header(address reserved_bottom) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   753
  _alloc_bottom = reserved_bottom;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   754
  _last_verified_top = reserved_bottom;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   755
  _other_region_used_bytes = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   756
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   757
  init_first_dump_space(reserved_bottom);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   758
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   759
  FileMapInfo* mapinfo = new FileMapInfo(false);
59234
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   760
  assert(FileMapInfo::dynamic_info() == mapinfo, "must be");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
   761
  _header = mapinfo->dynamic_header();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   762
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   763
  Thread* THREAD = Thread::current();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   764
  FileMapInfo* base_info = FileMapInfo::current_info();
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
   765
  _header->set_base_header_crc(base_info->crc());
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   766
  for (int i = 0; i < MetaspaceShared::n_regions; i++) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
   767
    _header->set_base_region_crc(i, base_info->space_crc(i));
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   768
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   769
  _header->populate(base_info, os::vm_allocation_granularity());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   770
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   771
59234
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   772
void DynamicArchiveBuilder::release_header() {
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   773
  // We temporarily allocated a dynamic FileMapInfo for dumping, which makes it appear we
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   774
  // have mapped a dynamic archive, but we actually have not. We are in a safepoint now.
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   775
  // Let's free it so that if class loading happens after we leave the safepoint, nothing
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   776
  // bad will happen.
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   777
  assert(SafepointSynchronize::is_at_safepoint(), "must be");
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   778
  FileMapInfo *mapinfo = FileMapInfo::dynamic_info();
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   779
  assert(mapinfo != NULL && _header == mapinfo->dynamic_header(), "must be");
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   780
  delete mapinfo;
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   781
  assert(!DynamicArchive::is_mapped(), "must be");
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   782
  _header = NULL;
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   783
}
ee0030a2a306 8234429: appcds/dynamicArchive tests crashing with Graal
iklam
parents: 59070
diff changeset
   784
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   785
size_t DynamicArchiveBuilder::estimate_trampoline_size() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   786
  size_t total = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   787
  size_t each_method_bytes =
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   788
    align_up(SharedRuntime::trampoline_size(), BytesPerWord) +
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   789
    align_up(sizeof(AdapterHandlerEntry*), BytesPerWord);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   790
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   791
  for (int i = 0; i < _klasses->length(); i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   792
    InstanceKlass* ik = _klasses->at(i);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   793
    Array<Method*>* methods = ik->methods();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   794
    total += each_method_bytes * methods->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   795
  }
55134
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   796
  if (total == 0) {
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   797
    // We have nothing to archive, but let's avoid having an empty region.
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   798
    total = SharedRuntime::trampoline_size();
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   799
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   800
  return total;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   801
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   802
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   803
void DynamicArchiveBuilder::make_trampolines() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   804
  for (int i = 0; i < _klasses->length(); i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   805
    InstanceKlass* ik = _klasses->at(i);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   806
    Array<Method*>* methods = ik->methods();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   807
    for (int j = 0; j < methods->length(); j++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   808
      Method* m = methods->at(j);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   809
      address c2i_entry_trampoline =
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   810
        (address)MetaspaceShared::misc_code_space_alloc(SharedRuntime::trampoline_size());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   811
      m->set_from_compiled_entry(to_target(c2i_entry_trampoline));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   812
      AdapterHandlerEntry** adapter_trampoline =
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   813
        (AdapterHandlerEntry**)MetaspaceShared::misc_code_space_alloc(sizeof(AdapterHandlerEntry*));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   814
      *adapter_trampoline = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   815
      m->set_adapter_trampoline(to_target(adapter_trampoline));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   816
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   817
  }
55134
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   818
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   819
  if (MetaspaceShared::misc_code_dump_space()->used() == 0) {
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   820
    // We have nothing to archive, but let's avoid having an empty region.
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   821
    MetaspaceShared::misc_code_space_alloc(SharedRuntime::trampoline_size());
72474808e305 8224692: runtime/appcds tests crash in "HotSpotJVMCI::compute_offset" when running in Graal as JIT mode
iklam
parents: 54932
diff changeset
   822
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   823
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   824
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   825
void DynamicArchiveBuilder::make_klasses_shareable() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   826
  int i, count = _klasses->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   827
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   828
  InstanceKlass::disable_method_binary_search();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   829
  for (i = 0; i < count; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   830
    InstanceKlass* ik = _klasses->at(i);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   831
    sort_methods(ik);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   832
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   833
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   834
  for (i = 0; i < count; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   835
    InstanceKlass* ik = _klasses->at(i);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   836
    ClassLoaderData *cld = ik->class_loader_data();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   837
    if (cld->is_boot_class_loader_data()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   838
      ik->set_class_loader_type(ClassLoader::BOOT_LOADER);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   839
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   840
    else if (cld->is_platform_class_loader_data()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   841
      ik->set_class_loader_type(ClassLoader::PLATFORM_LOADER);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   842
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   843
    else if (cld->is_system_class_loader_data()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   844
      ik->set_class_loader_type(ClassLoader::APP_LOADER);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   845
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   846
59056
15936b142f86 8233913: Remove implicit conversion from Method* to methodHandle
coleenp
parents: 58278
diff changeset
   847
    MetaspaceShared::rewrite_nofast_bytecodes_and_calculate_fingerprints(Thread::current(), ik);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   848
    ik->remove_unshareable_info();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   849
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   850
    assert(ik->array_klasses() == NULL, "sanity");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   851
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   852
    if (log_is_enabled(Debug, cds, dynamic)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   853
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   854
      log_debug(cds, dynamic)("klasses[%4i] = " PTR_FORMAT " %s", i, p2i(to_target(ik)), ik->external_name());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   855
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   856
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   857
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   858
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   859
// The address order of the copied Symbols may be different than when the original
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   860
// klasses were created. Re-sort all the tables. See Method::sort_methods().
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   861
void DynamicArchiveBuilder::sort_methods(InstanceKlass* ik) const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   862
  assert(ik != NULL, "DynamicArchiveBuilder currently doesn't support dumping the base archive");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   863
  if (MetaspaceShared::is_in_shared_metaspace(ik)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   864
    // We have reached a supertype that's already in the base archive
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   865
    return;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   866
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   867
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   868
  if (ik->java_mirror() == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   869
    // NULL mirror means this class has already been visited and methods are already sorted
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   870
    return;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   871
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   872
  ik->remove_java_mirror();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   873
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   874
  if (log_is_enabled(Debug, cds, dynamic)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   875
    ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   876
    log_debug(cds, dynamic)("sorting methods for " PTR_FORMAT " %s", p2i(to_target(ik)), ik->external_name());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   877
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   878
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   879
  // Make sure all supertypes have been sorted
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   880
  sort_methods(ik->java_super());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   881
  Array<InstanceKlass*>* interfaces = ik->local_interfaces();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   882
  int len = interfaces->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   883
  for (int i = 0; i < len; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   884
    sort_methods(interfaces->at(i));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   885
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   886
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   887
#ifdef ASSERT
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   888
  if (ik->methods() != NULL) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   889
    for (int m = 0; m < ik->methods()->length(); m++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   890
      Symbol* name = ik->methods()->at(m)->name();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   891
      assert(MetaspaceShared::is_in_shared_metaspace(name) || is_in_buffer_space(name), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   892
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   893
  }
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   894
  if (ik->default_methods() != NULL) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   895
    for (int m = 0; m < ik->default_methods()->length(); m++) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   896
      Symbol* name = ik->default_methods()->at(m)->name();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   897
      assert(MetaspaceShared::is_in_shared_metaspace(name) || is_in_buffer_space(name), "must be");
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   898
    }
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   899
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   900
#endif
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   901
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   902
  Thread* THREAD = Thread::current();
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   903
  Method::sort_methods(ik->methods(), /*set_idnums=*/true, dynamic_dump_method_comparator);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   904
  if (ik->default_methods() != NULL) {
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   905
    Method::sort_methods(ik->default_methods(), /*set_idnums=*/false, dynamic_dump_method_comparator);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   906
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   907
  ik->vtable().initialize_vtable(true, THREAD); assert(!HAS_PENDING_EXCEPTION, "cannot fail");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   908
  ik->itable().initialize_itable(true, THREAD); assert(!HAS_PENDING_EXCEPTION, "cannot fail");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   909
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   910
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   911
void DynamicArchiveBuilder::set_symbols_permanent() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   912
  int count = _symbols->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   913
  for (int i=0; i<count; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   914
    Symbol* s = _symbols->at(i);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   915
    s->set_permanent();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   916
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   917
    if (log_is_enabled(Trace, cds, dynamic)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   918
      ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   919
      log_trace(cds, dynamic)("symbols[%4i] = " PTR_FORMAT " %s", i, p2i(to_target(s)), s->as_quoted_ascii());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   920
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   921
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   922
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   923
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   924
class RelocateBufferToTarget: public BitMapClosure {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   925
  DynamicArchiveBuilder *_builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   926
  address* _buffer_bottom;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   927
  intx _buffer_to_target_delta;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   928
 public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   929
  RelocateBufferToTarget(DynamicArchiveBuilder* builder, address* bottom, intx delta) :
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   930
    _builder(builder), _buffer_bottom(bottom), _buffer_to_target_delta(delta) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   931
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   932
  bool do_bit(size_t offset) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   933
    address* p = _buffer_bottom + offset;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   934
    assert(_builder->is_in_buffer_space(p), "pointer must live in buffer space");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   935
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   936
    address old_ptr = *p;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   937
    if (_builder->is_in_buffer_space(old_ptr)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   938
      address new_ptr = old_ptr + _buffer_to_target_delta;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   939
      log_trace(cds, dynamic)("Final patch: @%6d [" PTR_FORMAT " -> " PTR_FORMAT "] " PTR_FORMAT " => " PTR_FORMAT,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   940
                              (int)offset, p2i(p), p2i(_builder->to_target(p)),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   941
                              p2i(old_ptr), p2i(new_ptr));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   942
      *p = new_ptr;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   943
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   944
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   945
    return true; // keep iterating
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   946
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   947
};
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   948
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   949
void DynamicArchiveBuilder::relocate_buffer_to_target() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   950
  RelocateBufferToTarget patcher(this, (address*)_alloc_bottom, _buffer_to_target_delta);
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   951
  ArchivePtrMarker::ptrmap()->iterate(&patcher);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   952
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   953
  Array<u8>* table = FileMapInfo::shared_path_table().table();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   954
  SharedPathTable runtime_table(to_target(table), FileMapInfo::shared_path_table().size());
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   955
  _header->set_shared_path_table(runtime_table);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   956
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   957
  address relocatable_base = (address)SharedBaseAddress;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   958
  address relocatable_end = (address)(current_dump_space()->top()) + _buffer_to_target_delta;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   959
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   960
  intx addr_delta = MetaspaceShared::final_delta();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   961
  if (addr_delta == 0) {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   962
    ArchivePtrMarker::compact(relocatable_base, relocatable_end);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   963
  } else {
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   964
    // The base archive is NOT mapped at Arguments::default_SharedBaseAddress() (due to ASLR).
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   965
    // This means that the current content of the dynamic archive is based on a random
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   966
    // address. Let's relocate all the pointers, so that it can be mapped to
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   967
    // Arguments::default_SharedBaseAddress() without runtime relocation.
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   968
    //
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   969
    // Note: both the base and dynamic archive are written with
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   970
    // FileMapHeader::_shared_base_address == Arguments::default_SharedBaseAddress()
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   971
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   972
    // Patch all pointers that are marked by ptrmap within this region,
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   973
    // where we have just dumped all the metaspace data.
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   974
    address patch_base = (address)_alloc_bottom;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   975
    address patch_end  = (address)current_dump_space()->top();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
   976
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   977
    // the current value of the pointers to be patched must be within this
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   978
    // range (i.e., must point to either the top archive (as currently mapped), or to the
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   979
    // (targeted address of) the top archive)
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   980
    address valid_old_base = relocatable_base;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   981
    address valid_old_end  = relocatable_end;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   982
    size_t base_plus_top_size = valid_old_end - valid_old_base;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   983
    size_t top_size = patch_end - patch_base;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   984
    size_t base_size = base_plus_top_size - top_size;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   985
    assert(base_plus_top_size > base_size, "no overflow");
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   986
    assert(base_plus_top_size > top_size, "no overflow");
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   987
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   988
    // after patching, the pointers must point inside this range
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   989
    // (the requested location of the archive, as mapped at runtime).
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   990
    address valid_new_base = (address)Arguments::default_SharedBaseAddress();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   991
    address valid_new_end  = valid_new_base + base_plus_top_size;
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   992
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   993
    log_debug(cds)("Relocating archive from [" INTPTR_FORMAT " - " INTPTR_FORMAT "] to "
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   994
                   "[" INTPTR_FORMAT " - " INTPTR_FORMAT "], delta = " INTX_FORMAT " bytes",
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   995
                   p2i(patch_base + base_size), p2i(patch_end),
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   996
                   p2i(valid_new_base + base_size), p2i(valid_new_end), addr_delta);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   997
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   998
    SharedDataRelocator<true> patcher((address*)patch_base, (address*)patch_end, valid_old_base, valid_old_end,
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
   999
                                      valid_new_base, valid_new_end, addr_delta, ArchivePtrMarker::ptrmap());
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
  1000
    ArchivePtrMarker::ptrmap()->iterate(&patcher);
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
  1001
    ArchivePtrMarker::compact(patcher.max_non_null_offset());
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
  1002
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1003
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1004
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58096
diff changeset
  1005
void DynamicArchiveBuilder::write_regions(FileMapInfo* dynamic_info) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1006
  dynamic_info->write_region(MetaspaceShared::rw,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1007
                             MetaspaceShared::read_write_dump_space()->base(),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1008
                             MetaspaceShared::read_write_dump_space()->used(),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1009
                             /*read_only=*/false,/*allow_exec=*/false);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1010
  dynamic_info->write_region(MetaspaceShared::ro,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1011
                             MetaspaceShared::read_only_dump_space()->base(),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1012
                             MetaspaceShared::read_only_dump_space()->used(),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1013
                             /*read_only=*/true, /*allow_exec=*/false);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1014
  dynamic_info->write_region(MetaspaceShared::mc,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1015
                             MetaspaceShared::misc_code_dump_space()->base(),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1016
                             MetaspaceShared::misc_code_dump_space()->used(),
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1017
                             /*read_only=*/false,/*allow_exec=*/true);
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
  1018
  dynamic_info->write_bitmap_region(ArchivePtrMarker::ptrmap());
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1019
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1020
58278
e47b459b315c 8231278: Rename FileMapHeader::_read_only_tables_start to _serialized_data_start
iklam
parents: 58277
diff changeset
  1021
void DynamicArchiveBuilder::write_archive(char* serialized_data_start) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1022
  int num_klasses = _klasses->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1023
  int num_symbols = _symbols->length();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1024
58278
e47b459b315c 8231278: Rename FileMapHeader::_read_only_tables_start to _serialized_data_start
iklam
parents: 58277
diff changeset
  1025
  _header->set_serialized_data_start(to_target(serialized_data_start));
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1026
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1027
  FileMapInfo* dynamic_info = FileMapInfo::dynamic_info();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1028
  assert(dynamic_info != NULL, "Sanity");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1029
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1030
  // Now write the archived data including the file offsets.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1031
  const char* archive_name = Arguments::GetSharedDynamicArchivePath();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1032
  dynamic_info->open_for_write(archive_name);
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58096
diff changeset
  1033
  write_regions(dynamic_info);
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
  1034
  dynamic_info->set_final_requested_base((char*)Arguments::default_SharedBaseAddress());
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58096
diff changeset
  1035
  dynamic_info->set_header_crc(dynamic_info->compute_header_crc());
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58096
diff changeset
  1036
  dynamic_info->write_header();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1037
  dynamic_info->close();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1038
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1039
  address base = to_target(_alloc_bottom);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1040
  address top  = address(current_dump_space()->top()) + _buffer_to_target_delta;
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
  1041
  size_t file_size = pointer_delta(top, base, sizeof(char));
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1042
59070
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
  1043
  base += MetaspaceShared::final_delta();
22ee476cc664 8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents: 59056
diff changeset
  1044
  top += MetaspaceShared::final_delta();
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
  1045
  log_info(cds, dynamic)("Written dynamic archive " PTR_FORMAT " - " PTR_FORMAT
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
  1046
                         " [" SIZE_FORMAT " bytes header, " SIZE_FORMAT " bytes total]",
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
  1047
                         p2i(base), p2i(top), _header->header_size(), file_size);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1048
  log_info(cds, dynamic)("%d klasses; %d symbols", num_klasses, num_symbols);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1049
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1050
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1051
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1052
class VM_PopulateDynamicDumpSharedSpace: public VM_Operation {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1053
  DynamicArchiveBuilder* _builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1054
public:
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1055
  VM_PopulateDynamicDumpSharedSpace(DynamicArchiveBuilder* builder) : _builder(builder) {}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1056
  VMOp_Type type() const { return VMOp_PopulateDumpSharedSpace; }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1057
  void doit() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1058
    ResourceMark rm;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1059
    if (SystemDictionaryShared::empty_dumptime_table()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1060
      log_warning(cds, dynamic)("There is no class to be included in the dynamic archive.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1061
      return;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1062
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1063
    if (AllowArchivingWithJavaAgent) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1064
      warning("This archive was created with AllowArchivingWithJavaAgent. It should be used "
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1065
              "for testing purposes only and should not be used in a production environment");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1066
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1067
    FileMapInfo::check_nonempty_dir_in_shared_path_table();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1068
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1069
    _builder->doit();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1070
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1071
};
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1072
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1073
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1074
void DynamicArchive::dump() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1075
  if (Arguments::GetSharedDynamicArchivePath() == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1076
    log_warning(cds, dynamic)("SharedDynamicArchivePath is not specified");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1077
    return;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1078
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1079
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1080
  DynamicArchiveBuilder builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1081
  _builder = &builder;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1082
  VM_PopulateDynamicDumpSharedSpace op(&builder);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1083
  VMThread::execute(&op);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1084
  _builder = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1085
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1086
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1087
address DynamicArchive::original_to_buffer_impl(address orig_obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1088
  assert(DynamicDumpSharedSpaces, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1089
  address buff_obj = _builder->get_new_loc(orig_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1090
  assert(buff_obj != NULL, "orig_obj must be used by the dynamic archive");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1091
  assert(buff_obj != orig_obj, "call this only when you know orig_obj must be copied and not just referenced");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1092
  assert(_builder->is_in_buffer_space(buff_obj), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1093
  return buff_obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1094
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1095
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1096
address DynamicArchive::buffer_to_target_impl(address buff_obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1097
  assert(DynamicDumpSharedSpaces, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1098
  assert(_builder->is_in_buffer_space(buff_obj), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1099
  return _builder->to_target(buff_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1100
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1101
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1102
address DynamicArchive::original_to_target_impl(address orig_obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1103
  assert(DynamicDumpSharedSpaces, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1104
  if (MetaspaceShared::is_in_shared_metaspace(orig_obj)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1105
    // This happens when the top archive points to a Symbol* in the base archive.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1106
    return orig_obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1107
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1108
  address buff_obj = _builder->get_new_loc(orig_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1109
  assert(buff_obj != NULL, "orig_obj must be used by the dynamic archive");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1110
  if (buff_obj == orig_obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1111
    // We are storing a pointer to an original object into the dynamic buffer. E.g.,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1112
    // a Symbol* that used by both the base and top archives.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1113
    assert(MetaspaceShared::is_in_shared_metaspace(orig_obj), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1114
    return orig_obj;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1115
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1116
    return _builder->to_target(buff_obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1117
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1118
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1119
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1120
uintx DynamicArchive::object_delta_uintx(void* buff_obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1121
  assert(DynamicDumpSharedSpaces, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1122
  address target_obj = _builder->to_target_no_check(address(buff_obj));
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1123
  assert(uintx(target_obj) >= SharedBaseAddress, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1124
  return uintx(target_obj) - SharedBaseAddress;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1125
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1126
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1127
bool DynamicArchive::is_in_target_space(void *obj) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1128
  assert(DynamicDumpSharedSpaces, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1129
  return _builder->is_in_target_space(obj);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1130
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1131
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1132
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1133
DynamicArchiveBuilder* DynamicArchive::_builder = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1134
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1135
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1136
bool DynamicArchive::validate(FileMapInfo* dynamic_info) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1137
  // Check if the recorded base archive matches with the current one
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1138
  FileMapInfo* base_info = FileMapInfo::current_info();
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
  1139
  DynamicArchiveHeader* dynamic_header = dynamic_info->dynamic_header();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1140
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1141
  // Check the header crc
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
  1142
  if (dynamic_header->base_header_crc() != base_info->crc()) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1143
    FileMapInfo::fail_continue("Archive header checksum verification failed.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1144
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1145
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1146
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1147
  // Check each space's crc
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1148
  for (int i = 0; i < MetaspaceShared::n_regions; i++) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 55134
diff changeset
  1149
    if (dynamic_header->base_region_crc(i) != base_info->space_crc(i)) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1150
      FileMapInfo::fail_continue("Archive region #%d checksum verification failed.", i);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1151
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1152
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1153
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1154
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1155
  // Validate the dynamic archived shared path table, and set the global
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1156
  // _shared_path_table to that.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1157
  if (!dynamic_info->validate_shared_path_table()) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1158
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1159
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1160
  return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents:
diff changeset
  1161
}