src/hotspot/share/memory/filemap.cpp
author ccheung
Wed, 02 Oct 2019 16:55:08 -0700
changeset 58447 319173c62caa
parent 58277 00a98f0aa1b3
child 58494 54c1ba464b78
child 58679 9c3209ff7550
child 59070 22ee476cc664
permissions -rw-r--r--
8231606: _method_ordering is not set during CDS dynamic dump time Summary: Add the missing DynamicDumpSharedSpaces check in sort_methods(); replace the (DumpSharedSpaces || DynamicDumpSharedSpaces) with the Arguments::is_dumping_archive() function call. Reviewed-by: iklam, coleenp, jiangli
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
     2
 * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 2131
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 2131
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 2131
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    25
#include "precompiled.hpp"
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47599
diff changeset
    26
#include "jvm.h"
54340
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
    27
#include "classfile/classFileStream.hpp"
49340
4e82736053ae 8191102: Incorrect include file use in classLoader.hpp
hseigel
parents: 48962
diff changeset
    28
#include "classfile/classLoader.inline.hpp"
54340
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
    29
#include "classfile/classLoaderData.inline.hpp"
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
    30
#include "classfile/classLoaderExt.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    31
#include "classfile/symbolTable.hpp"
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
    32
#include "classfile/systemDictionaryShared.hpp"
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
    33
#include "classfile/altHashing.hpp"
46522
86b13b03a053 8176132: -XX:+PrintSharedSpaces should be converted to use Unified Logging.
rprotacio
parents: 42876
diff changeset
    34
#include "logging/log.hpp"
46701
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46630
diff changeset
    35
#include "logging/logStream.hpp"
46522
86b13b03a053 8176132: -XX:+PrintSharedSpaces should be converted to use Unified Logging.
rprotacio
parents: 42876
diff changeset
    36
#include "logging/logMessage.hpp"
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
    37
#include "memory/dynamicArchive.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    38
#include "memory/filemap.hpp"
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
    39
#include "memory/heapShared.inline.hpp"
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
    40
#include "memory/iterator.inline.hpp"
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
    41
#include "memory/metadataFactory.hpp"
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
    42
#include "memory/metaspaceClosure.hpp"
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
    43
#include "memory/metaspaceShared.hpp"
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
    44
#include "memory/oopFactory.hpp"
54825
1b03400e5a8f 8223637: Fix build breakage after 8223136
stefank
parents: 54780
diff changeset
    45
#include "memory/universe.hpp"
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
    46
#include "oops/compressedOops.hpp"
49592
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49340
diff changeset
    47
#include "oops/compressedOops.inline.hpp"
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
    48
#include "oops/objArrayOop.hpp"
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
    49
#include "oops/oop.inline.hpp"
31332
dc17890f352d 8054386: Allow Java debugging when CDS is enabled
cjplummer
parents: 28950
diff changeset
    50
#include "prims/jvmtiExport.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    51
#include "runtime/arguments.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    52
#include "runtime/java.hpp"
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
    53
#include "runtime/mutexLocker.hpp"
51480
2e928420389d 8209826: Undefined reference to os::write after JDK-8209657 (filemap.hpp cleanup)
iklam
parents: 51477
diff changeset
    54
#include "runtime/os.inline.hpp"
25715
d5a8dbdc5150 8049325: Introduce and clean up umbrella headers for the files in the cpu subdirectories.
goetz
parents: 24424
diff changeset
    55
#include "runtime/vm_version.hpp"
14120
7d298141c258 7199092: NMT: NMT needs to deal overlapped virtual memory ranges
zgu
parents: 13728
diff changeset
    56
#include "services/memTracker.hpp"
46625
edefffab74e2 8183552: Move align functions to align.hpp
stefank
parents: 46619
diff changeset
    57
#include "utilities/align.hpp"
57897
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
    58
#include "utilities/classpathStream.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    59
#include "utilities/defaultStream.hpp"
49982
9042ffe5b7fe 8200729: Conditional compilation of GCs
stefank
parents: 49931
diff changeset
    60
#if INCLUDE_G1GC
49592
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49340
diff changeset
    61
#include "gc/g1/g1CollectedHeap.hpp"
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
    62
#include "gc/g1/heapRegion.hpp"
49592
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49340
diff changeset
    63
#endif
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    64
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
# include <sys/stat.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
# include <errno.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
#ifndef O_BINARY       // if defined (Win32) use binary files.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
#define O_BINARY 0     // otherwise do nothing.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
extern address JVM_FunctionAtStart();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
extern address JVM_FunctionAtEnd();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 1
diff changeset
    75
// Complain and stop. All error conditions occurring during the writing of
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
// an archive file should stop the process.  Unrecoverable errors during
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
// the reading of the archive file should stop the process.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
    79
static void fail_exit(const char *msg, va_list ap) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
  // This occurs very early during initialization: tty is not initialized.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
  jio_fprintf(defaultStream::error_stream(),
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 1
diff changeset
    82
              "An error has occurred while processing the"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
              " shared archive file.\n");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
  jio_vfprintf(defaultStream::error_stream(), msg, ap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  jio_fprintf(defaultStream::error_stream(), "\n");
19707
fecaabc8e462 8023381: VM fails to initialize in runtime/CDSCompressedKPtrs/XShareAuto.java runtime/SharedArchiveFile/CdsSameObjectAlignment.java
hseigel
parents: 19319
diff changeset
    86
  // Do not change the text of the below message because some tests check for it.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
  vm_exit_during_initialization("Unable to use shared archive.", NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
void FileMapInfo::fail_stop(const char *msg, ...) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
        va_list ap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
  va_start(ap, msg);
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
    94
  fail_exit(msg, ap);   // Never returns.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
  va_end(ap);           // for completeness.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
// Complain and continue.  Recoverable errors during the reading of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
// archive file may continue (with sharing disabled).
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
// If we continue, then disable shared spaces and close the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
void FileMapInfo::fail_continue(const char *msg, ...) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
  va_list ap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
  va_start(ap, msg);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   107
  if (_dynamic_archive_info == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   108
    MetaspaceShared::set_archive_loading_failed();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   109
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   110
    // _dynamic_archive_info has been setup after mapping the base archive
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   111
    DynamicArchive::disable();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   112
  }
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   113
  if (PrintSharedArchiveAndExit && _validating_shared_path_table) {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   114
    // If we are doing PrintSharedArchiveAndExit and some of the classpath entries
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   115
    // do not validate, we can still continue "limping" to validate the remaining
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   116
    // entries. No need to quit.
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   117
    tty->print("[");
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   118
    tty->vprint(msg, ap);
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   119
    tty->print_cr("]");
23186
9396c6fb571b 8033990: Add message to verbose output to indicate when JVM was unable to use shared archive (with -Xshare:auto)
mseledtsov
parents: 19707
diff changeset
   120
  } else {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   121
    if (RequireSharedSpaces) {
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   122
      fail_exit(msg, ap);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   123
    } else {
46522
86b13b03a053 8176132: -XX:+PrintSharedSpaces should be converted to use Unified Logging.
rprotacio
parents: 42876
diff changeset
   124
      if (log_is_enabled(Info, cds)) {
86b13b03a053 8176132: -XX:+PrintSharedSpaces should be converted to use Unified Logging.
rprotacio
parents: 42876
diff changeset
   125
        ResourceMark rm;
46701
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46630
diff changeset
   126
        LogStream ls(Log(cds)::info());
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46630
diff changeset
   127
        ls.print("UseSharedSpaces: ");
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46630
diff changeset
   128
        ls.vprint_cr(msg, ap);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   129
      }
23186
9396c6fb571b 8033990: Add message to verbose output to indicate when JVM was unable to use shared archive (with -Xshare:auto)
mseledtsov
parents: 19707
diff changeset
   130
    }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   131
    if (_dynamic_archive_info == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   132
      UseSharedSpaces = false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   133
      assert(current_info() != NULL, "singleton must be registered");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   134
      current_info()->close();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   135
    } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   136
      // We are failing when loading the top archive, but the base archive should
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   137
      // continue to work.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   138
      log_warning(cds, dynamic)("Unable to use shared archive. The top archive failed to load: %s", _dynamic_archive_info->_full_path);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   139
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
  va_end(ap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   144
// Fill in the fileMapInfo structure with data about this VM instance.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   146
// This method copies the vm version info into header_version.  If the version is too
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   147
// long then a truncated version, which has a hash code appended to it, is copied.
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   148
//
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   149
// Using a template enables this method to verify that header_version is an array of
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   150
// length JVM_IDENT_MAX.  This ensures that the code that writes to the CDS file and
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   151
// the code that reads the CDS file will both use the same size buffer.  Hence, will
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   152
// use identical truncation.  This is necessary for matching of truncated versions.
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   153
template <int N> static void get_header_version(char (&header_version) [N]) {
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   154
  assert(N == JVM_IDENT_MAX, "Bad header_version size");
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   155
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   156
  const char *vm_version = VM_Version::internal_vm_info_string();
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   157
  const int version_len = (int)strlen(vm_version);
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   158
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   159
  memset(header_version, 0, JVM_IDENT_MAX);
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   160
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   161
  if (version_len < (JVM_IDENT_MAX-1)) {
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   162
    strcpy(header_version, vm_version);
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   163
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   164
  } else {
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   165
    // Get the hash value.  Use a static seed because the hash needs to return the same
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   166
    // value over multiple jvm invocations.
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   167
    unsigned int hash = AltHashing::murmur3_32(8191, (const jbyte*)vm_version, version_len);
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   168
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   169
    // Truncate the ident, saving room for the 8 hex character hash value.
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   170
    strncpy(header_version, vm_version, JVM_IDENT_MAX-9);
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   171
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   172
    // Append the hash code as eight hex digits.
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   173
    sprintf(&header_version[JVM_IDENT_MAX-9], "%08x", hash);
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   174
    header_version[JVM_IDENT_MAX-1] = 0;  // Null terminate.
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   175
  }
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   176
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   177
  assert(header_version[JVM_IDENT_MAX-1] == 0, "must be");
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   178
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   180
FileMapInfo::FileMapInfo(bool is_static) {
46630
75aa3e39d02c 8182299: Enable disabled clang warnings, build on OSX 10 + Xcode 8
jwilhelm
parents: 46625
diff changeset
   181
  memset((void*)this, 0, sizeof(FileMapInfo));
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   182
  _is_static = is_static;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   183
  size_t header_size;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   184
  if (is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   185
    assert(_current_info == NULL, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   186
    _current_info = this;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   187
    header_size = sizeof(FileMapHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   188
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   189
    assert(_dynamic_archive_info == NULL, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   190
    _dynamic_archive_info = this;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   191
    header_size = sizeof(DynamicArchiveHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   192
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   193
  _header = (FileMapHeader*)os::malloc(header_size, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   194
  memset((void*)_header, 0, header_size);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   195
  _header->set_header_size(header_size);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   196
  _header->set_version(INVALID_CDS_ARCHIVE_VERSION);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   197
  _header->set_has_platform_or_app_classes(true);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   198
  _file_offset = 0;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   199
  _file_open = false;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   200
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   201
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   202
FileMapInfo::~FileMapInfo() {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   203
  if (_is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   204
    assert(_current_info == this, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   205
    _current_info = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   206
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   207
    assert(_dynamic_archive_info == this, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   208
    _dynamic_archive_info = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   209
  }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   210
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   211
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   212
void FileMapInfo::populate_header(size_t alignment) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   213
  header()->populate(this, alignment);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   214
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   215
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
   216
void FileMapHeader::populate(FileMapInfo* mapinfo, size_t alignment) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   217
  if (DynamicDumpSharedSpaces) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   218
    _magic = CDS_DYNAMIC_ARCHIVE_MAGIC;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   219
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   220
    _magic = CDS_ARCHIVE_MAGIC;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   221
  }
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
   222
  _version = CURRENT_CDS_ARCHIVE_VERSION;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   223
  _alignment = alignment;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   224
  _obj_alignment = ObjectAlignmentInBytes;
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
   225
  _compact_strings = CompactStrings;
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   226
  _narrow_oop_mode = CompressedOops::mode();
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   227
  _narrow_oop_base = CompressedOops::base();
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   228
  _narrow_oop_shift = CompressedOops::shift();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
   229
  _max_heap_size = MaxHeapSize;
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   230
  _narrow_klass_base = CompressedKlassPointers::base();
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   231
  _narrow_klass_shift = CompressedKlassPointers::shift();
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   232
  _shared_path_table = mapinfo->_shared_path_table;
52062
8dbf1a13af49 8206009: Move CDS java heap object archiving code to heapShared.hpp and heapShared.cpp
jiangli
parents: 51823
diff changeset
   233
  if (HeapShared::is_heap_object_archiving_allowed()) {
58015
dd84de796f2c 8224815: Remove non-GC uses of CollectedHeap::is_in_reserved()
eosterlund
parents: 57898
diff changeset
   234
    _heap_end = CompressedOops::end();
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
   235
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
  // The following fields are for sanity checks for whether this archive
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
  // will function correctly with this JVM and the bootclasspath it's
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
  // invoked with.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
  // JVM version string ... changes on each build.
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   242
  get_header_version(_jvm_ident);
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   243
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   244
  _app_class_paths_start_index = ClassLoaderExt::app_class_paths_start_index();
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   245
  _app_module_paths_start_index = ClassLoaderExt::app_module_paths_start_index();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   246
  _num_module_paths = ClassLoader::num_module_path_entries();
51439
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   247
  _max_used_path_index = ClassLoaderExt::max_used_path_index();
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   248
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   249
  _verify_local = BytecodeVerificationLocal;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   250
  _verify_remote = BytecodeVerificationRemote;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   251
  _has_platform_or_app_classes = ClassLoaderExt::has_platform_or_app_classes();
52514
f4e3900c8d08 8213346: Re-implement shared dictionary using CompactHashtable
iklam
parents: 52402
diff changeset
   252
  _shared_base_address = SharedBaseAddress;
52596
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
   253
  _allow_archiving_with_java_agent = AllowArchivingWithJavaAgent;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   254
  // the following 2 fields will be set in write_header for dynamic archive header
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   255
  _base_archive_name_size = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   256
  _base_archive_is_default = false;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   257
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   258
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   259
void SharedClassPathEntry::init_as_non_existent(const char* path, TRAPS) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   260
  _type = non_existent_entry;
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   261
  set_name(path, THREAD);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   262
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   263
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   264
void SharedClassPathEntry::init(bool is_modules_image,
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   265
                                ClassPathEntry* cpe, TRAPS) {
58447
319173c62caa 8231606: _method_ordering is not set during CDS dynamic dump time
ccheung
parents: 58277
diff changeset
   266
  Arguments::assert_is_dumping_archive();
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   267
  _timestamp = 0;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   268
  _filesize  = 0;
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   269
  _from_class_path_attr = false;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   270
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   271
  struct stat st;
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   272
  if (os::stat(cpe->name(), &st) == 0) {
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   273
    if ((st.st_mode & S_IFMT) == S_IFDIR) {
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   274
      _type = dir_entry;
40013
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
   275
    } else {
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   276
      // The timestamp of the modules_image is not checked at runtime.
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   277
      if (is_modules_image) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   278
        _type = modules_image_entry;
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   279
      } else {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   280
        _type = jar_entry;
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   281
        _timestamp = st.st_mtime;
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   282
        _from_class_path_attr = cpe->from_class_path_attr();
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   283
      }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   284
      _filesize = st.st_size;
40013
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
   285
    }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   286
  } else {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   287
    // The file/dir must exist, or it would not have been added
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   288
    // into ClassLoader::classpath_entry().
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   289
    //
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   290
    // If we can't access a jar file in the boot path, then we can't
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   291
    // make assumptions about where classes get loaded from.
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   292
    FileMapInfo::fail_stop("Unable to open file %s.", cpe->name());
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   293
  }
40013
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
   294
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   295
  // No need to save the name of the module file, as it will be computed at run time
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   296
  // to allow relocation of the JDK directory.
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   297
  const char* name = is_modules_image  ? "" : cpe->name();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   298
  set_name(name, THREAD);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   299
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   300
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   301
void SharedClassPathEntry::set_name(const char* name, TRAPS) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   302
  size_t len = strlen(name) + 1;
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   303
  _name = MetadataFactory::new_array<char>(ClassLoaderData::the_null_class_loader_data(), (int)len, THREAD);
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   304
  strcpy(_name->data(), name);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   305
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   307
const char* SharedClassPathEntry::name() const {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   308
  if (UseSharedSpaces && is_modules_image()) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   309
    // In order to validate the runtime modules image file size against the archived
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   310
    // size information, we need to obtain the runtime modules image path. The recorded
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   311
    // dump time modules image path in the archive may be different from the runtime path
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   312
    // if the JDK image has beed moved after generating the archive.
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   313
    return ClassLoader::get_jrt_entry()->name();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   314
  } else {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   315
    return _name->data();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   316
  }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   317
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   318
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   319
bool SharedClassPathEntry::validate(bool is_class_path) const {
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   320
  assert(UseSharedSpaces, "runtime only");
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   321
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   322
  struct stat st;
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   323
  const char* name = this->name();
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   324
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   325
  bool ok = true;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   326
  log_info(class, path)("checking shared classpath entry: %s", name);
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   327
  if (os::stat(name, &st) != 0 && is_class_path) {
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   328
    // If the archived module path entry does not exist at runtime, it is not fatal
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   329
    // (no need to invalid the shared archive) because the shared runtime visibility check
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   330
    // filters out any archived module classes that do not have a matching runtime
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   331
    // module path location.
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   332
    FileMapInfo::fail_continue("Required classpath entry does not exist: %s", name);
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   333
    ok = false;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   334
  } else if (is_dir()) {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   335
    if (!os::dir_is_empty(name)) {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   336
      FileMapInfo::fail_continue("directory is not empty: %s", name);
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   337
      ok = false;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   338
    }
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   339
  } else if ((has_timestamp() && _timestamp != st.st_mtime) ||
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   340
             _filesize != st.st_size) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   341
    ok = false;
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   342
    if (PrintSharedArchiveAndExit) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   343
      FileMapInfo::fail_continue(_timestamp != st.st_mtime ?
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   344
                                 "Timestamp mismatch" :
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   345
                                 "File size mismatch");
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   346
    } else {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   347
      FileMapInfo::fail_continue("A jar file is not the one used while building"
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   348
                                 " the shared archive file: %s", name);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
    }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   350
  }
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   351
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   352
  if (PrintSharedArchiveAndExit && !ok) {
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   353
    // If PrintSharedArchiveAndExit is enabled, don't report failure to the
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   354
    // caller. Please see above comments for more details.
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   355
    ok = true;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   356
    MetaspaceShared::set_archive_loading_failed();
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   357
  }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   358
  return ok;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   359
}
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   360
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   361
bool SharedClassPathEntry::check_non_existent() const {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   362
  assert(_type == non_existent_entry, "must be");
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   363
  log_info(class, path)("should be non-existent: %s", name());
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   364
  struct stat st;
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   365
  if (os::stat(name(), &st) != 0) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   366
    log_info(class, path)("ok");
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   367
    return true; // file doesn't exist
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   368
  } else {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   369
    return false;
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   370
  }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   371
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   372
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   373
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   374
void SharedClassPathEntry::metaspace_pointers_do(MetaspaceClosure* it) {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   375
  it->push(&_name);
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   376
  it->push(&_manifest);
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   377
}
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   378
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   379
void SharedPathTable::metaspace_pointers_do(MetaspaceClosure* it) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   380
  it->push(&_table);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   381
  for (int i=0; i<_size; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   382
    path_at(i)->metaspace_pointers_do(it);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   383
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   384
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   385
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   386
void SharedPathTable::dumptime_init(ClassLoaderData* loader_data, Thread* THREAD) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   387
  size_t entry_size = sizeof(SharedClassPathEntry);
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   388
  int num_entries = 0;
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   389
  num_entries += ClassLoader::num_boot_classpath_entries();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   390
  num_entries += ClassLoader::num_app_classpath_entries();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   391
  num_entries += ClassLoader::num_module_path_entries();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   392
  num_entries += FileMapInfo::num_non_existent_class_paths();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   393
  size_t bytes = entry_size * num_entries;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   394
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   395
  _table = MetadataFactory::new_array<u8>(loader_data, (int)(bytes + 7 / 8), THREAD);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   396
  _size = num_entries;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   397
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   398
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   399
void FileMapInfo::allocate_shared_path_table() {
58447
319173c62caa 8231606: _method_ordering is not set during CDS dynamic dump time
ccheung
parents: 58277
diff changeset
   400
  Arguments::assert_is_dumping_archive();
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   401
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   402
  EXCEPTION_MARK; // The following calls should never throw, but would exit VM on error.
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   403
  ClassLoaderData* loader_data = ClassLoaderData::the_null_class_loader_data();
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   404
  ClassPathEntry* jrt = ClassLoader::get_jrt_entry();
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   405
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   406
  assert(jrt != NULL,
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   407
         "No modular java runtime image present when allocating the CDS classpath entry table");
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   408
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   409
  _shared_path_table.dumptime_init(loader_data, THREAD);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   410
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   411
  // 1. boot class path
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   412
  int i = 0;
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   413
  i = add_shared_classpaths(i, "boot",   jrt, THREAD);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   414
  i = add_shared_classpaths(i, "app",    ClassLoader::app_classpath_entries(), THREAD);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   415
  i = add_shared_classpaths(i, "module", ClassLoader::module_path_entries(), THREAD);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   416
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   417
  for (int x = 0; x < num_non_existent_class_paths(); x++, i++) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   418
    const char* path = _non_existent_class_paths->at(x);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   419
    shared_path(i)->init_as_non_existent(path, THREAD);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   420
  }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   421
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   422
  assert(i == _shared_path_table.size(), "number of shared path entry mismatch");
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   423
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   424
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   425
int FileMapInfo::add_shared_classpaths(int i, const char* which, ClassPathEntry *cpe, TRAPS) {
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   426
  while (cpe != NULL) {
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   427
    bool is_jrt = (cpe == ClassLoader::get_jrt_entry());
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   428
    const char* type = (is_jrt ? "jrt" : (cpe->is_jar_file() ? "jar" : "dir"));
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   429
    log_info(class, path)("add %s shared path (%s) %s", which, type, cpe->name());
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   430
    SharedClassPathEntry* ent = shared_path(i);
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   431
    ent->init(is_jrt, cpe, THREAD);
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   432
    if (cpe->is_jar_file()) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   433
      update_jar_manifest(cpe, ent, THREAD);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   434
    }
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   435
    if (is_jrt) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   436
      cpe = ClassLoader::get_next_boot_classpath_entry(cpe);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   437
    } else {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   438
      cpe = cpe->next();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   439
    }
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   440
    i++;
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   441
  }
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   442
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   443
  return i;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   445
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   446
void FileMapInfo::check_nonempty_dir_in_shared_path_table() {
58447
319173c62caa 8231606: _method_ordering is not set during CDS dynamic dump time
ccheung
parents: 58277
diff changeset
   447
  Arguments::assert_is_dumping_archive();
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   448
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   449
  bool has_nonempty_dir = false;
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   450
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   451
  int last = _shared_path_table.size() - 1;
51439
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   452
  if (last > ClassLoaderExt::max_used_path_index()) {
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   453
     // no need to check any path beyond max_used_path_index
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   454
     last = ClassLoaderExt::max_used_path_index();
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   455
  }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   456
51439
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   457
  for (int i = 0; i <= last; i++) {
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   458
    SharedClassPathEntry *e = shared_path(i);
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   459
    if (e->is_dir()) {
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   460
      const char* path = e->name();
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   461
      if (!os::dir_is_empty(path)) {
58110
85e1de070bef 8186988: use log_warning() and log_error() instead of tty->print_cr for CDS warning and error messages
ccheung
parents: 58096
diff changeset
   462
        log_error(cds)("Error: non-empty directory '%s'", path);
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   463
        has_nonempty_dir = true;
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   464
      }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   465
    }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   466
  }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   467
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   468
  if (has_nonempty_dir) {
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   469
    ClassLoader::exit_with_path_failure("Cannot have non-empty directory in paths", NULL);
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   470
  }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   471
}
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   472
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   473
void FileMapInfo::record_non_existent_class_path_entry(const char* path) {
58447
319173c62caa 8231606: _method_ordering is not set during CDS dynamic dump time
ccheung
parents: 58277
diff changeset
   474
  Arguments::assert_is_dumping_archive();
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   475
  log_info(class, path)("non-existent Class-Path entry %s", path);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   476
  if (_non_existent_class_paths == NULL) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   477
    _non_existent_class_paths = new (ResourceObj::C_HEAP, mtInternal)GrowableArray<const char*>(10, true);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   478
  }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   479
  _non_existent_class_paths->append(os::strdup(path));
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   480
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   481
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   482
int FileMapInfo::num_non_existent_class_paths() {
58447
319173c62caa 8231606: _method_ordering is not set during CDS dynamic dump time
ccheung
parents: 58277
diff changeset
   483
  Arguments::assert_is_dumping_archive();
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   484
  if (_non_existent_class_paths != NULL) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   485
    return _non_existent_class_paths->length();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   486
  } else {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   487
    return 0;
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   488
  }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   489
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   490
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   491
class ManifestStream: public ResourceObj {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   492
  private:
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   493
  u1*   _buffer_start; // Buffer bottom
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   494
  u1*   _buffer_end;   // Buffer top (one past last element)
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   495
  u1*   _current;      // Current buffer position
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   496
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   497
 public:
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   498
  // Constructor
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   499
  ManifestStream(u1* buffer, int length) : _buffer_start(buffer),
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   500
                                           _current(buffer) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   501
    _buffer_end = buffer + length;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   502
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   503
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   504
  static bool is_attr(u1* attr, const char* name) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   505
    return strncmp((const char*)attr, name, strlen(name)) == 0;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   506
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   507
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   508
  static char* copy_attr(u1* value, size_t len) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   509
    char* buf = NEW_RESOURCE_ARRAY(char, len + 1);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   510
    strncpy(buf, (char*)value, len);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   511
    buf[len] = 0;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   512
    return buf;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   513
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   514
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   515
  // The return value indicates if the JAR is signed or not
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   516
  bool check_is_signed() {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   517
    u1* attr = _current;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   518
    bool isSigned = false;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   519
    while (_current < _buffer_end) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   520
      if (*_current == '\n') {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   521
        *_current = '\0';
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   522
        u1* value = (u1*)strchr((char*)attr, ':');
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   523
        if (value != NULL) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   524
          assert(*(value+1) == ' ', "Unrecognized format" );
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   525
          if (strstr((char*)attr, "-Digest") != NULL) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   526
            isSigned = true;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   527
            break;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   528
          }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   529
        }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   530
        *_current = '\n'; // restore
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   531
        attr = _current + 1;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   532
      }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   533
      _current ++;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   534
    }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   535
    return isSigned;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   536
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   537
};
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   538
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   539
void FileMapInfo::update_jar_manifest(ClassPathEntry *cpe, SharedClassPathEntry* ent, TRAPS) {
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   540
  ClassLoaderData* loader_data = ClassLoaderData::the_null_class_loader_data();
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   541
  ResourceMark rm(THREAD);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   542
  jint manifest_size;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   543
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   544
  assert(cpe->is_jar_file() && ent->is_jar(), "the shared class path entry is not a JAR file");
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   545
  char* manifest = ClassLoaderExt::read_manifest(cpe, &manifest_size, CHECK);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   546
  if (manifest != NULL) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   547
    ManifestStream* stream = new ManifestStream((u1*)manifest,
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   548
                                                manifest_size);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   549
    if (stream->check_is_signed()) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   550
      ent->set_is_signed();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   551
    } else {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   552
      // Copy the manifest into the shared archive
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   553
      manifest = ClassLoaderExt::read_raw_manifest(cpe, &manifest_size, CHECK);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   554
      Array<u1>* buf = MetadataFactory::new_array<u1>(loader_data,
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   555
                                                      manifest_size,
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   556
                                                      THREAD);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   557
      char* p = (char*)(buf->data());
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   558
      memcpy(p, manifest, manifest_size);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   559
      ent->set_manifest(buf);
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   560
    }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   561
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   562
}
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   563
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   564
char* FileMapInfo::skip_first_path_entry(const char* path) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   565
  size_t path_sep_len = strlen(os::path_separator());
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   566
  char* p = strstr((char*)path, os::path_separator());
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   567
  if (p != NULL) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   568
    debug_only( {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   569
      size_t image_name_len = strlen(MODULES_IMAGE_NAME);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   570
      assert(strncmp(p - image_name_len, MODULES_IMAGE_NAME, image_name_len) == 0,
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   571
             "first entry must be the modules image");
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   572
    } );
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   573
    p += path_sep_len;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   574
  } else {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   575
    debug_only( {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   576
      assert(ClassLoader::string_ends_with(path, MODULES_IMAGE_NAME),
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   577
             "first entry must be the modules image");
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   578
    } );
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   579
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   580
  return p;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   581
}
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   582
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   583
int FileMapInfo::num_paths(const char* path) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   584
  if (path == NULL) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   585
    return 0;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   586
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   587
  int npaths = 1;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   588
  char* p = (char*)path;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   589
  while (p != NULL) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   590
    char* prev = p;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   591
    p = strstr((char*)p, os::path_separator());
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   592
    if (p != NULL) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   593
      p++;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   594
      // don't count empty path
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   595
      if ((p - prev) > 1) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   596
       npaths++;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   597
      }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   598
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   599
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   600
  return npaths;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   601
}
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   602
57897
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   603
GrowableArray<const char*>* FileMapInfo::create_path_array(const char* paths) {
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   604
  GrowableArray<const char*>* path_array =  new(ResourceObj::RESOURCE_AREA, mtInternal)
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   605
      GrowableArray<const char*>(10);
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   606
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   607
  ClasspathStream cp_stream(paths);
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   608
  while (cp_stream.has_next()) {
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   609
    const char* path = cp_stream.get_next();
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   610
    struct stat st;
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   611
    if (os::stat(path, &st) == 0) {
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   612
      path_array->append(path);
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   613
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   614
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   615
  return path_array;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   616
}
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   617
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   618
bool FileMapInfo::fail(const char* msg, const char* name) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   619
  ClassLoader::trace_class_path(msg, name);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   620
  MetaspaceShared::set_archive_loading_failed();
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   621
  return false;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   622
}
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   623
57897
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   624
bool FileMapInfo::check_paths(int shared_path_start_idx, int num_paths, GrowableArray<const char*>* rp_array) {
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   625
  int i = 0;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   626
  int j = shared_path_start_idx;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   627
  bool mismatch = false;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   628
  while (i < num_paths && !mismatch) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   629
    while (shared_path(j)->from_class_path_attr()) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   630
      // shared_path(j) was expanded from the JAR file attribute "Class-Path:"
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   631
      // during dump time. It's not included in the -classpath VM argument.
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   632
      j++;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   633
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   634
    if (!os::same_files(shared_path(j)->name(), rp_array->at(i))) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   635
      mismatch = true;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   636
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   637
    i++;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   638
    j++;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   639
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   640
  return mismatch;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   641
}
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   642
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   643
bool FileMapInfo::validate_boot_class_paths() {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   644
  //
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   645
  // - Archive contains boot classes only - relaxed boot path check:
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   646
  //   Extra path elements appended to the boot path at runtime are allowed.
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   647
  //
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   648
  // - Archive contains application or platform classes - strict boot path check:
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   649
  //   Validate the entire runtime boot path, which must be compatible
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   650
  //   with the dump time boot path. Appending boot path at runtime is not
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   651
  //   allowed.
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   652
  //
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   653
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   654
  // The first entry in boot path is the modules_image (guaranteed by
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   655
  // ClassLoader::setup_boot_search_path()). Skip the first entry. The
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   656
  // path of the runtime modules_image may be different from the dump
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   657
  // time path (e.g. the JDK image is copied to a different location
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   658
  // after generating the shared archive), which is acceptable. For most
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   659
  // common cases, the dump time boot path might contain modules_image only.
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   660
  char* runtime_boot_path = Arguments::get_sysclasspath();
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   661
  char* rp = skip_first_path_entry(runtime_boot_path);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   662
  assert(shared_path(0)->is_modules_image(), "first shared_path must be the modules image");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   663
  int dp_len = header()->app_class_paths_start_index() - 1; // ignore the first path to the module image
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   664
  bool mismatch = false;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   665
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   666
  bool relaxed_check = !header()->has_platform_or_app_classes();
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   667
  if (dp_len == 0 && rp == NULL) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   668
    return true;   // ok, both runtime and dump time boot paths have modules_images only
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   669
  } else if (dp_len == 0 && rp != NULL) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   670
    if (relaxed_check) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   671
      return true;   // ok, relaxed check, runtime has extra boot append path entries
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   672
    } else {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   673
      mismatch = true;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   674
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   675
  } else if (dp_len > 0 && rp != NULL) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   676
    int num;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   677
    ResourceMark rm;
57897
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   678
    GrowableArray<const char*>* rp_array = create_path_array(rp);
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   679
    int rp_len = rp_array->length();
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   680
    if (rp_len >= dp_len) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   681
      if (relaxed_check) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   682
        // only check the leading entries in the runtime boot path, up to
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   683
        // the length of the dump time boot path
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   684
        num = dp_len;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   685
      } else {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   686
        // check the full runtime boot path, must match with dump time
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   687
        num = rp_len;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   688
      }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   689
      mismatch = check_paths(1, num, rp_array);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   690
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   691
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   692
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   693
  if (mismatch) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   694
    // The paths are different
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   695
    return fail("[BOOT classpath mismatch, actual =", runtime_boot_path);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   696
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   697
  return true;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   698
}
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   699
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   700
bool FileMapInfo::validate_app_class_paths(int shared_app_paths_len) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   701
  const char *appcp = Arguments::get_appclasspath();
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   702
  assert(appcp != NULL, "NULL app classpath");
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   703
  int rp_len = num_paths(appcp);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   704
  bool mismatch = false;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   705
  if (rp_len < shared_app_paths_len) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   706
    return fail("Run time APP classpath is shorter than the one at dump time: ", appcp);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   707
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   708
  if (shared_app_paths_len != 0 && rp_len != 0) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   709
    // Prefix is OK: E.g., dump with -cp foo.jar, but run with -cp foo.jar:bar.jar.
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   710
    ResourceMark rm;
57897
e2e315f1aa63 8230168: Use ClasspathStream for FileMapInfo::create_path_array
iklam
parents: 57584
diff changeset
   711
    GrowableArray<const char*>* rp_array = create_path_array(appcp);
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   712
    if (rp_array->length() == 0) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   713
      // None of the jar file specified in the runtime -cp exists.
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   714
      return fail("None of the jar file specified in the runtime -cp exists: -Djava.class.path=", appcp);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   715
    }
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   716
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   717
    // Handling of non-existent entries in the classpath: we eliminate all the non-existent
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   718
    // entries from both the dump time classpath (ClassLoader::update_class_path_entry_list)
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   719
    // and the runtime classpath (FileMapInfo::create_path_array), and check the remaining
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   720
    // entries. E.g.:
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   721
    //
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   722
    // dump : -cp a.jar:NE1:NE2:b.jar  -> a.jar:b.jar -> recorded in archive.
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   723
    // run 1: -cp NE3:a.jar:NE4:b.jar  -> a.jar:b.jar -> matched
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   724
    // run 2: -cp x.jar:NE4:b.jar      -> x.jar:b.jar -> mismatched
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   725
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   726
    int j = header()->app_class_paths_start_index();
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   727
    mismatch = check_paths(j, shared_app_paths_len, rp_array);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   728
    if (mismatch) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   729
      return fail("[APP classpath mismatch, actual: -Djava.class.path=", appcp);
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   730
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   731
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   732
  return true;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   733
}
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   734
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   735
void FileMapInfo::log_paths(const char* msg, int start_idx, int end_idx) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   736
  LogTarget(Info, class, path) lt;
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   737
  if (lt.is_enabled()) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   738
    LogStream ls(lt);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   739
    ls.print("%s", msg);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   740
    const char* prefix = "";
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   741
    for (int i = start_idx; i < end_idx; i++) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   742
      ls.print("%s%s", prefix, shared_path(i)->name());
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   743
      prefix = os::path_separator();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   744
    }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   745
    ls.cr();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   746
  }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   747
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   748
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   749
bool FileMapInfo::validate_shared_path_table() {
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   750
  assert(UseSharedSpaces, "runtime only");
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   751
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   752
  _validating_shared_path_table = true;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   753
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   754
  // Load the shared path table info from the archive header
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   755
  _shared_path_table = header()->shared_path_table();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   756
  if (DynamicDumpSharedSpaces) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   757
    // Only support dynamic dumping with the usage of the default CDS archive
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   758
    // or a simple base archive.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   759
    // If the base layer archive contains additional path component besides
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   760
    // the runtime image and the -cp, dynamic dumping is disabled.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   761
    //
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   762
    // When dynamic archiving is enabled, the _shared_path_table is overwritten
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   763
    // to include the application path and stored in the top layer archive.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   764
    assert(shared_path(0)->is_modules_image(), "first shared_path must be the modules image");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   765
    if (header()->app_class_paths_start_index() > 1) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   766
      DynamicDumpSharedSpaces = false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   767
      warning(
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   768
        "Dynamic archiving is disabled because base layer archive has appended boot classpath");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   769
    }
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   770
    if (header()->num_module_paths() > 0) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   771
      DynamicDumpSharedSpaces = false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   772
      warning(
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   773
        "Dynamic archiving is disabled because base layer archive has module path");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   774
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   775
  }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   776
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   777
  log_paths("Expecting BOOT path=", 0, header()->app_class_paths_start_index());
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   778
  log_paths("Expecting -Djava.class.path=", header()->app_class_paths_start_index(), header()->app_module_paths_start_index());
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   779
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   780
  int module_paths_start_index = header()->app_module_paths_start_index();
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   781
  int shared_app_paths_len = 0;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   782
51439
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   783
  // validate the path entries up to the _max_used_path_index
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   784
  for (int i=0; i < header()->max_used_path_index() + 1; i++) {
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   785
    if (i < module_paths_start_index) {
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   786
      if (shared_path(i)->validate()) {
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   787
        // Only count the app class paths not from the "Class-path" attribute of a jar manifest.
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   788
        if (!shared_path(i)->from_class_path_attr() && i >= header()->app_class_paths_start_index()) {
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   789
          shared_app_paths_len++;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   790
        }
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   791
        log_info(class, path)("ok");
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   792
      } else {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   793
        if (_dynamic_archive_info != NULL && _dynamic_archive_info->_is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   794
          assert(!UseSharedSpaces, "UseSharedSpaces should be disabled");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   795
        }
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   796
        return false;
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   797
      }
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   798
    } else if (i >= module_paths_start_index) {
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   799
      if (shared_path(i)->validate(false /* not a class path entry */)) {
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   800
        log_info(class, path)("ok");
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   801
      } else {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   802
        if (_dynamic_archive_info != NULL && _dynamic_archive_info->_is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   803
          assert(!UseSharedSpaces, "UseSharedSpaces should be disabled");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   804
        }
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   805
        return false;
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   806
      }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   807
    }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   808
  }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   809
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   810
  if (header()->max_used_path_index() == 0) {
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   811
    // default archive only contains the module image in the bootclasspath
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   812
    assert(shared_path(0)->is_modules_image(), "first shared_path must be the modules image");
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   813
  } else {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   814
    if (!validate_boot_class_paths() || !validate_app_class_paths(shared_app_paths_len)) {
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   815
      fail_continue("shared class paths mismatch (hint: enable -Xlog:class+path=info to diagnose the failure)");
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   816
      return false;
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   817
    }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   818
  }
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
   819
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   820
  validate_non_existent_class_paths();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   821
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   822
  _validating_shared_path_table = false;
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   823
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   824
#if INCLUDE_JVMTI
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   825
  if (_classpath_entries_for_jvmti != NULL) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   826
    os::free(_classpath_entries_for_jvmti);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   827
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   828
  size_t sz = sizeof(ClassPathEntry*) * get_number_of_shared_paths();
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   829
  _classpath_entries_for_jvmti = (ClassPathEntry**)os::malloc(sz, mtClass);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   830
  memset((void*)_classpath_entries_for_jvmti, 0, sz);
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   831
#endif
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   832
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   833
  return true;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   834
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   835
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   836
void FileMapInfo::validate_non_existent_class_paths() {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   837
  // All of the recorded non-existent paths came from the Class-Path: attribute from the JAR
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   838
  // files on the app classpath. If any of these are found to exist during runtime,
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   839
  // it will change how classes are loading for the app loader. For safety, disable
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   840
  // loading of archived platform/app classes (currently there's no way to disable just the
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   841
  // app classes).
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   842
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   843
  assert(UseSharedSpaces, "runtime only");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   844
  for (int i = header()->app_module_paths_start_index() + header()->num_module_paths();
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   845
       i < get_number_of_shared_paths();
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   846
       i++) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   847
    SharedClassPathEntry* ent = shared_path(i);
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   848
    if (!ent->check_non_existent()) {
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   849
      warning("Archived non-system classes are disabled because the "
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   850
              "file %s exists", ent->name());
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   851
      header()->set_has_platform_or_app_classes(false);
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   852
    }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   853
  }
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   854
}
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
   855
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   856
bool FileMapInfo::check_archive(const char* archive_name, bool is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   857
  int fd = os::open(archive_name, O_RDONLY | O_BINARY, 0);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   858
  if (fd < 0) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   859
    // do not vm_exit_during_initialization here because Arguments::init_shared_archive_paths()
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   860
    // requires a shared archive name. The open_for_read() function will log a message regarding
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   861
    // failure in opening a shared archive.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   862
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   863
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   864
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   865
  size_t sz = is_static ? sizeof(FileMapHeader) : sizeof(DynamicArchiveHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   866
  void* header = os::malloc(sz, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   867
  memset(header, 0, sz);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   868
  size_t n = os::read(fd, header, (unsigned int)sz);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   869
  if (n != sz) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   870
    os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   871
    os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   872
    vm_exit_during_initialization("Unable to read header from shared archive", archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   873
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   874
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   875
  if (is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   876
    FileMapHeader* static_header = (FileMapHeader*)header;
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   877
    if (static_header->magic() != CDS_ARCHIVE_MAGIC) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   878
      os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   879
      os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   880
      vm_exit_during_initialization("Not a base shared archive", archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   881
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   882
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   883
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   884
    DynamicArchiveHeader* dynamic_header = (DynamicArchiveHeader*)header;
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   885
    if (dynamic_header->magic() != CDS_DYNAMIC_ARCHIVE_MAGIC) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   886
      os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   887
      os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   888
      vm_exit_during_initialization("Not a top shared archive", archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   889
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   890
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   891
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   892
  os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   893
  os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   894
  return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   895
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   896
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   897
bool FileMapInfo::get_base_archive_name_from_header(const char* archive_name,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   898
                                                    int* size, char** base_archive_name) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   899
  int fd = os::open(archive_name, O_RDONLY | O_BINARY, 0);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   900
  if (fd < 0) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   901
    *size = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   902
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   903
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   904
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   905
  // read the header as a dynamic archive header
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   906
  size_t sz = sizeof(DynamicArchiveHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   907
  DynamicArchiveHeader* dynamic_header = (DynamicArchiveHeader*)os::malloc(sz, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   908
  size_t n = os::read(fd, dynamic_header, (unsigned int)sz);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   909
  if (n != sz) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   910
    fail_continue("Unable to read the file header.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   911
    os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   912
    os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   913
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   914
  }
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   915
  if (dynamic_header->magic() != CDS_DYNAMIC_ARCHIVE_MAGIC) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   916
    // Not a dynamic header, no need to proceed further.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   917
    *size = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   918
    os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   919
    os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   920
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   921
  }
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   922
  if (dynamic_header->base_archive_is_default()) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   923
    *base_archive_name = Arguments::get_default_shared_archive_path();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   924
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   925
    // read the base archive name
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   926
    size_t name_size = dynamic_header->base_archive_name_size();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   927
    if (name_size == 0) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   928
      os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   929
      os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   930
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   931
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   932
    *base_archive_name = NEW_C_HEAP_ARRAY(char, name_size, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   933
    n = os::read(fd, *base_archive_name, (unsigned int)name_size);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   934
    if (n != name_size) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   935
      fail_continue("Unable to read the base archive name from the header.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   936
      FREE_C_HEAP_ARRAY(char, *base_archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   937
      *base_archive_name = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   938
      os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   939
      os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   940
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   941
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   942
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   943
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   944
  os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   945
  os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   946
  return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   947
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   948
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   949
void FileMapInfo::restore_shared_path_table() {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   950
  _shared_path_table = _current_info->header()->shared_path_table();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   951
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   952
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
// Read the FileMapInfo information from the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   954
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   955
bool FileMapInfo::init_from_file(int fd, bool is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   956
  size_t sz = is_static ? sizeof(FileMapHeader) : sizeof(DynamicArchiveHeader);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   957
  size_t n = os::read(fd, header(), (unsigned int)sz);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   958
  if (n != sz) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   959
    fail_continue("Unable to read the file header.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   960
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   961
  }
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   962
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   963
  if (!Arguments::has_jimage()) {
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   964
    FileMapInfo::fail_continue("The shared archive file cannot be used with an exploded module build.");
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   965
    return false;
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   966
  }
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   967
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   968
  unsigned int expected_magic = is_static ? CDS_ARCHIVE_MAGIC : CDS_DYNAMIC_ARCHIVE_MAGIC;
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   969
  if (header()->magic() != expected_magic) {
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   970
    log_info(cds)("_magic expected: 0x%08x", expected_magic);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   971
    log_info(cds)("         actual: 0x%08x", header()->magic());
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   972
    FileMapInfo::fail_continue("The shared archive file has a bad magic number.");
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   973
    return false;
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   974
  }
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   975
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   976
  if (header()->version() != CURRENT_CDS_ARCHIVE_VERSION) {
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   977
    log_info(cds)("_version expected: %d", CURRENT_CDS_ARCHIVE_VERSION);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   978
    log_info(cds)("           actual: %d", header()->version());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   979
    fail_continue("The shared archive file has the wrong version.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   980
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   981
  }
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   982
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   983
  if (header()->header_size() != sz) {
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   984
    log_info(cds)("_header_size expected: " SIZE_FORMAT, sz);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   985
    log_info(cds)("               actual: " SIZE_FORMAT, header()->header_size());
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   986
    FileMapInfo::fail_continue("The shared archive file has an incorrect header size.");
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   987
    return false;
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   988
  }
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   989
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   990
  const char* actual_ident = header()->jvm_ident();
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   991
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   992
  if (actual_ident[JVM_IDENT_MAX-1] != 0) {
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   993
    FileMapInfo::fail_continue("JVM version identifier is corrupted.");
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   994
    return false;
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   995
  }
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
   996
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   997
  char expected_ident[JVM_IDENT_MAX];
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   998
  get_header_version(expected_ident);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
   999
  if (strncmp(actual_ident, expected_ident, JVM_IDENT_MAX-1) != 0) {
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1000
    log_info(cds)("_jvm_ident expected: %s", expected_ident);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1001
    log_info(cds)("             actual: %s", actual_ident);
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1002
    FileMapInfo::fail_continue("The shared archive file was created by a different"
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1003
                  " version or build of HotSpot");
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1004
    return false;
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1005
  }
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1006
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1007
  if (VerifySharedSpaces) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1008
    int expected_crc = header()->compute_crc();
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1009
    if (expected_crc != header()->crc()) {
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1010
      log_info(cds)("_crc expected: %d", expected_crc);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1011
      log_info(cds)("       actual: %d", header()->crc());
55694
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1012
      FileMapInfo::fail_continue("Header checksum verification failed.");
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1013
      return false;
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1014
    }
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1015
  }
7b7df2be6219 8226406: JVM fails to detect mismatched or corrupt CDS archive
ccheung
parents: 55296
diff changeset
  1016
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1017
  _file_offset = n + header()->base_archive_name_size(); // accounts for the size of _base_archive_name
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1018
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1019
  if (is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1020
    // just checking the last region is sufficient since the archive is written
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1021
    // in sequential order
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1022
    size_t len = lseek(fd, 0, SEEK_END);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1023
    FileMapRegion* si = space_at(MetaspaceShared::last_valid_region);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1024
    // The last space might be empty
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1025
    if (si->file_offset() > len || len - si->file_offset() < si->used()) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1026
      fail_continue("The shared archive file has been truncated.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1027
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1028
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1029
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1030
    SharedBaseAddress = header()->shared_base_address();
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1031
  }
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1032
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1033
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1034
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1035
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1036
void FileMapInfo::seek_to_position(size_t pos) {
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1037
  if (lseek(_fd, (long)pos, SEEK_SET) < 0) {
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1038
    fail_stop("Unable to seek to position " SIZE_FORMAT, pos);
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1039
  }
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1040
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1041
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1042
// Read the FileMapInfo information from the file.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1043
bool FileMapInfo::open_for_read(const char* path) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1044
  if (_file_open) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1045
    return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1046
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1047
  if (path == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1048
    _full_path = Arguments::GetSharedArchivePath();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1049
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1050
    _full_path = path;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1051
  }
53911
65f2a401e0eb 8218811: replace open by os::open in hotspot coding
mbaesken
parents: 53884
diff changeset
  1052
  int fd = os::open(_full_path, O_RDONLY | O_BINARY, 0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1053
  if (fd < 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1054
    if (errno == ENOENT) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1055
      // Not locating the shared archive is ok.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1056
      fail_continue("Specified shared archive not found (%s).", _full_path);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1057
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1058
      fail_continue("Failed to open shared archive file (%s).",
37113
5a33bf5089ac 8148425: strerror() function is not thread-safe
stuefe
parents: 36364
diff changeset
  1059
                    os::strerror(errno));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1060
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1061
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1062
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1063
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1064
  _fd = fd;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1065
  _file_open = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1066
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1067
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1068
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1069
// Write the FileMapInfo information to the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1070
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1071
void FileMapInfo::open_for_write(const char* path) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1072
  if (path == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1073
    _full_path = Arguments::GetSharedArchivePath();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1074
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1075
    _full_path = path;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1076
  }
48962
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
  1077
  LogMessage(cds) msg;
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
  1078
  if (msg.is_info()) {
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
  1079
    msg.info("Dumping shared data to file: ");
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
  1080
    msg.info("   %s", _full_path);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1081
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1082
15461
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
  1083
#ifdef _WINDOWS  // On Windows, need WRITE permission to remove the file.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1084
    chmod(_full_path, _S_IREAD | _S_IWRITE);
15461
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
  1085
#endif
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
  1086
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
  1087
  // Use remove() to delete the existing file because, on Unix, this will
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
  1088
  // allow processes that have it open continued access to the file.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1089
  remove(_full_path);
53911
65f2a401e0eb 8218811: replace open by os::open in hotspot coding
mbaesken
parents: 53884
diff changeset
  1090
  int fd = os::open(_full_path, O_RDWR | O_CREAT | O_TRUNC | O_BINARY, 0444);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1091
  if (fd < 0) {
28950
693ae3d5e1ff 8072694: Need errno info when CDS archive creation fails
hseigel
parents: 28023
diff changeset
  1092
    fail_stop("Unable to create shared archive file %s: (%s).", _full_path,
37113
5a33bf5089ac 8148425: strerror() function is not thread-safe
stuefe
parents: 36364
diff changeset
  1093
              os::strerror(errno));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1094
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1095
  _fd = fd;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1096
  _file_open = true;
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1097
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1098
  // Seek past the header. We will write the header after all regions are written
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1099
  // and their CRCs computed.
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1100
  size_t header_bytes = header()->header_size();
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1101
  if (header()->magic() == CDS_DYNAMIC_ARCHIVE_MAGIC) {
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1102
    header_bytes += strlen(Arguments::GetSharedArchivePath()) + 1;
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1103
  }
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1104
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1105
  header_bytes = align_up(header_bytes, os::vm_allocation_granularity());
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1106
  _file_offset = header_bytes;
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1107
  seek_to_position(_file_offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1108
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1109
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1110
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1111
// Write the header to the file, seek to the next allocation boundary.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1112
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1113
void FileMapInfo::write_header() {
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1114
  _file_offset = 0;
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1115
  seek_to_position(_file_offset);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1116
  char* base_archive_name = NULL;
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1117
  if (header()->magic() == CDS_DYNAMIC_ARCHIVE_MAGIC) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1118
    base_archive_name = (char*)Arguments::GetSharedArchivePath();
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1119
    header()->set_base_archive_name_size(strlen(base_archive_name) + 1);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1120
    header()->set_base_archive_is_default(FLAG_IS_DEFAULT(SharedArchiveFile));
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1121
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1122
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1123
  assert(is_file_position_aligned(), "must be");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1124
  write_bytes(header(), header()->header_size());
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1125
  if (base_archive_name != NULL) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1126
    write_bytes(base_archive_name, header()->base_archive_name_size());
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1127
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1128
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1129
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1130
void FileMapRegion::init(bool is_heap_region, char* base, size_t size, bool read_only,
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1131
                         bool allow_exec, int crc) {
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1132
  _is_heap_region = is_heap_region;
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1133
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1134
  if (is_heap_region) {
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1135
    assert(!DynamicDumpSharedSpaces, "must be");
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1136
    assert((base - (char*)CompressedKlassPointers::base()) % HeapWordSize == 0, "Sanity");
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1137
    if (base != NULL) {
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1138
      _addr._offset = (intx)CompressedOops::encode_not_null((oop)base);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1139
    } else {
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1140
      _addr._offset = 0;
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1141
    }
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1142
  } else {
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1143
    _addr._base = base;
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1144
  }
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1145
  _used = size;
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1146
  _read_only = read_only;
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1147
  _allow_exec = allow_exec;
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1148
  _crc = crc;
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1149
}
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1150
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
void FileMapInfo::write_region(int region, char* base, size_t size,
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1152
                               bool read_only, bool allow_exec) {
58447
319173c62caa 8231606: _method_ordering is not set during CDS dynamic dump time
ccheung
parents: 58277
diff changeset
  1153
  Arguments::assert_is_dumping_archive();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1154
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1155
  FileMapRegion* si = space_at(region);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1156
  char* target_base = base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1157
  if (DynamicDumpSharedSpaces) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1158
    assert(!HeapShared::is_heap_region(region), "dynamic archive doesn't support heap regions");
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1159
    target_base = DynamicArchive::buffer_to_target(base);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1160
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1162
  si->set_file_offset(_file_offset);
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1163
  log_info(cds)("Shared file region %d: " SIZE_FORMAT_HEX_W(08)
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1164
                " bytes, addr " INTPTR_FORMAT " file offset " SIZE_FORMAT_HEX_W(08),
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1165
                region, size, p2i(target_base), _file_offset);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1166
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1167
  int crc = ClassLoader::crc32(0, base, (jint)size);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1168
  si->init(HeapShared::is_heap_region(region), target_base, size, read_only, allow_exec, crc);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1169
51070
2f4c3cac8556 8206977: Minor improvements of runtime code.
goetz
parents: 50199
diff changeset
  1170
  if (base != NULL) {
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1171
    write_bytes_aligned(base, size);
51070
2f4c3cac8556 8206977: Minor improvements of runtime code.
goetz
parents: 50199
diff changeset
  1172
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1173
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1175
// Write out the given archive heap memory regions.  GC code combines multiple
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1176
// consecutive archive GC regions into one MemRegion whenever possible and
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1177
// produces the 'heap_mem' array.
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1178
//
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1179
// If the archive heap memory size is smaller than a single dump time GC region
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1180
// size, there is only one MemRegion in the array.
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1181
//
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1182
// If the archive heap memory size is bigger than one dump time GC region size,
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1183
// the 'heap_mem' array may contain more than one consolidated MemRegions. When
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1184
// the first/bottom archive GC region is a partial GC region (with the empty
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1185
// portion at the higher address within the region), one MemRegion is used for
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1186
// the bottom partial archive GC region. The rest of the consecutive archive
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1187
// GC regions are combined into another MemRegion.
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1188
//
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1189
// Here's the mapping from (archive heap GC regions) -> (GrowableArray<MemRegion> *regions).
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1190
//   + We have 1 or more archive heap regions: ah0, ah1, ah2 ..... ahn
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1191
//   + We have 1 or 2 consolidated heap memory regions: r0 and r1
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1192
//
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1193
// If there's a single archive GC region (ah0), then r0 == ah0, and r1 is empty.
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1194
// Otherwise:
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1195
//
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1196
// "X" represented space that's occupied by heap objects.
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1197
// "_" represented unused spaced in the heap region.
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1198
//
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1199
//
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1200
//    |ah0       | ah1 | ah2| ...... | ahn|
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1201
//    |XXXXXX|__ |XXXXX|XXXX|XXXXXXXX|XXXX|
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1202
//    |<-r0->|   |<- r1 ----------------->|
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1203
//            ^^^
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1204
//             |
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1205
//             +-- gap
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1206
size_t FileMapInfo::write_archive_heap_regions(GrowableArray<MemRegion> *heap_mem,
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1207
                                               GrowableArray<ArchiveHeapOopmapInfo> *oopmaps,
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1208
                                               int first_region_id, int max_num_regions) {
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1209
  assert(max_num_regions <= 2, "Only support maximum 2 memory regions");
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1210
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1211
  int arr_len = heap_mem == NULL ? 0 : heap_mem->length();
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1212
  if(arr_len > max_num_regions) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1213
    fail_stop("Unable to write archive heap memory regions: "
52811
ff04b71bf6f1 8214388: CDS dumping fails with java heap fragmentation
iklam
parents: 52702
diff changeset
  1214
              "number of memory regions exceeds maximum due to fragmentation. "
52702
10c6e9066819 8214217: [TESTBUG] runtime/appcds/LotsOfClasses.java failed with fragmented heap
jiangli
parents: 52674
diff changeset
  1215
              "Please increase java heap size "
10c6e9066819 8214217: [TESTBUG] runtime/appcds/LotsOfClasses.java failed with fragmented heap
jiangli
parents: 52674
diff changeset
  1216
              "(current MaxHeapSize is " SIZE_FORMAT ", InitialHeapSize is " SIZE_FORMAT ").",
10c6e9066819 8214217: [TESTBUG] runtime/appcds/LotsOfClasses.java failed with fragmented heap
jiangli
parents: 52674
diff changeset
  1217
              MaxHeapSize, InitialHeapSize);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1218
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1219
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1220
  size_t total_size = 0;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1221
  for (int i = first_region_id, arr_idx = 0;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1222
           i < first_region_id + max_num_regions;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1223
           i++, arr_idx++) {
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1224
    char* start = NULL;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1225
    size_t size = 0;
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1226
    if (arr_idx < arr_len) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1227
      start = (char*)heap_mem->at(arr_idx).start();
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1228
      size = heap_mem->at(arr_idx).byte_size();
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1229
      total_size += size;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1230
    }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1231
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1232
    log_info(cds)("Archive heap region %d " INTPTR_FORMAT " - " INTPTR_FORMAT " = " SIZE_FORMAT_W(8) " bytes",
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1233
                  i, p2i(start), p2i(start + size), size);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1234
    write_region(i, start, size, false, false);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1235
    if (size > 0) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1236
      space_at(i)->init_oopmap(oopmaps->at(arr_idx)._oopmap,
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1237
                               oopmaps->at(arr_idx)._oopmap_size_in_bits);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1238
    }
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1239
  }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1240
  return total_size;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1241
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1242
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
// Dump bytes to file -- at the current file position.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1244
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1245
void FileMapInfo::write_bytes(const void* buffer, size_t nbytes) {
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1246
  assert(_file_open, "must be");
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1247
  size_t n = os::write(_fd, buffer, (unsigned int)nbytes);
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1248
  if (n != nbytes) {
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1249
    // If the shared archive is corrupted, close it and remove it.
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1250
    close();
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1251
    remove(_full_path);
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1252
    fail_stop("Unable to write to shared archive file.");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1253
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1254
  _file_offset += nbytes;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1256
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1257
bool FileMapInfo::is_file_position_aligned() const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1258
  return _file_offset == align_up(_file_offset,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1259
                                  os::vm_allocation_granularity());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1260
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1261
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1262
// Align file position to an allocation unit boundary.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
void FileMapInfo::align_file_position() {
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1265
  assert(_file_open, "must be");
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1266
  size_t new_file_offset = align_up(_file_offset,
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1267
                                    os::vm_allocation_granularity());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1268
  if (new_file_offset != _file_offset) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1269
    _file_offset = new_file_offset;
58277
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1270
    // Seek one byte back from the target and write a byte to insure
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1271
    // that the written file is the correct length.
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1272
    _file_offset -= 1;
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1273
    seek_to_position(_file_offset);
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1274
    char zero = 0;
00a98f0aa1b3 8231257: Avoid calling FileMapInfo::write_region twice
iklam
parents: 58110
diff changeset
  1275
    write_bytes(&zero, 1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1276
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1277
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1278
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1279
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
// Dump bytes to file -- at the current file position.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1281
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1282
void FileMapInfo::write_bytes_aligned(const void* buffer, size_t nbytes) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
  align_file_position();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1284
  write_bytes(buffer, nbytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1285
  align_file_position();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1286
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1287
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1288
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1289
// Close the shared archive file.  This does NOT unmap mapped regions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1290
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1291
void FileMapInfo::close() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
  if (_file_open) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1293
    if (::close(_fd) < 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
      fail_stop("Unable to close the shared archive file.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1296
    _file_open = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1297
    _fd = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1300
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1302
// JVM/TI RedefineClasses() support:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1303
// Remap the shared readonly space to shared readwrite, private.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1304
bool FileMapInfo::remap_shared_readonly_as_readwrite() {
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1305
  int idx = MetaspaceShared::ro;
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1306
  FileMapRegion* si = space_at(idx);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1307
  if (!si->read_only()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1308
    // the space is already readwrite so we are done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1309
    return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1310
  }
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1311
  size_t used = si->used();
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1312
  size_t size = align_up(used, os::vm_allocation_granularity());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1313
  if (!open_for_read()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1314
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1315
  }
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1316
  char *addr = region_addr(idx);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1317
  char *base = os::remap_memory(_fd, _full_path, si->file_offset(),
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1318
                                addr, size, false /* !read_only */,
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1319
                                si->allow_exec());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1320
  close();
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1321
  // These have to be errors because the shared region is now unmapped.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1322
  if (base == NULL) {
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1323
    log_error(cds)("Unable to remap shared readonly space (errno=%d).", errno);
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1324
    vm_exit(1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1325
  }
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1326
  if (base != addr) {
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1327
    log_error(cds)("Unable to remap shared readonly space (errno=%d).", errno);
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1328
    vm_exit(1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1329
  }
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1330
  si->set_read_only(false);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1331
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1332
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1333
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1334
// Map the whole region at once, assumed to be allocated contiguously.
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1335
ReservedSpace FileMapInfo::reserve_shared_memory() {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1336
  char* requested_addr = region_addr(0);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1337
  size_t size = FileMapInfo::core_spaces_size();
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1338
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1339
  // Reserve the space first, then map otherwise map will go right over some
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1340
  // other reserved memory (like the code cache).
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1341
  ReservedSpace rs(size, os::vm_allocation_granularity(), false, requested_addr);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1342
  if (!rs.is_reserved()) {
33148
68fa8b6c4340 8042893: compiler: PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC needs to be removed from source files
david
parents: 32589
diff changeset
  1343
    fail_continue("Unable to reserve shared space at required address "
68fa8b6c4340 8042893: compiler: PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC needs to be removed from source files
david
parents: 32589
diff changeset
  1344
                  INTPTR_FORMAT, p2i(requested_addr));
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1345
    return rs;
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1346
  }
14120
7d298141c258 7199092: NMT: NMT needs to deal overlapped virtual memory ranges
zgu
parents: 13728
diff changeset
  1347
  // the reserved virtual memory is for mapping class data sharing archive
15100
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1348
  MemTracker::record_virtual_memory_type((address)rs.base(), mtClassShared);
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1349
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1350
  return rs;
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1351
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1352
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1353
// Memory map a region in the address space.
55296
357c9dcb6eb9 8224497: Remove FIXME in metaspaceClosure.cpp
ccheung
parents: 54927
diff changeset
  1354
static const char* shared_region_name[] = { "MiscData", "ReadWrite", "ReadOnly", "MiscCode",
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1355
                                            "String1", "String2", "OpenArchive1", "OpenArchive2" };
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1357
char* FileMapInfo::map_regions(int regions[], char* saved_base[], size_t len) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1358
  char* prev_top = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1359
  char* curr_base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1360
  char* curr_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1361
  int i = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1362
  for (i = 0; i < (int)len; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1363
    curr_base = map_region(regions[i], &curr_top);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1364
    if (curr_base == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1365
      return NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1366
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1367
    if (i > 0) {
55296
357c9dcb6eb9 8224497: Remove FIXME in metaspaceClosure.cpp
ccheung
parents: 54927
diff changeset
  1368
      // We require that mc->rw->ro->md to be laid out consecutively, with no
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1369
      // gaps between them. That way, we can ensure that the OS won't be able to
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1370
      // allocate any new memory spaces inside _shared_metaspace_{base,top}, which
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1371
      // would mess up the simple comparision in MetaspaceShared::is_in_shared_metaspace().
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1372
      assert(curr_base == prev_top, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1373
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1374
    log_info(cds)("Mapped region #%d at base %p top %p", regions[i], curr_base, curr_top);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1375
    saved_base[i] = curr_base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1376
    prev_top = curr_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1377
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1378
  return curr_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1379
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1380
48794
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1381
char* FileMapInfo::map_region(int i, char** top_ret) {
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1382
  assert(!HeapShared::is_heap_region(i), "sanity");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1383
  FileMapRegion* si = space_at(i);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1384
  size_t used = si->used();
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1385
  size_t alignment = os::vm_allocation_granularity();
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1386
  size_t size = align_up(used, alignment);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1387
  char *requested_addr = region_addr(i);
31332
dc17890f352d 8054386: Allow Java debugging when CDS is enabled
cjplummer
parents: 28950
diff changeset
  1388
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1389
#ifdef _WINDOWS
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1390
  // Windows cannot remap read-only shared memory to read-write when required for
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1391
  // RedefineClasses, which is also used by JFR.  Always map windows regions as RW.
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1392
  si->set_read_only(false);
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1393
#else
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1394
  // If a tool agent is in use (debugging enabled), or JFR, we must map the address space RW
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1395
  if (JvmtiExport::can_modify_any_class() || JvmtiExport::can_walk_any_space() ||
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1396
      Arguments::has_jfr_option()) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1397
    si->set_read_only(false);
31332
dc17890f352d 8054386: Allow Java debugging when CDS is enabled
cjplummer
parents: 28950
diff changeset
  1398
  }
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1399
#endif // _WINDOWS
31332
dc17890f352d 8054386: Allow Java debugging when CDS is enabled
cjplummer
parents: 28950
diff changeset
  1400
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1401
  // map the contents of the CDS archive in this memory
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1402
  char *base = os::map_memory(_fd, _full_path, si->file_offset(),
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1403
                              requested_addr, size, si->read_only(),
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1404
                              si->allow_exec());
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1405
  if (base == NULL || base != requested_addr) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1406
    fail_continue("Unable to map %s shared space at required address.", shared_region_name[i]);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1407
    _memory_mapping_failed = true;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1408
    return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1409
  }
15100
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1410
#ifdef _WINDOWS
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1411
  // This call is Windows-only because the memory_type gets recorded for the other platforms
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1412
  // in method FileMapInfo::reserve_shared_memory(), which is not called on Windows.
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1413
  MemTracker::record_virtual_memory_type((address)base, mtClassShared);
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1414
#endif
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1415
54838
d7819bedfaaf 8221478: Disable VerifySharedSpaces by default
redestad
parents: 54825
diff changeset
  1416
  if (VerifySharedSpaces && !verify_region_checksum(i)) {
48794
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1417
    return NULL;
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1418
  }
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1419
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1420
  *top_ret = base + size;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1421
  return base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1422
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1423
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1424
size_t FileMapInfo::read_bytes(void* buffer, size_t count) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1425
  assert(_file_open, "Archive file is not open");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1426
  size_t n = os::read(_fd, buffer, (unsigned int)count);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1427
  if (n != count) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1428
    // Close the file if there's a problem reading it.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1429
    close();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1430
    return 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1431
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1432
  _file_offset += count;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1433
  return count;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1434
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1435
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1436
address FileMapInfo::decode_start_address(FileMapRegion* spc, bool with_current_oop_encoding_mode) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1437
  if (with_current_oop_encoding_mode) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1438
    return (address)CompressedOops::decode_not_null(spc->offset());
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1439
  } else {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1440
    return (address)HeapShared::decode_from_archive(spc->offset());
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1441
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1442
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1443
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1444
static MemRegion *closed_archive_heap_ranges = NULL;
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1445
static MemRegion *open_archive_heap_ranges = NULL;
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1446
static int num_closed_archive_heap_ranges = 0;
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1447
static int num_open_archive_heap_ranges = 0;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1448
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1449
#if INCLUDE_CDS_JAVA_HEAP
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1450
bool FileMapInfo::has_heap_regions() {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1451
  return (space_at(MetaspaceShared::first_closed_archive_heap_region)->used() > 0);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1452
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1453
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1454
// Returns the address range of the archived heap regions computed using the
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1455
// current oop encoding mode. This range may be different than the one seen at
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1456
// dump time due to encoding mode differences. The result is used in determining
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1457
// if/how these regions should be relocated at run time.
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1458
MemRegion FileMapInfo::get_heap_regions_range_with_current_oop_encoding_mode() {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1459
  address start = (address) max_uintx;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1460
  address end   = NULL;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1461
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1462
  for (int i = MetaspaceShared::first_closed_archive_heap_region;
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1463
           i <= MetaspaceShared::last_valid_region;
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1464
           i++) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1465
    FileMapRegion* si = space_at(i);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1466
    size_t size = si->used();
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1467
    if (size > 0) {
51720
b7bfd64e43a6 8210523: runtime/appcds/cacheObject/DifferentHeapSizes.java crash
iklam
parents: 51491
diff changeset
  1468
      address s = start_address_as_decoded_with_current_oop_encoding_mode(si);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1469
      address e = s + size;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1470
      if (start > s) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1471
        start = s;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1472
      }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1473
      if (end < e) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1474
        end = e;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1475
      }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1476
    }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1477
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1478
  assert(end != NULL, "must have at least one used heap region");
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1479
  return MemRegion((HeapWord*)start, (HeapWord*)end);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1480
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1481
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1482
//
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1483
// Map the closed and open archive heap objects to the runtime java heap.
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1484
//
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1485
// The shared objects are mapped at (or close to ) the java heap top in
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1486
// closed archive regions. The mapped objects contain no out-going
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1487
// references to any other java heap regions. GC does not write into the
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1488
// mapped closed archive heap region.
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1489
//
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1490
// The open archive heap objects are mapped below the shared objects in
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1491
// the runtime java heap. The mapped open archive heap data only contains
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1492
// references to the shared objects and open archive objects initially.
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1493
// During runtime execution, out-going references to any other java heap
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1494
// regions may be added. GC may mark and update references in the mapped
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1495
// open archive objects.
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1496
void FileMapInfo::map_heap_regions_impl() {
52062
8dbf1a13af49 8206009: Move CDS java heap object archiving code to heapShared.hpp and heapShared.cpp
jiangli
parents: 51823
diff changeset
  1497
  if (!HeapShared::is_heap_object_archiving_allowed()) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1498
    log_info(cds)("CDS heap data is being ignored. UseG1GC, "
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1499
                  "UseCompressedOops and UseCompressedClassPointers are required.");
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1500
    return;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1501
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1502
52319
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1503
  if (JvmtiExport::should_post_class_file_load_hook() && JvmtiExport::has_early_class_hook_env()) {
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1504
    ShouldNotReachHere(); // CDS should have been disabled.
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1505
    // The archived objects are mapped at JVM start-up, but we don't know if
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1506
    // j.l.String or j.l.Class might be replaced by the ClassFileLoadHook,
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1507
    // which would make the archived String or mirror objects invalid. Let's be safe and not
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1508
    // use the archived objects. These 2 classes are loaded during the JVMTI "early" stage.
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1509
    //
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1510
    // If JvmtiExport::has_early_class_hook_env() is false, the classes of some objects
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1511
    // in the archived subgraphs may be replaced by the ClassFileLoadHook. But that's OK
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1512
    // because we won't install an archived object subgraph if the klass of any of the
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1513
    // referenced objects are replaced. See HeapShared::initialize_from_archived_subgraph().
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1514
  }
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1515
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1516
  log_info(cds)("CDS archive was created with max heap size = " SIZE_FORMAT "M, and the following configuration:",
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1517
                max_heap_size()/M);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1518
  log_info(cds)("    narrow_klass_base = " PTR_FORMAT ", narrow_klass_shift = %d",
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1519
                p2i(narrow_klass_base()), narrow_klass_shift());
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1520
  log_info(cds)("    narrow_oop_mode = %d, narrow_oop_base = " PTR_FORMAT ", narrow_oop_shift = %d",
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1521
                narrow_oop_mode(), p2i(narrow_oop_base()), narrow_oop_shift());
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1522
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1523
  log_info(cds)("The current max heap size = " SIZE_FORMAT "M, HeapRegion::GrainBytes = " SIZE_FORMAT,
58015
dd84de796f2c 8224815: Remove non-GC uses of CollectedHeap::is_in_reserved()
eosterlund
parents: 57898
diff changeset
  1524
                MaxHeapSize/M, HeapRegion::GrainBytes);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1525
  log_info(cds)("    narrow_klass_base = " PTR_FORMAT ", narrow_klass_shift = %d",
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1526
                p2i(CompressedKlassPointers::base()), CompressedKlassPointers::shift());
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1527
  log_info(cds)("    narrow_oop_mode = %d, narrow_oop_base = " PTR_FORMAT ", narrow_oop_shift = %d",
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1528
                CompressedOops::mode(), p2i(CompressedOops::base()), CompressedOops::shift());
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1529
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1530
  if (narrow_klass_base() != CompressedKlassPointers::base() ||
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1531
      narrow_klass_shift() != CompressedKlassPointers::shift()) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1532
    log_info(cds)("CDS heap data cannot be used because the archive was created with an incompatible narrow klass encoding mode.");
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1533
    return;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1534
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1535
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1536
  if (narrow_oop_mode() != CompressedOops::mode() ||
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1537
      narrow_oop_base() != CompressedOops::base() ||
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1538
      narrow_oop_shift() != CompressedOops::shift()) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1539
    log_info(cds)("CDS heap data need to be relocated because the archive was created with an incompatible oop encoding mode.");
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1540
    _heap_pointers_need_patching = true;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1541
  } else {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1542
    MemRegion range = get_heap_regions_range_with_current_oop_encoding_mode();
58015
dd84de796f2c 8224815: Remove non-GC uses of CollectedHeap::is_in_reserved()
eosterlund
parents: 57898
diff changeset
  1543
    if (!CompressedOops::is_in(range)) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1544
      log_info(cds)("CDS heap data need to be relocated because");
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1545
      log_info(cds)("the desired range " PTR_FORMAT " - "  PTR_FORMAT, p2i(range.start()), p2i(range.end()));
58015
dd84de796f2c 8224815: Remove non-GC uses of CollectedHeap::is_in_reserved()
eosterlund
parents: 57898
diff changeset
  1546
      log_info(cds)("is outside of the heap " PTR_FORMAT " - "  PTR_FORMAT, p2i(CompressedOops::begin()), p2i(CompressedOops::end()));
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1547
      _heap_pointers_need_patching = true;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1548
    }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1549
  }
47599
0fb1d501c408 8174986: CDS archived java heap region may not compatible with AOT
jiangli
parents: 47216
diff changeset
  1550
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1551
  ptrdiff_t delta = 0;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1552
  if (_heap_pointers_need_patching) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1553
    //   dumptime heap end  ------------v
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1554
    //   [      |archived heap regions| ]         runtime heap end ------v
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1555
    //                                       [   |archived heap regions| ]
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1556
    //                                  |<-----delta-------------------->|
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1557
    //
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1558
    // At dump time, the archived heap regions were near the top of the heap.
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1559
    // At run time, they may not be inside the heap, so we move them so
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1560
    // that they are now near the top of the runtime time. This can be done by
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1561
    // the simple math of adding the delta as shown above.
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1562
    address dumptime_heap_end = header()->heap_end();
58015
dd84de796f2c 8224815: Remove non-GC uses of CollectedHeap::is_in_reserved()
eosterlund
parents: 57898
diff changeset
  1563
    address runtime_heap_end = (address)CompressedOops::end();
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1564
    delta = runtime_heap_end - dumptime_heap_end;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1565
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1566
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1567
  log_info(cds)("CDS heap data relocation delta = " INTX_FORMAT " bytes", delta);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1568
  HeapShared::init_narrow_oop_decoding(narrow_oop_base() + delta, narrow_oop_shift());
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1569
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1570
  FileMapRegion* si = space_at(MetaspaceShared::first_closed_archive_heap_region);
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1571
  address relocated_closed_heap_region_bottom = start_address_as_decoded_from_archive(si);
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1572
  if (!is_aligned(relocated_closed_heap_region_bottom, HeapRegion::GrainBytes)) {
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1573
    // Align the bottom of the closed archive heap regions at G1 region boundary.
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1574
    // This will avoid the situation where the highest open region and the lowest
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1575
    // closed region sharing the same G1 region. Otherwise we will fail to map the
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1576
    // open regions.
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1577
    size_t align = size_t(relocated_closed_heap_region_bottom) % HeapRegion::GrainBytes;
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1578
    delta -= align;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1579
    log_info(cds)("CDS heap data need to be relocated lower by a further " SIZE_FORMAT
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1580
                  " bytes to " INTX_FORMAT " to be aligned with HeapRegion::GrainBytes",
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1581
                  align, delta);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1582
    HeapShared::init_narrow_oop_decoding(narrow_oop_base() + delta, narrow_oop_shift());
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1583
    _heap_pointers_need_patching = true;
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1584
    relocated_closed_heap_region_bottom = start_address_as_decoded_from_archive(si);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1585
  }
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1586
  assert(is_aligned(relocated_closed_heap_region_bottom, HeapRegion::GrainBytes),
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1587
         "must be");
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1588
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1589
  // Map the closed_archive_heap regions, GC does not write into the regions.
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1590
  if (map_heap_data(&closed_archive_heap_ranges,
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1591
                    MetaspaceShared::first_closed_archive_heap_region,
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1592
                    MetaspaceShared::max_closed_archive_heap_region,
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1593
                    &num_closed_archive_heap_ranges)) {
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1594
    HeapShared::set_closed_archive_heap_region_mapped();
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1595
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1596
    // Now, map open_archive heap regions, GC can write into the regions.
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1597
    if (map_heap_data(&open_archive_heap_ranges,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1598
                      MetaspaceShared::first_open_archive_heap_region,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1599
                      MetaspaceShared::max_open_archive_heap_region,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1600
                      &num_open_archive_heap_ranges,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1601
                      true /* open */)) {
52062
8dbf1a13af49 8206009: Move CDS java heap object archiving code to heapShared.hpp and heapShared.cpp
jiangli
parents: 51823
diff changeset
  1602
      HeapShared::set_open_archive_heap_region_mapped();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1603
    }
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1604
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1605
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1606
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1607
void FileMapInfo::map_heap_regions() {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1608
  if (has_heap_regions()) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1609
    map_heap_regions_impl();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1610
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1611
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1612
  if (!HeapShared::closed_archive_heap_region_mapped()) {
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1613
    assert(closed_archive_heap_ranges == NULL &&
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1614
           num_closed_archive_heap_ranges == 0, "sanity");
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1615
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1616
52062
8dbf1a13af49 8206009: Move CDS java heap object archiving code to heapShared.hpp and heapShared.cpp
jiangli
parents: 51823
diff changeset
  1617
  if (!HeapShared::open_archive_heap_region_mapped()) {
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1618
    assert(open_archive_heap_ranges == NULL && num_open_archive_heap_ranges == 0, "sanity");
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1619
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1620
}
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1621
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1622
bool FileMapInfo::map_heap_data(MemRegion **heap_mem, int first,
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1623
                                int max, int* num, bool is_open_archive) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1624
  MemRegion * regions = new MemRegion[max];
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1625
  FileMapRegion* si;
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1626
  int region_num = 0;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1627
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1628
  for (int i = first;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1629
           i < first + max; i++) {
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1630
    si = space_at(i);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1631
    size_t size = si->used();
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1632
    if (size > 0) {
51720
b7bfd64e43a6 8210523: runtime/appcds/cacheObject/DifferentHeapSizes.java crash
iklam
parents: 51491
diff changeset
  1633
      HeapWord* start = (HeapWord*)start_address_as_decoded_from_archive(si);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1634
      regions[region_num] = MemRegion(start, size / HeapWordSize);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1635
      region_num ++;
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1636
      log_info(cds)("Trying to map heap data: region[%d] at " INTPTR_FORMAT ", size = " SIZE_FORMAT_W(8) " bytes",
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1637
                    i, p2i(start), size);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1638
    }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1639
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1640
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1641
  if (region_num == 0) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1642
    return false; // no archived java heap data
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1643
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1644
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1645
  // Check that ranges are within the java heap
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1646
  if (!G1CollectedHeap::heap()->check_archive_addresses(regions, region_num)) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1647
    log_info(cds)("UseSharedSpaces: Unable to allocate region, range is not within java heap.");
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1648
    return false;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1649
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1650
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1651
  // allocate from java heap
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1652
  if (!G1CollectedHeap::heap()->alloc_archive_regions(
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1653
             regions, region_num, is_open_archive)) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1654
    log_info(cds)("UseSharedSpaces: Unable to allocate region, java heap range is already in use.");
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1655
    return false;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1656
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1657
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1658
  // Map the archived heap data. No need to call MemTracker::record_virtual_memory_type()
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1659
  // for mapped regions as they are part of the reserved java heap, which is
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1660
  // already recorded.
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1661
  for (int i = 0; i < region_num; i++) {
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1662
    si = space_at(first + i);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1663
    char* addr = (char*)regions[i].start();
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1664
    char* base = os::map_memory(_fd, _full_path, si->file_offset(),
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1665
                                addr, regions[i].byte_size(), si->read_only(),
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1666
                                si->allow_exec());
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1667
    if (base == NULL || base != addr) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1668
      // dealloc the regions from java heap
52674
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1669
      dealloc_archive_heap_regions(regions, region_num, is_open_archive);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1670
      log_info(cds)("UseSharedSpaces: Unable to map at required address in java heap. "
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1671
                    INTPTR_FORMAT ", size = " SIZE_FORMAT " bytes",
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1672
                    p2i(addr), regions[i].byte_size());
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1673
      return false;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1674
    }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1675
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1676
    if (VerifySharedSpaces && !region_crc_check(addr, regions[i].byte_size(), si->crc())) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1677
      // dealloc the regions from java heap
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1678
      dealloc_archive_heap_regions(regions, region_num, is_open_archive);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1679
      log_info(cds)("UseSharedSpaces: mapped heap regions are corrupt");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1680
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1681
    }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1682
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1683
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1684
  // the shared heap data is mapped successfully
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1685
  *heap_mem = regions;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1686
  *num = region_num;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1687
  return true;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1688
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1689
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1690
void FileMapInfo::patch_archived_heap_embedded_pointers() {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1691
  if (!_heap_pointers_need_patching) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1692
    return;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1693
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1694
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1695
  patch_archived_heap_embedded_pointers(closed_archive_heap_ranges,
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1696
                                        num_closed_archive_heap_ranges,
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1697
                                        MetaspaceShared::first_closed_archive_heap_region);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1698
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1699
  patch_archived_heap_embedded_pointers(open_archive_heap_ranges,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1700
                                        num_open_archive_heap_ranges,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1701
                                        MetaspaceShared::first_open_archive_heap_region);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1702
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1703
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1704
void FileMapInfo::patch_archived_heap_embedded_pointers(MemRegion* ranges, int num_ranges,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1705
                                                        int first_region_idx) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1706
  for (int i=0; i<num_ranges; i++) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1707
    FileMapRegion* si = space_at(i + first_region_idx);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1708
    HeapShared::patch_archived_heap_embedded_pointers(ranges[i], (address)si->oopmap(),
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1709
                                                      si->oopmap_size_in_bits());
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1710
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1711
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1712
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1713
// This internally allocates objects using SystemDictionary::Object_klass(), so it
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1714
// must be called after the well-known classes are resolved.
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1715
void FileMapInfo::fixup_mapped_heap_regions() {
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1716
  // If any closed regions were found, call the fill routine to make them parseable.
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1717
  // Note that closed_archive_heap_ranges may be non-NULL even if no ranges were found.
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1718
  if (num_closed_archive_heap_ranges != 0) {
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1719
    assert(closed_archive_heap_ranges != NULL,
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1720
           "Null closed_archive_heap_ranges array with non-zero count");
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1721
    G1CollectedHeap::heap()->fill_archive_regions(closed_archive_heap_ranges,
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1722
                                                  num_closed_archive_heap_ranges);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1723
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1724
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1725
  // do the same for mapped open archive heap regions
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1726
  if (num_open_archive_heap_ranges != 0) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1727
    assert(open_archive_heap_ranges != NULL, "NULL open_archive_heap_ranges array with non-zero count");
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1728
    G1CollectedHeap::heap()->fill_archive_regions(open_archive_heap_ranges,
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1729
                                                  num_open_archive_heap_ranges);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1730
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1731
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1732
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1733
// dealloc the archive regions from java heap
52674
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1734
void FileMapInfo::dealloc_archive_heap_regions(MemRegion* regions, int num, bool is_open) {
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1735
  if (num > 0) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1736
    assert(regions != NULL, "Null archive ranges array with non-zero count");
52674
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1737
    G1CollectedHeap::heap()->dealloc_archive_regions(regions, num, is_open);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1738
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1739
}
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1740
#endif // INCLUDE_CDS_JAVA_HEAP
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1741
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1742
bool FileMapInfo::region_crc_check(char* buf, size_t size, int expected_crc) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1743
  int crc = ClassLoader::crc32(0, buf, (jint)size);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1744
  if (crc != expected_crc) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1745
    fail_continue("Checksum verification failed.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1746
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1747
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1748
  return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1749
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1750
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1751
bool FileMapInfo::verify_region_checksum(int i) {
54838
d7819bedfaaf 8221478: Disable VerifySharedSpaces by default
redestad
parents: 54825
diff changeset
  1752
  assert(VerifySharedSpaces, "sanity");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1753
  size_t sz = space_at(i)->used();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1754
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1755
  if (sz == 0) {
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1756
    return true; // no data
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1757
  } else {
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1758
    return region_crc_check(region_addr(i), sz, space_at(i)->crc());
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1759
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1760
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1761
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1762
void FileMapInfo::unmap_regions(int regions[], char* saved_base[], size_t len) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1763
  for (int i = 0; i < (int)len; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1764
    if (saved_base[i] != NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1765
      unmap_region(regions[i]);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1766
    }
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1767
  }
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1768
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1769
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1770
// Unmap a memory region in the address space.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1771
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1772
void FileMapInfo::unmap_region(int i) {
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1773
  assert(!HeapShared::is_heap_region(i), "sanity");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1774
  FileMapRegion* si = space_at(i);
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1775
  size_t used = si->used();
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1776
  size_t size = align_up(used, os::vm_allocation_granularity());
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1777
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1778
  if (used == 0) {
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1779
    return;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1780
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1781
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1782
  char* addr = region_addr(i);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1783
  if (!os::unmap_memory(addr, size)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1784
    fail_stop("Unable to unmap shared space.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1785
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1786
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1787
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1788
void FileMapInfo::assert_mark(bool check) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1789
  if (!check) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1790
    fail_stop("Mark mismatch while restoring from shared file.");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1791
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1792
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1793
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1794
void FileMapInfo::metaspace_pointers_do(MetaspaceClosure* it) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1795
  _shared_path_table.metaspace_pointers_do(it);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1796
}
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1797
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1798
FileMapInfo* FileMapInfo::_current_info = NULL;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1799
FileMapInfo* FileMapInfo::_dynamic_archive_info = NULL;
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1800
bool FileMapInfo::_heap_pointers_need_patching = false;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1801
SharedPathTable FileMapInfo::_shared_path_table;
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
  1802
bool FileMapInfo::_validating_shared_path_table = false;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1803
bool FileMapInfo::_memory_mapping_failed = false;
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
  1804
GrowableArray<const char*>* FileMapInfo::_non_existent_class_paths = NULL;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1805
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1806
// Open the shared archive file, read and validate the header
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1807
// information (version, boot classpath, etc.).  If initialization
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1808
// fails, shared spaces are disabled and the file is closed. [See
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1809
// fail_continue.]
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1810
//
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1811
// Validation of the archive is done in two steps:
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1812
//
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
  1813
// [1] validate_header() - done here.
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
  1814
// [2] validate_shared_path_table - this is done later, because the table is in the RW
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1815
//     region of the archive, which is not mapped yet.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1816
bool FileMapInfo::initialize(bool is_static) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1817
  assert(UseSharedSpaces, "UseSharedSpaces expected.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1818
52319
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1819
  if (JvmtiExport::should_post_class_file_load_hook() && JvmtiExport::has_early_class_hook_env()) {
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1820
    // CDS assumes that no classes resolved in SystemDictionary::resolve_well_known_classes
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1821
    // are replaced at runtime by JVMTI ClassFileLoadHook. All of those classes are resolved
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1822
    // during the JVMTI "early" stage, so we can still use CDS if
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1823
    // JvmtiExport::has_early_class_hook_env() is false.
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1824
    FileMapInfo::fail_continue("CDS is disabled because early JVMTI ClassFileLoadHook is in use.");
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1825
    return false;
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1826
  }
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1827
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1828
  if (!open_for_read()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1829
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1830
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1831
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1832
  init_from_file(_fd, is_static);
57579
1edf6cc224fb 8228407: JVM crashes with shared archive file mismatch
ccheung
parents: 55694
diff changeset
  1833
  // UseSharedSpaces could be disabled if the checking of some of the header fields in
1edf6cc224fb 8228407: JVM crashes with shared archive file mismatch
ccheung
parents: 55694
diff changeset
  1834
  // init_from_file has failed.
1edf6cc224fb 8228407: JVM crashes with shared archive file mismatch
ccheung
parents: 55694
diff changeset
  1835
  if (!UseSharedSpaces || !validate_header(is_static)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1836
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1837
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1838
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1839
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1840
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1841
char* FileMapInfo::region_addr(int idx) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1842
  FileMapRegion* si = space_at(idx);
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1843
  if (HeapShared::is_heap_region(idx)) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1844
    assert(DumpSharedSpaces, "The following doesn't work at runtime");
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1845
    return si->used() > 0 ?
51720
b7bfd64e43a6 8210523: runtime/appcds/cacheObject/DifferentHeapSizes.java crash
iklam
parents: 51491
diff changeset
  1846
          (char*)start_address_as_decoded_with_current_oop_encoding_mode(si) : NULL;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1847
  } else {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1848
    return si->base();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1849
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1850
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1851
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1852
int FileMapHeader::compute_crc() {
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1853
  char* start = (char*)this;
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1854
  // start computing from the field after _crc
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1855
  char* buf = (char*)&_crc + sizeof(_crc);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1856
  size_t sz = _header_size - (buf - start);
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1857
  int crc = ClassLoader::crc32(0, buf, (jint)sz);
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1858
  return crc;
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1859
}
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1860
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
  1861
// This function should only be called during run time with UseSharedSpaces enabled.
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1862
bool FileMapHeader::validate() {
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1863
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1864
  if (_obj_alignment != ObjectAlignmentInBytes) {
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1865
    FileMapInfo::fail_continue("The shared archive file's ObjectAlignmentInBytes of %d"
33148
68fa8b6c4340 8042893: compiler: PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC needs to be removed from source files
david
parents: 32589
diff changeset
  1866
                  " does not equal the current ObjectAlignmentInBytes of " INTX_FORMAT ".",
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1867
                  _obj_alignment, ObjectAlignmentInBytes);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1868
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1869
  }
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1870
  if (_compact_strings != CompactStrings) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1871
    FileMapInfo::fail_continue("The shared archive file's CompactStrings setting (%s)"
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1872
                  " does not equal the current CompactStrings setting (%s).",
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1873
                  _compact_strings ? "enabled" : "disabled",
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1874
                  CompactStrings   ? "enabled" : "disabled");
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1875
    return false;
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1876
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1877
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1878
  // This must be done after header validation because it might change the
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1879
  // header data
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1880
  const char* prop = Arguments::get_property("java.system.class.loader");
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1881
  if (prop != NULL) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1882
    warning("Archived non-system classes are disabled because the "
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1883
            "java.system.class.loader property is specified (value = \"%s\"). "
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1884
            "To use archived non-system classes, this property must not be set", prop);
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1885
    _has_platform_or_app_classes = false;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1886
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1887
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1888
  // For backwards compatibility, we don't check the verification setting
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1889
  // if the archive only contains system classes.
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1890
  if (_has_platform_or_app_classes &&
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1891
      ((!_verify_local && BytecodeVerificationLocal) ||
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1892
       (!_verify_remote && BytecodeVerificationRemote))) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1893
    FileMapInfo::fail_continue("The shared archive file was created with less restrictive "
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1894
                  "verification setting than the current setting.");
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1895
    return false;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1896
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1897
52596
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1898
  // Java agents are allowed during run time. Therefore, the following condition is not
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1899
  // checked: (!_allow_archiving_with_java_agent && AllowArchivingWithJavaAgent)
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1900
  // Note: _allow_archiving_with_java_agent is set in the shared archive during dump time
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1901
  // while AllowArchivingWithJavaAgent is set during the current run.
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1902
  if (_allow_archiving_with_java_agent && !AllowArchivingWithJavaAgent) {
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1903
    FileMapInfo::fail_continue("The setting of the AllowArchivingWithJavaAgent is different "
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1904
                               "from the setting in the shared archive.");
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1905
    return false;
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1906
  }
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1907
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1908
  if (_allow_archiving_with_java_agent) {
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1909
    warning("This archive was created with AllowArchivingWithJavaAgent. It should be used "
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1910
            "for testing purposes only and should not be used in a production environment");
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1911
  }
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1912
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1913
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1914
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1915
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1916
bool FileMapInfo::validate_header(bool is_static) {
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1917
  return header()->validate();
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1918
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1919
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1920
// Check if a given address is within one of the shared regions
37439
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1921
bool FileMapInfo::is_in_shared_region(const void* p, int idx) {
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1922
  assert(idx == MetaspaceShared::ro ||
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1923
         idx == MetaspaceShared::rw ||
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1924
         idx == MetaspaceShared::mc ||
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1925
         idx == MetaspaceShared::md, "invalid region index");
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1926
  char* base = region_addr(idx);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1927
  if (p >= base && p < base + space_at(idx)->used()) {
37439
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1928
    return true;
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1929
  }
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1930
  return false;
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1931
}
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1932
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1933
// Unmap mapped regions of shared space.
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1934
void FileMapInfo::stop_sharing_and_unmap(const char* msg) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1935
  MetaspaceShared::set_shared_metaspace_range(NULL, NULL);
52314
e53af5fa0dae 8212205: VM asserts after CDS archive has been unmapped
iklam
parents: 52126
diff changeset
  1936
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1937
  FileMapInfo *map_info = FileMapInfo::current_info();
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1938
  if (map_info) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1939
    map_info->fail_continue("%s", msg);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1940
    for (int i = 0; i < MetaspaceShared::num_non_heap_spaces; i++) {
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1941
      if (!HeapShared::is_heap_region(i)) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1942
        char *addr = map_info->region_addr(i);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1943
        if (addr != NULL) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1944
          map_info->unmap_region(i);
58096
0d97bf7cf8a4 8230586: Encapsulate fields in filemap.hpp
iklam
parents: 58015
diff changeset
  1945
          map_info->space_at(i)->mark_invalid();
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1946
        }
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1947
      }
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1948
    }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1949
    // Dealloc the archive heap regions only without unmapping. The regions are part
32589
f86fb16fcab0 8131734: assert(!is_null(v)) failed: narrow klass value can never be zero with -Xshared:auto
jiangli
parents: 31375
diff changeset
  1950
    // of the java heap. Unmapping of the heap regions are managed by GC.
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1951
    map_info->dealloc_archive_heap_regions(open_archive_heap_ranges,
52674
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1952
                                           num_open_archive_heap_ranges,
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1953
                                           true);
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1954
    map_info->dealloc_archive_heap_regions(closed_archive_heap_ranges,
52674
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1955
                                           num_closed_archive_heap_ranges,
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1956
                                           false);
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1957
  } else if (DumpSharedSpaces) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1958
    fail_stop("%s", msg);
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1959
  }
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1960
}
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1961
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1962
#if INCLUDE_JVMTI
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1963
ClassPathEntry** FileMapInfo::_classpath_entries_for_jvmti = NULL;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1964
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1965
ClassPathEntry* FileMapInfo::get_classpath_entry_for_jvmti(int i, TRAPS) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1966
  ClassPathEntry* ent = _classpath_entries_for_jvmti[i];
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1967
  if (ent == NULL) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1968
    if (i == 0) {
57898
5ddb746d45e0 8227370: Remove SharedPathsMiscInfo
iklam
parents: 57897
diff changeset
  1969
      ent = ClassLoader::get_jrt_entry();
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1970
      assert(ent != NULL, "must be");
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1971
    } else {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1972
      SharedClassPathEntry* scpe = shared_path(i);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1973
      assert(scpe->is_jar(), "must be"); // other types of scpe will not produce archived classes
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1974
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1975
      const char* path = scpe->name();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1976
      struct stat st;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1977
      if (os::stat(path, &st) != 0) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1978
        char *msg = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, strlen(path) + 128); ;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1979
        jio_snprintf(msg, strlen(path) + 127, "error in opening JAR file %s", path);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1980
        THROW_MSG_(vmSymbols::java_io_IOException(), msg, NULL);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1981
      } else {
55524
b279ae9843b8 8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work
ccheung
parents: 55296
diff changeset
  1982
        ent = ClassLoader::create_class_path_entry(path, &st, /*throw_exception=*/true, false, false, CHECK_NULL);
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1983
      }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1984
    }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1985
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1986
    MutexLocker mu(CDSClassFileStream_lock, THREAD);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1987
    if (_classpath_entries_for_jvmti[i] == NULL) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1988
      _classpath_entries_for_jvmti[i] = ent;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1989
    } else {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1990
      // Another thread has beat me to creating this entry
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1991
      delete ent;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1992
      ent = _classpath_entries_for_jvmti[i];
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1993
    }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1994
  }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1995
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1996
  return ent;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1997
}
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1998
54340
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  1999
ClassFileStream* FileMapInfo::open_stream_for_jvmti(InstanceKlass* ik, Handle class_loader, TRAPS) {
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2000
  int path_index = ik->shared_classpath_index();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2001
  assert(path_index >= 0, "should be called for shared built-in classes only");
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  2002
  assert(path_index < (int)get_number_of_shared_paths(), "sanity");
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2003
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2004
  ClassPathEntry* cpe = get_classpath_entry_for_jvmti(path_index, CHECK_NULL);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2005
  assert(cpe != NULL, "must be");
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2006
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2007
  Symbol* name = ik->name();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2008
  const char* const class_name = name->as_C_string();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2009
  const char* const file_name = ClassLoader::file_name_for_class_name(class_name,
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2010
                                                                      name->utf8_length());
54340
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  2011
  ClassLoaderData* loader_data = ClassLoaderData::class_loader_data(class_loader());
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  2012
  ClassFileStream* cfs = cpe->open_stream_for_loader(file_name, loader_data, THREAD);
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  2013
  assert(cfs != NULL, "must be able to read the classfile data of shared classes for built-in loaders.");
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  2014
  log_debug(cds, jvmti)("classfile data for %s [%d: %s] = %d bytes", class_name, path_index,
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  2015
                        cfs->source(), cfs->length());
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  2016
  return cfs;
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2017
}
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2018
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  2019
#endif