src/hotspot/share/memory/filemap.cpp
author ccheung
Fri, 28 Jun 2019 09:49:10 -0700
changeset 55524 b279ae9843b8
parent 55296 357c9dcb6eb9
child 55717 2b4e14968afd
permissions -rw-r--r--
8211723: AppCDS: referring to a jar file in any way other than exactly how it was done during dumping doesn't work Summary: Replaced os::file_name_strncmp() with os::same_files(). Reviewed-by: iklam, 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"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    58
#include "utilities/defaultStream.hpp"
49982
9042ffe5b7fe 8200729: Conditional compilation of GCs
stefank
parents: 49931
diff changeset
    59
#if INCLUDE_G1GC
49592
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49340
diff changeset
    60
#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
    61
#include "gc/g1/heapRegion.hpp"
49592
77fb0be7d19f 8199946: Move load/store and encode/decode out of oopDesc
stefank
parents: 49340
diff changeset
    62
#endif
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    63
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
# include <sys/stat.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
# include <errno.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
#ifndef O_BINARY       // if defined (Win32) use binary files.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
#define O_BINARY 0     // otherwise do nothing.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
extern address JVM_FunctionAtStart();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
extern address JVM_FunctionAtEnd();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 1
diff changeset
    74
// Complain and stop. All error conditions occurring during the writing of
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
// an archive file should stop the process.  Unrecoverable errors during
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
// the reading of the archive file should stop the process.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
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
    78
static void fail_exit(const char *msg, va_list ap) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
  // This occurs very early during initialization: tty is not initialized.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
  jio_fprintf(defaultStream::error_stream(),
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 1
diff changeset
    81
              "An error has occurred while processing the"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
              " shared archive file.\n");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  jio_vfprintf(defaultStream::error_stream(), msg, ap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
  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
    85
  // Do not change the text of the below message because some tests check for it.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
  vm_exit_during_initialization("Unable to use shared archive.", NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
void FileMapInfo::fail_stop(const char *msg, ...) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
        va_list ap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
  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
    93
  fail_exit(msg, ap);   // Never returns.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
  va_end(ap);           // for completeness.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
// Complain and continue.  Recoverable errors during the reading of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
// archive file may continue (with sharing disabled).
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
// If we continue, then disable shared spaces and close the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
void FileMapInfo::fail_continue(const char *msg, ...) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
  va_list ap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
  va_start(ap, msg);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   106
  if (_dynamic_archive_info == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   107
    MetaspaceShared::set_archive_loading_failed();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   108
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   109
    // _dynamic_archive_info has been setup after mapping the base archive
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   110
    DynamicArchive::disable();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   111
  }
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   112
  if (PrintSharedArchiveAndExit && _validating_shared_path_table) {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   113
    // 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
   114
    // 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
   115
    // entries. No need to quit.
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   116
    tty->print("[");
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   117
    tty->vprint(msg, ap);
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   118
    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
   119
  } else {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   120
    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
   121
      fail_exit(msg, ap);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   122
    } else {
46522
86b13b03a053 8176132: -XX:+PrintSharedSpaces should be converted to use Unified Logging.
rprotacio
parents: 42876
diff changeset
   123
      if (log_is_enabled(Info, cds)) {
86b13b03a053 8176132: -XX:+PrintSharedSpaces should be converted to use Unified Logging.
rprotacio
parents: 42876
diff changeset
   124
        ResourceMark rm;
46701
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46630
diff changeset
   125
        LogStream ls(Log(cds)::info());
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46630
diff changeset
   126
        ls.print("UseSharedSpaces: ");
f559541c0daa 8181917: Refactor UL LogStreams to avoid using resource area
stuefe
parents: 46630
diff changeset
   127
        ls.vprint_cr(msg, ap);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   128
      }
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
   129
    }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   130
    if (_dynamic_archive_info == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   131
      UseSharedSpaces = false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   132
      assert(current_info() != NULL, "singleton must be registered");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   133
      current_info()->close();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   134
    } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   135
      // We are failing when loading the top archive, but the base archive should
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   136
      // continue to work.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   137
      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
   138
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
  va_end(ap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   143
// Fill in the fileMapInfo structure with data about this VM instance.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   145
// 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
   146
// 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
   147
//
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   148
// 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
   149
// 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
   150
// 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
   151
// 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
   152
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
   153
  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
   154
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   155
  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
   156
  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
   157
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   158
  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
   159
    strcpy(header_version, vm_version);
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   160
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   161
  } else {
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   162
    // 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
   163
    // value over multiple jvm invocations.
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   164
    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
   165
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   166
    // 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
   167
    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
   168
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   169
    // 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
   170
    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
   171
    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
   172
  }
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
   173
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   175
FileMapInfo::FileMapInfo(bool is_static) {
46630
75aa3e39d02c 8182299: Enable disabled clang warnings, build on OSX 10 + Xcode 8
jwilhelm
parents: 46625
diff changeset
   176
  memset((void*)this, 0, sizeof(FileMapInfo));
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   177
  _is_static = is_static;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   178
  size_t header_size;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   179
  if (is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   180
    assert(_current_info == NULL, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   181
    _current_info = this;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   182
    header_size = sizeof(FileMapHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   183
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   184
    assert(_dynamic_archive_info == NULL, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   185
    _dynamic_archive_info = this;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   186
    header_size = sizeof(DynamicArchiveHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   187
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   188
  _header = (FileMapHeader*)os::malloc(header_size, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   189
  memset((void*)_header, 0, header_size);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   190
  _header->_header_size = header_size;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   191
  _header->_version = INVALID_CDS_ARCHIVE_VERSION;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   192
  _header->_has_platform_or_app_classes = true;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   193
  _file_offset = 0;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   194
  _file_open = false;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   195
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   196
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   197
FileMapInfo::~FileMapInfo() {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   198
  if (_is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   199
    assert(_current_info == this, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   200
    _current_info = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   201
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   202
    assert(_dynamic_archive_info == this, "must be singleton"); // not thread safe
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   203
    _dynamic_archive_info = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   204
  }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   205
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   206
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   207
void FileMapInfo::populate_header(size_t alignment) {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   208
  _header->populate(this, alignment);
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   209
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   210
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
   211
void FileMapHeader::populate(FileMapInfo* mapinfo, size_t alignment) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   212
  if (DynamicDumpSharedSpaces) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   213
    _magic = CDS_DYNAMIC_ARCHIVE_MAGIC;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   214
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   215
    _magic = CDS_ARCHIVE_MAGIC;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   216
  }
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
   217
  _version = CURRENT_CDS_ARCHIVE_VERSION;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   218
  _alignment = alignment;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   219
  _obj_alignment = ObjectAlignmentInBytes;
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
   220
  _compact_strings = CompactStrings;
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   221
  _narrow_oop_mode = CompressedOops::mode();
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   222
  _narrow_oop_base = CompressedOops::base();
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   223
  _narrow_oop_shift = CompressedOops::shift();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
   224
  _max_heap_size = MaxHeapSize;
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   225
  _narrow_klass_base = CompressedKlassPointers::base();
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
   226
  _narrow_klass_shift = CompressedKlassPointers::shift();
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   227
  _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
   228
  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
   229
    _heap_reserved = Universe::heap()->reserved_region();
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
   230
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
  // The following fields are for sanity checks for whether this archive
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
  // will function correctly with this JVM and the bootclasspath it's
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
  // invoked with.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
  // JVM version string ... changes on each build.
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   237
  get_header_version(_jvm_ident);
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   238
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   239
  ClassLoaderExt::finalize_shared_paths_misc_info();
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   240
  _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
   241
  _app_module_paths_start_index = ClassLoaderExt::app_module_paths_start_index();
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   242
  _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
   243
  _max_used_path_index = ClassLoaderExt::max_used_path_index();
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   244
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   245
  _verify_local = BytecodeVerificationLocal;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   246
  _verify_remote = BytecodeVerificationRemote;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   247
  _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
   248
  _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
   249
  _allow_archiving_with_java_agent = AllowArchivingWithJavaAgent;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   250
  // 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
   251
  _base_archive_name_size = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   252
  _base_archive_is_default = false;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   253
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   254
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
   255
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
   256
                                ClassPathEntry* cpe, TRAPS) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   257
  assert(DumpSharedSpaces || DynamicDumpSharedSpaces, "dump time only");
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   258
  _timestamp = 0;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   259
  _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
   260
  _from_class_path_attr = false;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   261
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   262
  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
   263
  if (os::stat(cpe->name(), &st) == 0) {
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   264
    if ((st.st_mode & S_IFMT) == S_IFDIR) {
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   265
      _type = dir_entry;
40013
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
   266
    } else {
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   267
      // 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
   268
      if (is_modules_image) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   269
        _type = modules_image_entry;
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   270
      } else {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   271
        _type = jar_entry;
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   272
        _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
   273
        _from_class_path_attr = cpe->from_class_path_attr();
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   274
      }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   275
      _filesize = st.st_size;
40013
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
   276
    }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   277
  } else {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   278
    // 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
   279
    // into ClassLoader::classpath_entry().
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   280
    //
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   281
    // 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
   282
    // 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
   283
    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
   284
  }
40013
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
   285
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
   286
  size_t len = strlen(cpe->name()) + 1;
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   287
  _name = MetadataFactory::new_array<char>(ClassLoaderData::the_null_class_loader_data(), (int)len, THREAD);
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
   288
  strcpy(_name->data(), cpe->name());
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   289
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   291
bool SharedClassPathEntry::validate(bool is_class_path) {
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   292
  assert(UseSharedSpaces, "runtime only");
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   293
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   294
  struct stat st;
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   295
  const char* name;
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   296
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   297
  // In order to validate the runtime modules image file size against the archived
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   298
  // size information, we need to obtain the runtime modules image path. The recorded
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   299
  // dump time modules image path in the archive may be different from the runtime path
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   300
  // if the JDK image has beed moved after generating the archive.
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   301
  if (is_modules_image()) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   302
    name = ClassLoader::get_jrt_entry()->name();
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   303
  } else {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   304
    name = this->name();
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   305
  }
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   306
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   307
  bool ok = true;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   308
  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
   309
  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
   310
    // 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
   311
    // (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
   312
    // 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
   313
    // module path location.
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   314
    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
   315
    ok = false;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   316
  } else if (is_dir()) {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   317
    if (!os::dir_is_empty(name)) {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   318
      FileMapInfo::fail_continue("directory is not empty: %s", name);
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   319
      ok = false;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   320
    }
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   321
  } else if ((has_timestamp() && _timestamp != st.st_mtime) ||
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   322
             _filesize != st.st_size) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   323
    ok = false;
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   324
    if (PrintSharedArchiveAndExit) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   325
      FileMapInfo::fail_continue(_timestamp != st.st_mtime ?
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   326
                                 "Timestamp mismatch" :
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   327
                                 "File size mismatch");
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   328
    } else {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   329
      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
   330
                                 " the shared archive file: %s", name);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
    }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   332
  }
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   333
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   334
  if (PrintSharedArchiveAndExit && !ok) {
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   335
    // 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
   336
    // 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
   337
    ok = true;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   338
    MetaspaceShared::set_archive_loading_failed();
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   339
  }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   340
  return ok;
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   341
}
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   342
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   343
void SharedClassPathEntry::metaspace_pointers_do(MetaspaceClosure* it) {
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   344
  it->push(&_name);
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   345
  it->push(&_manifest);
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   346
}
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   347
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   348
void SharedPathTable::metaspace_pointers_do(MetaspaceClosure* it) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   349
  it->push(&_table);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   350
  for (int i=0; i<_size; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   351
    path_at(i)->metaspace_pointers_do(it);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   352
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   353
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   354
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   355
void SharedPathTable::dumptime_init(ClassLoaderData* loader_data, Thread* THREAD) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   356
  size_t entry_size = sizeof(SharedClassPathEntry);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   357
  int num_boot_classpath_entries = ClassLoader::num_boot_classpath_entries();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   358
  int num_app_classpath_entries = ClassLoader::num_app_classpath_entries();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   359
  int num_module_path_entries = ClassLoader::num_module_path_entries();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   360
  int num_entries = num_boot_classpath_entries + num_app_classpath_entries + num_module_path_entries;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   361
  size_t bytes = entry_size * num_entries;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   362
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   363
  _table = MetadataFactory::new_array<u8>(loader_data, (int)(bytes + 7 / 8), THREAD);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   364
  _size = num_entries;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   365
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   366
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   367
void FileMapInfo::allocate_shared_path_table() {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   368
  assert(DumpSharedSpaces || DynamicDumpSharedSpaces, "Sanity");
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   369
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   370
  Thread* THREAD = Thread::current();
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   371
  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
   372
  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
   373
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   374
  assert(jrt != NULL,
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   375
         "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
   376
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   377
  _shared_path_table.dumptime_init(loader_data, THREAD);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   378
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   379
  // 1. boot class path
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   380
  int i = 0;
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   381
  ClassPathEntry* cpe = jrt;
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   382
  while (cpe != NULL) {
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   383
    bool is_jrt = (cpe == jrt);
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   384
    const char* type = (is_jrt ? "jrt" : (cpe->is_jar_file() ? "jar" : "dir"));
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
   385
    log_info(class, path)("add main shared path (%s) %s", type, cpe->name());
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   386
    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
   387
    ent->init(is_jrt, cpe, THREAD);
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   388
    if (!is_jrt) {    // No need to do the modules image.
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   389
      EXCEPTION_MARK; // The following call should never throw, but would exit VM on error.
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   390
      update_shared_classpath(cpe, ent, THREAD);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   391
    }
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   392
    cpe = ClassLoader::get_next_boot_classpath_entry(cpe);
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   393
    i++;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   395
  assert(i == ClassLoader::num_boot_classpath_entries(),
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   396
         "number of boot class path entry mismatch");
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   397
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   398
  // 2. app class path
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   399
  ClassPathEntry *acpe = ClassLoader::app_classpath_entries();
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   400
  while (acpe != NULL) {
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   401
    log_info(class, path)("add app shared path %s", acpe->name());
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   402
    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
   403
    ent->init(false, acpe, THREAD);
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   404
    EXCEPTION_MARK;
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   405
    update_shared_classpath(acpe, ent, THREAD);
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   406
    acpe = acpe->next();
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   407
    i++;
47991
a474466c4fdb 8187118: Remove appending -cp path to the boot class path at AppCDS dump time
jiangli
parents: 47765
diff changeset
   408
  }
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   409
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   410
  // 3. module path
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   411
  ClassPathEntry *mpe = ClassLoader::module_path_entries();
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   412
  while (mpe != NULL) {
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   413
    log_info(class, path)("add module path %s",mpe->name());
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   414
    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
   415
    ent->init(false, mpe, THREAD);
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   416
    EXCEPTION_MARK;
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   417
    update_shared_classpath(mpe, ent, THREAD);
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   418
    mpe = mpe->next();
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   419
    i++;
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   420
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   421
  assert(i == _shared_path_table.size(), "number of shared path entry mismatch");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   424
void FileMapInfo::check_nonempty_dir_in_shared_path_table() {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   425
  assert(DumpSharedSpaces || DynamicDumpSharedSpaces, "dump time only");
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   426
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   427
  bool has_nonempty_dir = false;
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   428
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   429
  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
   430
  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
   431
     // 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
   432
     last = ClassLoaderExt::max_used_path_index();
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   433
  }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   434
51439
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   435
  for (int i = 0; i <= last; i++) {
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   436
    SharedClassPathEntry *e = shared_path(i);
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   437
    if (e->is_dir()) {
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   438
      const char* path = e->name();
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   439
      if (!os::dir_is_empty(path)) {
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   440
        tty->print_cr("Error: non-empty directory '%s'", path);
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   441
        has_nonempty_dir = true;
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   442
      }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   443
    }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   444
  }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   445
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   446
  if (has_nonempty_dir) {
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   447
    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
   448
  }
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   449
}
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   450
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   451
class ManifestStream: public ResourceObj {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   452
  private:
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   453
  u1*   _buffer_start; // Buffer bottom
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   454
  u1*   _buffer_end;   // Buffer top (one past last element)
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   455
  u1*   _current;      // Current buffer position
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   456
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   457
 public:
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   458
  // Constructor
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   459
  ManifestStream(u1* buffer, int length) : _buffer_start(buffer),
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   460
                                           _current(buffer) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   461
    _buffer_end = buffer + length;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   462
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   463
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   464
  static bool is_attr(u1* attr, const char* name) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   465
    return strncmp((const char*)attr, name, strlen(name)) == 0;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   466
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   467
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   468
  static char* copy_attr(u1* value, size_t len) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   469
    char* buf = NEW_RESOURCE_ARRAY(char, len + 1);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   470
    strncpy(buf, (char*)value, len);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   471
    buf[len] = 0;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   472
    return buf;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   473
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   474
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   475
  // 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
   476
  bool check_is_signed() {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   477
    u1* attr = _current;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   478
    bool isSigned = false;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   479
    while (_current < _buffer_end) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   480
      if (*_current == '\n') {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   481
        *_current = '\0';
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   482
        u1* value = (u1*)strchr((char*)attr, ':');
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   483
        if (value != NULL) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   484
          assert(*(value+1) == ' ', "Unrecognized format" );
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   485
          if (strstr((char*)attr, "-Digest") != NULL) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   486
            isSigned = true;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   487
            break;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   488
          }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   489
        }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   490
        *_current = '\n'; // restore
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   491
        attr = _current + 1;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   492
      }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   493
      _current ++;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   494
    }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   495
    return isSigned;
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
};
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   498
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   499
void FileMapInfo::update_shared_classpath(ClassPathEntry *cpe, SharedClassPathEntry* ent, TRAPS) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   500
  ClassLoaderData* loader_data = ClassLoaderData::the_null_class_loader_data();
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   501
  ResourceMark rm(THREAD);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   502
  jint manifest_size;
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
  if (cpe->is_jar_file()) {
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   505
    assert(ent->is_jar(), "the shared class path entry is not a JAR file");
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   506
    char* manifest = ClassLoaderExt::read_manifest(cpe, &manifest_size, CHECK);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   507
    if (manifest != NULL) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   508
      ManifestStream* stream = new ManifestStream((u1*)manifest,
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   509
                                                  manifest_size);
50199
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   510
      if (stream->check_is_signed()) {
83d8b3a25f25 8199807: AppCDS performs overly restrictive path matching check.
jiangli
parents: 50039
diff changeset
   511
        ent->set_is_signed();
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   512
      } else {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   513
        // Copy the manifest into the shared archive
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   514
        manifest = ClassLoaderExt::read_raw_manifest(cpe, &manifest_size, CHECK);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   515
        Array<u1>* buf = MetadataFactory::new_array<u1>(loader_data,
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   516
                                                        manifest_size,
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   517
                                                        THREAD);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   518
        char* p = (char*)(buf->data());
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   519
        memcpy(p, manifest, manifest_size);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   520
        ent->set_manifest(buf);
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   521
      }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   522
    }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   523
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   524
}
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   525
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
   526
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
   527
  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
   528
  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
   529
  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
   530
    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
   531
      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
   532
      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
   533
             "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
   534
    } );
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
   535
    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
   536
  } 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
   537
    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
   538
      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
   539
             "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
   540
    } );
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
   541
  }
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
   542
  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
   543
}
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
   544
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
   545
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
   546
  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
   547
    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
   548
  }
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
   549
  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
   550
  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
   551
  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
   552
    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
   553
    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
   554
    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
   555
      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
   556
      // 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
   557
      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
   558
       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
   559
      }
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
   560
    }
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
   561
  }
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
   562
  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
   563
}
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
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
GrowableArray<char*>* FileMapInfo::create_path_array(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
   566
  GrowableArray<char*>* path_array =  new(ResourceObj::RESOURCE_AREA, mtInternal)
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
      GrowableArray<char*>(10);
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
  char* begin_ptr = (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
   569
  char* end_ptr = strchr((char*)path, os::path_separator()[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
   570
  if (end_ptr == 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
   571
    end_ptr = strchr((char*)path, '\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
   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
  while (end_ptr != 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
   574
    if ((end_ptr - begin_ptr) > 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
   575
      struct stat st;
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
      char* temp_name = NEW_RESOURCE_ARRAY(char, (size_t)(end_ptr - begin_ptr + 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
   577
      strncpy(temp_name, begin_ptr, end_ptr - begin_ptr);
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
      temp_name[end_ptr - begin_ptr] = '\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
   579
      if (os::stat(temp_name, &st) == 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
   580
        path_array->append(temp_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
   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
    if (end_ptr < (path + strlen(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
      begin_ptr = ++end_ptr;
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
      end_ptr = strchr(begin_ptr, os::path_separator()[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
      if (end_ptr == 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
   587
        end_ptr = strchr(begin_ptr, '\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
   588
      }
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
    } 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
   590
      break;
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
    }
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
  }
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
  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
   594
}
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
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
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
   597
  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
   598
  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
   599
  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
   600
}
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
bool FileMapInfo::check_paths(int shared_path_start_idx, int num_paths, GrowableArray<char*>* 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
   603
  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
   604
  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
   605
  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
   606
  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
   607
    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
   608
      // 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
   609
      // 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
   610
      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
   611
    }
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
   612
    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
   613
      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
   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
    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
   616
    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
   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
  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
   619
}
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
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
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
   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
  // - 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
   624
  //   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
   625
  //
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
  // - 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
   627
  //   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
   628
  //   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
   629
  //   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
   630
  //
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
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
  // 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
   633
  // 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
   634
  // 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
   635
  // 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
   636
  // 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
   637
  // 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
   638
  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
   639
  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
   640
  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
   641
  int dp_len = _header->_app_class_paths_start_index - 1; // ignore the first path to the module 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
   642
  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
   643
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
  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
   645
  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
   646
    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
   647
  } 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
   648
    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
   649
      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
   650
    } 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
   651
      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
   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
  } 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
   654
    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
   655
    ResourceMark rm;
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
    GrowableArray<char*>* rp_array = create_path_array(rp);
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
    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
   658
    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
   659
      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
   660
        // 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
   661
        // 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
   662
        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
   663
      } 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
   664
        // 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
   665
        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
   666
      }
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
      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
   668
    }
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
  }
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
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
  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
   672
    // 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
   673
    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
   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
  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
   676
}
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
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
   678
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
   679
  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
   680
  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
   681
  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
   682
  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
   683
  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
   684
    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
   685
  }
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
  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
   687
    // 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
   688
    ResourceMark rm;
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
    GrowableArray<char*>* rp_array = create_path_array(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
   690
    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
   691
      // 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
   692
      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
   693
    }
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
    int j = _header->_app_class_paths_start_index;
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
    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
   696
    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
   697
      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
   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
  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
   701
}
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   702
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   703
bool FileMapInfo::validate_shared_path_table() {
49931
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   704
  assert(UseSharedSpaces, "runtime only");
840e26123940 8193213: Make the UseAppCDS option obsolete.
jiangli
parents: 49739
diff changeset
   705
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   706
  _validating_shared_path_table = true;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   707
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   708
  // Load the shared path table info from the archive header
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   709
  _shared_path_table = _header->_shared_path_table;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   710
  if (DynamicDumpSharedSpaces) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   711
    // Only support dynamic dumping with the usage of the default CDS archive
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   712
    // or a simple base archive.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   713
    // If the base layer archive contains additional path component besides
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   714
    // the runtime image and the -cp, dynamic dumping is disabled.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   715
    //
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   716
    // When dynamic archiving is enabled, the _shared_path_table is overwritten
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   717
    // to include the application path and stored in the top layer archive.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   718
    assert(shared_path(0)->is_modules_image(), "first shared_path must be the modules image");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   719
    if (_header->_app_class_paths_start_index > 1) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   720
      DynamicDumpSharedSpaces = false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   721
      warning(
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   722
        "Dynamic archiving is disabled because base layer archive has appended boot classpath");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   723
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   724
    if (_header->_num_module_paths > 0) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   725
      DynamicDumpSharedSpaces = false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   726
      warning(
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   727
        "Dynamic archiving is disabled because base layer archive has module path");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   728
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   729
  }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   730
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
   731
  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
   732
  int shared_app_paths_len = 0;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   733
51439
0517bd2a0eda 8209385: CDS runtime classpath checking is too strict when only classes from the system modules are archived
ccheung
parents: 51070
diff changeset
   734
  // validate the path entries up to the _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
   735
  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
   736
    if (i < module_paths_start_index) {
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   737
      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
   738
        // Only count the app class paths not from the "Class-path" attribute of a jar manifest.
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
   739
        if (!shared_path(i)->from_class_path_attr() && i >= _header->_app_class_paths_start_index) {
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
   740
          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
   741
        }
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   742
        log_info(class, path)("ok");
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   743
      } else {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   744
        if (_dynamic_archive_info != NULL && _dynamic_archive_info->_is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   745
          assert(!UseSharedSpaces, "UseSharedSpaces should be disabled");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   746
        }
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   747
        return false;
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   748
      }
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   749
    } else if (i >= module_paths_start_index) {
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   750
      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
   751
        log_info(class, path)("ok");
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   752
      } else {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   753
        if (_dynamic_archive_info != NULL && _dynamic_archive_info->_is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   754
          assert(!UseSharedSpaces, "UseSharedSpaces should be disabled");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   755
        }
52562
3a9384c12260 8213713: Minor issues during MetaspaceShared::initialize_runtime_shared_and_meta_spaces
jiangli
parents: 52514
diff changeset
   756
        return false;
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   757
      }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   758
    }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   759
  }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   760
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
   761
  if (_header->_max_used_path_index == 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
   762
    // 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
   763
    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
   764
  } 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
   765
    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
   766
      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
   767
      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
   768
    }
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
   769
  }
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
   770
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
   771
  _validating_shared_path_table = false;
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   772
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   773
#if INCLUDE_JVMTI
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   774
  if (_classpath_entries_for_jvmti != NULL) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   775
    os::free(_classpath_entries_for_jvmti);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   776
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   777
  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
   778
  _classpath_entries_for_jvmti = (ClassPathEntry**)os::malloc(sz, mtClass);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   779
  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
   780
#endif
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
   781
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   782
  return true;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   783
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   784
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   785
bool FileMapInfo::check_archive(const char* archive_name, bool is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   786
  int fd = os::open(archive_name, O_RDONLY | O_BINARY, 0);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   787
  if (fd < 0) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   788
    // do not vm_exit_during_initialization here because Arguments::init_shared_archive_paths()
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   789
    // 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
   790
    // failure in opening a shared archive.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   791
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   792
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   793
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   794
  size_t sz = is_static ? sizeof(FileMapHeader) : sizeof(DynamicArchiveHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   795
  void* header = os::malloc(sz, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   796
  memset(header, 0, sz);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   797
  size_t n = os::read(fd, header, (unsigned int)sz);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   798
  if (n != sz) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   799
    os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   800
    os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   801
    vm_exit_during_initialization("Unable to read header from shared archive", archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   802
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   803
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   804
  if (is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   805
    FileMapHeader* static_header = (FileMapHeader*)header;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   806
    if (static_header->_magic != CDS_ARCHIVE_MAGIC) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   807
      os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   808
      os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   809
      vm_exit_during_initialization("Not a base shared archive", archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   810
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   811
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   812
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   813
    DynamicArchiveHeader* dynamic_header = (DynamicArchiveHeader*)header;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   814
    if (dynamic_header->_magic != CDS_DYNAMIC_ARCHIVE_MAGIC) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   815
      os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   816
      os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   817
      vm_exit_during_initialization("Not a top shared archive", archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   818
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   819
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   820
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   821
  os::free(header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   822
  os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   823
  return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   824
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   825
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   826
bool FileMapInfo::get_base_archive_name_from_header(const char* archive_name,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   827
                                                    int* size, char** base_archive_name) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   828
  int fd = os::open(archive_name, O_RDONLY | O_BINARY, 0);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   829
  if (fd < 0) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   830
    *size = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   831
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   832
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   833
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   834
  // read the header as a dynamic archive header
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   835
  size_t sz = sizeof(DynamicArchiveHeader);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   836
  DynamicArchiveHeader* dynamic_header = (DynamicArchiveHeader*)os::malloc(sz, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   837
  size_t n = os::read(fd, dynamic_header, (unsigned int)sz);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   838
  if (n != sz) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   839
    fail_continue("Unable to read the file header.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   840
    os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   841
    os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   842
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   843
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   844
  if (dynamic_header->_magic != CDS_DYNAMIC_ARCHIVE_MAGIC) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   845
    // Not a dynamic header, no need to proceed further.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   846
    *size = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   847
    os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   848
    os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   849
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   850
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   851
  if (dynamic_header->_base_archive_is_default) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   852
    *base_archive_name = Arguments::get_default_shared_archive_path();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   853
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   854
    // skip over the _paths_misc_info
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   855
    sz = dynamic_header->_paths_misc_info_size;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   856
    lseek(fd, (long)sz, SEEK_CUR);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   857
    // read the base archive name
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   858
    size_t name_size = dynamic_header->_base_archive_name_size;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   859
    if (name_size == 0) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   860
      os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   861
      os::close(fd);
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
    *base_archive_name = NEW_C_HEAP_ARRAY(char, name_size, mtInternal);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   865
    n = os::read(fd, *base_archive_name, (unsigned int)name_size);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   866
    if (n != name_size) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   867
      fail_continue("Unable to read the base archive name from the header.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   868
      FREE_C_HEAP_ARRAY(char, *base_archive_name);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   869
      *base_archive_name = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   870
      os::free(dynamic_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
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   873
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   874
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   875
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   876
  os::free(dynamic_header);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   877
  os::close(fd);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   878
  return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   879
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   880
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   881
void FileMapInfo::restore_shared_path_table() {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   882
  _shared_path_table = _current_info->_header->_shared_path_table;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   883
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   884
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   885
// Read the FileMapInfo information from the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   886
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   887
bool FileMapInfo::init_from_file(int fd, bool is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   888
  size_t sz = is_static ? sizeof(FileMapHeader) : sizeof(DynamicArchiveHeader);
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
   889
  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
   890
  if (n != sz) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   891
    fail_continue("Unable to read the file header.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   892
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   893
  }
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
   894
  if (_header->_version != CURRENT_CDS_ARCHIVE_VERSION) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   895
    fail_continue("The shared archive file has the wrong version.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   896
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   897
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   898
  _file_offset = n;
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   899
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   900
  size_t info_size = _header->_paths_misc_info_size;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   901
  _paths_misc_info = NEW_C_HEAP_ARRAY(char, info_size, mtClass);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   902
  n = os::read(fd, _paths_misc_info, (unsigned int)info_size);
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   903
  if (n != info_size) {
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   904
    fail_continue("Unable to read the shared path info header.");
27880
afb974a04396 8060074: os::free() takes MemoryTrackingLevel but doesn't need it
coleenp
parents: 27025
diff changeset
   905
    FREE_C_HEAP_ARRAY(char, _paths_misc_info);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   906
    _paths_misc_info = NULL;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   907
    return false;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   908
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   909
  _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
   910
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   911
  if (is_static) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   912
    if (_header->_magic != CDS_ARCHIVE_MAGIC) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   913
      fail_continue("Incorrect static archive magic number");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   914
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   915
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   916
    // just checking the last region is sufficient since the archive is written
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   917
    // in sequential order
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   918
    size_t len = lseek(fd, 0, SEEK_END);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   919
    CDSFileMapRegion* si = space_at(MetaspaceShared::last_valid_region);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   920
    // The last space might be empty
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   921
    if (si->_file_offset > len || len - si->_file_offset < si->_used) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   922
      fail_continue("The shared archive file has been truncated.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   923
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   924
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   925
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   926
    SharedBaseAddress = _header->_shared_base_address;
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
   927
  }
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
   928
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   931
489c9b5090e2 Initial load
duke
parents:
diff changeset
   932
489c9b5090e2 Initial load
duke
parents:
diff changeset
   933
// Read the FileMapInfo information from the file.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   934
bool FileMapInfo::open_for_read(const char* path) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   935
  if (_file_open) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   936
    return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   937
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   938
  if (path == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   939
    _full_path = Arguments::GetSharedArchivePath();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   940
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   941
    _full_path = path;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   942
  }
53911
65f2a401e0eb 8218811: replace open by os::open in hotspot coding
mbaesken
parents: 53884
diff changeset
   943
  int fd = os::open(_full_path, O_RDONLY | O_BINARY, 0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   944
  if (fd < 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   945
    if (errno == ENOENT) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   946
      // Not locating the shared archive is ok.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   947
      fail_continue("Specified shared archive not found (%s).", _full_path);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   948
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   949
      fail_continue("Failed to open shared archive file (%s).",
37113
5a33bf5089ac 8148425: strerror() function is not thread-safe
stuefe
parents: 36364
diff changeset
   950
                    os::strerror(errno));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   951
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   952
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   954
489c9b5090e2 Initial load
duke
parents:
diff changeset
   955
  _fd = fd;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   956
  _file_open = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   957
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   958
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   959
489c9b5090e2 Initial load
duke
parents:
diff changeset
   960
// Write the FileMapInfo information to the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   961
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   962
void FileMapInfo::open_for_write(const char* path) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   963
  if (path == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   964
    _full_path = Arguments::GetSharedArchivePath();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   965
  } else {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   966
    _full_path = path;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   967
  }
48962
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
   968
  LogMessage(cds) msg;
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
   969
  if (msg.is_info()) {
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
   970
    msg.info("Dumping shared data to file: ");
88ad6c676c87 8194994: Remove redundant string streams used for logging
mlarsson
parents: 48794
diff changeset
   971
    msg.info("   %s", _full_path);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   972
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   973
15461
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
   974
#ifdef _WINDOWS  // On Windows, need WRITE permission to remove the file.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   975
    chmod(_full_path, _S_IREAD | _S_IWRITE);
15461
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
   976
#endif
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
   977
e3acbfdabafa 7197672: There are issues with shared data on windows
hseigel
parents: 15101
diff changeset
   978
  // 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
   979
  // allow processes that have it open continued access to the file.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   980
  remove(_full_path);
53911
65f2a401e0eb 8218811: replace open by os::open in hotspot coding
mbaesken
parents: 53884
diff changeset
   981
  int fd = os::open(_full_path, O_RDWR | O_CREAT | O_TRUNC | O_BINARY, 0444);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   982
  if (fd < 0) {
28950
693ae3d5e1ff 8072694: Need errno info when CDS archive creation fails
hseigel
parents: 28023
diff changeset
   983
    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
   984
              os::strerror(errno));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   985
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   986
  _fd = fd;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   987
  _file_offset = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   988
  _file_open = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   989
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   990
489c9b5090e2 Initial load
duke
parents:
diff changeset
   991
489c9b5090e2 Initial load
duke
parents:
diff changeset
   992
// Write the header to the file, seek to the next allocation boundary.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   993
489c9b5090e2 Initial load
duke
parents:
diff changeset
   994
void FileMapInfo::write_header() {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   995
  int info_size = ClassLoader::get_shared_paths_misc_info_size();
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   996
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   997
  _header->_paths_misc_info_size = info_size;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
   998
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
   999
  char* base_archive_name = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1000
  if (_header->_magic == CDS_DYNAMIC_ARCHIVE_MAGIC) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1001
    base_archive_name = (char*)Arguments::GetSharedArchivePath();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1002
    _header->_base_archive_name_size = (int)strlen(base_archive_name) + 1;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1003
    _header->_base_archive_is_default = FLAG_IS_DEFAULT(SharedArchiveFile);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1004
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1005
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1006
  assert(is_file_position_aligned(), "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1007
  write_bytes(_header, _header->_header_size);
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1008
  write_bytes(ClassLoader::get_shared_paths_misc_info(), (size_t)info_size);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1009
  if (base_archive_name != NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1010
    write_bytes(base_archive_name, (size_t)_header->_base_archive_name_size);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1011
  }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1012
  align_file_position();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1013
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1014
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1015
// Dump region to file.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1016
// This is called twice for each region during archiving, once before
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1017
// the archive file is open (_file_open is false) and once after.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1018
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
  1019
                               bool read_only, bool allow_exec) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1020
  assert(DumpSharedSpaces || DynamicDumpSharedSpaces, "Dump time only");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1021
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1022
  CDSFileMapRegion* si = space_at(region);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1023
  char* target_base = base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1024
  if (DynamicDumpSharedSpaces) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1025
    target_base = DynamicArchive::buffer_to_target(base);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1026
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1027
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1028
  if (_file_open) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1029
    guarantee(si->_file_offset == _file_offset, "file offset mismatch.");
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1030
    log_info(cds)("Shared file region %d: " SIZE_FORMAT_HEX_W(08)
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1031
                  " bytes, addr " INTPTR_FORMAT " file offset " SIZE_FORMAT_HEX_W(08),
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1032
                  region, size, p2i(target_base), _file_offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1033
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1034
    si->_file_offset = _file_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1035
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1036
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1037
  if (HeapShared::is_heap_region(region)) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1038
    assert((target_base - (char*)CompressedKlassPointers::base()) % HeapWordSize == 0, "Sanity");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1039
    if (target_base != NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1040
      si->_addr._offset = (intx)CompressedOops::encode_not_null((oop)target_base);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1041
    } else {
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1042
      si->_addr._offset = 0;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1043
    }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1044
  } else {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1045
    si->_addr._base = target_base;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1046
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1047
  si->_used = size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1048
  si->_read_only = read_only;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1049
  si->_allow_exec = allow_exec;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1050
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1051
  // Use the current 'base' when computing the CRC value and writing out data
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1052
  si->_crc = ClassLoader::crc32(0, base, (jint)size);
51070
2f4c3cac8556 8206977: Minor improvements of runtime code.
goetz
parents: 50199
diff changeset
  1053
  if (base != NULL) {
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1054
    write_bytes_aligned(base, size);
51070
2f4c3cac8556 8206977: Minor improvements of runtime code.
goetz
parents: 50199
diff changeset
  1055
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1056
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1057
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1058
// 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
  1059
// 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
  1060
// 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
  1061
//
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1062
// 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
  1063
// size, there is only one MemRegion in the array.
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1064
//
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1065
// 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
  1066
// 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
  1067
// 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
  1068
// 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
  1069
// 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
  1070
// GC regions are combined into another MemRegion.
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1071
//
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1072
// 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
  1073
//   + 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
  1074
//   + 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
  1075
//
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1076
// 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
  1077
// Otherwise:
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1078
//
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1079
// "X" represented space that's occupied by heap objects.
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1080
// "_" represented unused spaced in the heap region.
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1081
//
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1082
//
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1083
//    |ah0       | ah1 | ah2| ...... | ahn|
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1084
//    |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
  1085
//    |<-r0->|   |<- r1 ----------------->|
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1086
//            ^^^
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1087
//             |
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1088
//             +-- gap
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1089
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
  1090
                                               GrowableArray<ArchiveHeapOopmapInfo> *oopmaps,
52514
f4e3900c8d08 8213346: Re-implement shared dictionary using CompactHashtable
iklam
parents: 52402
diff changeset
  1091
                                               int first_region_id, int max_num_regions,
f4e3900c8d08 8213346: Re-implement shared dictionary using CompactHashtable
iklam
parents: 52402
diff changeset
  1092
                                               bool print_log) {
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1093
  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
  1094
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1095
  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
  1096
  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
  1097
    fail_stop("Unable to write archive heap memory regions: "
52811
ff04b71bf6f1 8214388: CDS dumping fails with java heap fragmentation
iklam
parents: 52702
diff changeset
  1098
              "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
  1099
              "Please increase java heap size "
10c6e9066819 8214217: [TESTBUG] runtime/appcds/LotsOfClasses.java failed with fragmented heap
jiangli
parents: 52674
diff changeset
  1100
              "(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
  1101
              MaxHeapSize, InitialHeapSize);
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1102
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1103
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1104
  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
  1105
  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
  1106
           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
  1107
           i++, arr_idx++) {
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1108
    char* start = NULL;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1109
    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
  1110
    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
  1111
      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
  1112
      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
  1113
      total_size += size;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1114
    }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1115
52514
f4e3900c8d08 8213346: Re-implement shared dictionary using CompactHashtable
iklam
parents: 52402
diff changeset
  1116
    if (print_log) {
f4e3900c8d08 8213346: Re-implement shared dictionary using CompactHashtable
iklam
parents: 52402
diff changeset
  1117
      log_info(cds)("Archive heap region %d " INTPTR_FORMAT " - " INTPTR_FORMAT " = " SIZE_FORMAT_W(8) " bytes",
f4e3900c8d08 8213346: Re-implement shared dictionary using CompactHashtable
iklam
parents: 52402
diff changeset
  1118
                    i, p2i(start), p2i(start + size), size);
f4e3900c8d08 8213346: Re-implement shared dictionary using CompactHashtable
iklam
parents: 52402
diff changeset
  1119
    }
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1120
    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
  1121
    if (size > 0) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1122
      space_at(i)->_oopmap = oopmaps->at(arr_idx)._oopmap;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1123
      space_at(i)->_oopmap_size_in_bits = oopmaps->at(arr_idx)._oopmap_size_in_bits;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1124
    }
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1125
  }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1126
  return total_size;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1127
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1128
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1129
// Dump bytes to file -- at the current file position.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1130
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1131
void FileMapInfo::write_bytes(const void* buffer, size_t nbytes) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1132
  if (_file_open) {
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1133
    size_t n = os::write(_fd, buffer, (unsigned int)nbytes);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1134
    if (n != nbytes) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1135
      // If the shared archive is corrupted, close it and remove it.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1136
      close();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1137
      remove(_full_path);
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1138
      fail_stop("Unable to write to shared archive file.");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1139
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1140
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1141
  _file_offset += nbytes;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1142
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1143
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1144
bool FileMapInfo::is_file_position_aligned() const {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1145
  return _file_offset == align_up(_file_offset,
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1146
                                  os::vm_allocation_granularity());
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1147
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1148
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1149
// Align file position to an allocation unit boundary.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1150
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
void FileMapInfo::align_file_position() {
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1152
  size_t new_file_offset = align_up(_file_offset,
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1153
                                         os::vm_allocation_granularity());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1154
  if (new_file_offset != _file_offset) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1155
    _file_offset = new_file_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1156
    if (_file_open) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1157
      // Seek one byte back from the target and write a byte to insure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
      // that the written file is the correct length.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
      _file_offset -= 1;
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1160
      if (lseek(_fd, (long)_file_offset, SEEK_SET) < 0) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1161
        fail_stop("Unable to seek.");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
      char zero = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1164
      write_bytes(&zero, 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1165
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1166
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1167
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1168
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1169
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1170
// Dump bytes to file -- at the current file position.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1171
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1172
void FileMapInfo::write_bytes_aligned(const void* buffer, size_t nbytes) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1173
  align_file_position();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
  write_bytes(buffer, nbytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1175
  align_file_position();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1176
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1178
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1179
// Close the shared archive file.  This does NOT unmap mapped regions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1180
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1181
void FileMapInfo::close() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1182
  if (_file_open) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1183
    if (::close(_fd) < 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1184
      fail_stop("Unable to close the shared archive file.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1185
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1186
    _file_open = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1187
    _fd = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1188
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1189
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1190
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1191
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1192
// JVM/TI RedefineClasses() support:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
// Remap the shared readonly space to shared readwrite, private.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
bool FileMapInfo::remap_shared_readonly_as_readwrite() {
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1195
  int idx = MetaspaceShared::ro;
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1196
  CDSFileMapRegion* si = space_at(idx);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1197
  if (!si->_read_only) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
    // the space is already readwrite so we are done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
    return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
  size_t used = si->_used;
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1202
  size_t size = align_up(used, os::vm_allocation_granularity());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
  if (!open_for_read()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
  }
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1206
  char *addr = region_addr(idx);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1207
  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
  1208
                                addr, size, false /* !read_only */,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
                                si->_allow_exec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
  close();
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1211
  // These have to be errors because the shared region is now unmapped.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1212
  if (base == NULL) {
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1213
    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
  1214
    vm_exit(1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1215
  }
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1216
  if (base != addr) {
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1217
    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
  1218
    vm_exit(1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1219
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1220
  si->_read_only = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1221
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1222
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1223
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1224
// 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
  1225
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
  1226
  char* requested_addr = region_addr(0);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1227
  size_t size = FileMapInfo::core_spaces_size();
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1228
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1229
  // 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
  1230
  // other reserved memory (like the code cache).
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1231
  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
  1232
  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
  1233
    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
  1234
                  INTPTR_FORMAT, p2i(requested_addr));
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1235
    return rs;
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1236
  }
14120
7d298141c258 7199092: NMT: NMT needs to deal overlapped virtual memory ranges
zgu
parents: 13728
diff changeset
  1237
  // 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
  1238
  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
  1239
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1240
  return rs;
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1241
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1242
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
// Memory map a region in the address space.
55296
357c9dcb6eb9 8224497: Remove FIXME in metaspaceClosure.cpp
ccheung
parents: 54927
diff changeset
  1244
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
  1245
                                            "String1", "String2", "OpenArchive1", "OpenArchive2" };
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1246
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1247
char* FileMapInfo::map_regions(int regions[], char* saved_base[], size_t len) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1248
  char* prev_top = NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1249
  char* curr_base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1250
  char* curr_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1251
  int i = 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1252
  for (i = 0; i < (int)len; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1253
    curr_base = map_region(regions[i], &curr_top);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1254
    if (curr_base == NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1255
      return NULL;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1256
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1257
    if (i > 0) {
55296
357c9dcb6eb9 8224497: Remove FIXME in metaspaceClosure.cpp
ccheung
parents: 54927
diff changeset
  1258
      // 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
  1259
      // 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
  1260
      // allocate any new memory spaces inside _shared_metaspace_{base,top}, which
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1261
      // would mess up the simple comparision in MetaspaceShared::is_in_shared_metaspace().
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1262
      assert(curr_base == prev_top, "must be");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1263
    }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1264
    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
  1265
    saved_base[i] = curr_base;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1266
    prev_top = curr_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1267
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1268
  return curr_top;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1269
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1270
48794
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1271
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
  1272
  assert(!HeapShared::is_heap_region(i), "sanity");
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1273
  CDSFileMapRegion* si = space_at(i);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1274
  size_t used = si->_used;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1275
  size_t alignment = os::vm_allocation_granularity();
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1276
  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
  1277
  char *requested_addr = region_addr(i);
31332
dc17890f352d 8054386: Allow Java debugging when CDS is enabled
cjplummer
parents: 28950
diff changeset
  1278
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1279
#ifdef _WINDOWS
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1280
  // 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
  1281
  // RedefineClasses, which is also used by JFR.  Always map windows regions as RW.
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1282
  si->_read_only = false;
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1283
#else
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1284
  // 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
  1285
  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
  1286
      Arguments::has_jfr_option()) {
31375
aa5ecd9a5716 8087153: EXCEPTION_ACCESS_VIOLATION when CDS RO section vanished on win32
cjplummer
parents: 31364
diff changeset
  1287
    si->_read_only = false;
31332
dc17890f352d 8054386: Allow Java debugging when CDS is enabled
cjplummer
parents: 28950
diff changeset
  1288
  }
54573
b73893f7fee3 8222379: JFR TestClassLoadEvent.java failed due to EXCEPTION_ACCESS_VIOLATION
coleenp
parents: 54340
diff changeset
  1289
#endif // _WINDOWS
31332
dc17890f352d 8054386: Allow Java debugging when CDS is enabled
cjplummer
parents: 28950
diff changeset
  1290
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 7405
diff changeset
  1291
  // map the contents of the CDS archive in this memory
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
  char *base = os::map_memory(_fd, _full_path, si->_file_offset,
31375
aa5ecd9a5716 8087153: EXCEPTION_ACCESS_VIOLATION when CDS RO section vanished on win32
cjplummer
parents: 31364
diff changeset
  1293
                              requested_addr, size, si->_read_only,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
                              si->_allow_exec);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1295
  if (base == NULL || base != requested_addr) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1296
    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
  1297
    _memory_mapping_failed = true;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
    return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
  }
15100
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1300
#ifdef _WINDOWS
0ae85ac7c8b0 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 14577
diff changeset
  1301
  // 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
  1302
  // 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
  1303
  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
  1304
#endif
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1305
54838
d7819bedfaaf 8221478: Disable VerifySharedSpaces by default
redestad
parents: 54825
diff changeset
  1306
  if (VerifySharedSpaces && !verify_region_checksum(i)) {
48794
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1307
    return NULL;
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1308
  }
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1309
ea0d0781c63c 8178351: Simplify MetaspaceShared::is_in_shared_space and MetaspaceObj::is_shared
iklam
parents: 47991
diff changeset
  1310
  *top_ret = base + size;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1311
  return base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1312
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1313
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1314
size_t FileMapInfo::read_bytes(void* buffer, size_t count) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1315
  assert(_file_open, "Archive file is not open");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1316
  size_t n = os::read(_fd, buffer, (unsigned int)count);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1317
  if (n != count) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1318
    // Close the file if there's a problem reading it.
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1319
    close();
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1320
    return 0;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1321
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1322
  _file_offset += count;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1323
  return count;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1324
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1325
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1326
address FileMapInfo::decode_start_address(CDSFileMapRegion* spc, bool 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
  1327
  if (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
  1328
    return (address)CompressedOops::decode_not_null(offset_of_space(spc));
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1329
  } else {
51720
b7bfd64e43a6 8210523: runtime/appcds/cacheObject/DifferentHeapSizes.java crash
iklam
parents: 51491
diff changeset
  1330
    return (address)HeapShared::decode_from_archive(offset_of_space(spc));
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1331
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1332
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1333
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1334
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
  1335
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
  1336
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
  1337
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
  1338
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1339
#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
  1340
bool FileMapInfo::has_heap_regions() {
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1341
  return (_header->_space[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
  1342
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1343
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1344
// 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
  1345
// 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
  1346
// 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
  1347
// 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
  1348
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
  1349
  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
  1350
  address end   = NULL;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1351
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1352
  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
  1353
           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
  1354
           i++) {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1355
    CDSFileMapRegion* si = space_at(i);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1356
    size_t size = si->_used;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1357
    if (size > 0) {
51720
b7bfd64e43a6 8210523: runtime/appcds/cacheObject/DifferentHeapSizes.java crash
iklam
parents: 51491
diff changeset
  1358
      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
  1359
      address e = s + size;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1360
      if (start > s) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1361
        start = s;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1362
      }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1363
      if (end < e) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1364
        end = e;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1365
      }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1366
    }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1367
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1368
  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
  1369
  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
  1370
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1371
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1372
//
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1373
// 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
  1374
//
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1375
// 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
  1376
// 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
  1377
// 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
  1378
// 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
  1379
//
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1380
// 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
  1381
// 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
  1382
// 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
  1383
// 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
  1384
// 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
  1385
// open archive objects.
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1386
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
  1387
  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
  1388
    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
  1389
                  "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
  1390
    return;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1391
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1392
52319
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1393
  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
  1394
    ShouldNotReachHere(); // CDS should have been disabled.
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1395
    // 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
  1396
    // 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
  1397
    // 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
  1398
    // 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
  1399
    //
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1400
    // 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
  1401
    // 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
  1402
    // 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
  1403
    // 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
  1404
  }
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1405
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1406
  MemRegion heap_reserved = Universe::heap()->reserved_region();
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1407
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1408
  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
  1409
                max_heap_size()/M);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1410
  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
  1411
                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
  1412
  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
  1413
                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
  1414
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1415
  log_info(cds)("The current max heap size = " SIZE_FORMAT "M, HeapRegion::GrainBytes = " SIZE_FORMAT,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1416
                heap_reserved.byte_size()/M, HeapRegion::GrainBytes);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1417
  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
  1418
                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
  1419
  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
  1420
                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
  1421
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1422
  if (narrow_klass_base() != CompressedKlassPointers::base() ||
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1423
      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
  1424
    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
  1425
    return;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1426
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1427
54780
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1428
  if (narrow_oop_mode() != CompressedOops::mode() ||
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1429
      narrow_oop_base() != CompressedOops::base() ||
f8d182aedc92 8223136: Move compressed oops functions to CompressedOops class
stefank
parents: 54573
diff changeset
  1430
      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
  1431
    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
  1432
    _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
  1433
  } else {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1434
    MemRegion range = 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
  1435
    if (!heap_reserved.contains(range)) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1436
      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
  1437
      log_info(cds)("the desired range " PTR_FORMAT " - "  PTR_FORMAT, p2i(range.start()), p2i(range.end()));
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1438
      log_info(cds)("is outside of the heap " PTR_FORMAT " - "  PTR_FORMAT, p2i(heap_reserved.start()), p2i(heap_reserved.end()));
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1439
      _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
  1440
    }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1441
  }
47599
0fb1d501c408 8174986: CDS archived java heap region may not compatible with AOT
jiangli
parents: 47216
diff changeset
  1442
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1443
  ptrdiff_t delta = 0;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1444
  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
  1445
    //   dumptime heap end  ------------v
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1446
    //   [      |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
  1447
    //                                       [   |archived heap regions| ]
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1448
    //                                  |<-----delta-------------------->|
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1449
    //
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1450
    // 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
  1451
    // 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
  1452
    // 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
  1453
    // the simple math of adding the delta as shown above.
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1454
    address dumptime_heap_end = (address)_header->_heap_reserved.end();
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1455
    address runtime_heap_end = (address)heap_reserved.end();
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1456
    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
  1457
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1458
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1459
  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
  1460
  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
  1461
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1462
  CDSFileMapRegion* si = space_at(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
  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
  1464
  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
  1465
    // 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
  1466
    // 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
  1467
    // 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
  1468
    // open regions.
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1469
    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
  1470
    delta -= align;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1471
    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
  1472
                  " 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
  1473
                  align, delta);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1474
    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
  1475
    _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
  1476
    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
  1477
  }
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1478
  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
  1479
         "must be");
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1480
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1481
  // 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
  1482
  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
  1483
                    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
  1484
                    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
  1485
                    &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
  1486
    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
  1487
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1488
    // 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
  1489
    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
  1490
                      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
  1491
                      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
  1492
                      &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
  1493
                      true /* open */)) {
52062
8dbf1a13af49 8206009: Move CDS java heap object archiving code to heapShared.hpp and heapShared.cpp
jiangli
parents: 51823
diff changeset
  1494
      HeapShared::set_open_archive_heap_region_mapped();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1495
    }
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1496
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1497
}
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1498
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1499
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
  1500
  if (has_heap_regions()) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1501
    map_heap_regions_impl();
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1502
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1503
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1504
  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
  1505
    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
  1506
           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
  1507
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1508
52062
8dbf1a13af49 8206009: Move CDS java heap object archiving code to heapShared.hpp and heapShared.cpp
jiangli
parents: 51823
diff changeset
  1509
  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
  1510
    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
  1511
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1512
}
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1513
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1514
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
  1515
                                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
  1516
  MemRegion * regions = new MemRegion[max];
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1517
  CDSFileMapRegion* si;
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1518
  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
  1519
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1520
  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
  1521
           i < first + max; i++) {
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1522
    si = space_at(i);
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1523
    size_t size = si->_used;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1524
    if (size > 0) {
51720
b7bfd64e43a6 8210523: runtime/appcds/cacheObject/DifferentHeapSizes.java crash
iklam
parents: 51491
diff changeset
  1525
      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
  1526
      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
  1527
      region_num ++;
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1528
      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
  1529
                    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
  1530
    }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1531
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1532
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1533
  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
  1534
    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
  1535
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1536
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1537
  // 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
  1538
  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
  1539
    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
  1540
    return false;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1541
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1542
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1543
  // 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
  1544
  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
  1545
             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
  1546
    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
  1547
    return false;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1548
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1549
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1550
  // 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
  1551
  // 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
  1552
  // already recorded.
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1553
  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
  1554
    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
  1555
    char* addr = (char*)regions[i].start();
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1556
    char* base = os::map_memory(_fd, _full_path, si->_file_offset,
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1557
                                addr, regions[i].byte_size(), si->_read_only,
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1558
                                si->_allow_exec);
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1559
    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
  1560
      // dealloc the regions from java heap
52674
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1561
      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
  1562
      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
  1563
                    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
  1564
                    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
  1565
      return false;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1566
    }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1567
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1568
    if (VerifySharedSpaces && !region_crc_check(addr, regions[i].byte_size(), si->_crc)) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1569
      // dealloc the regions from java heap
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1570
      dealloc_archive_heap_regions(regions, region_num, is_open_archive);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1571
      log_info(cds)("UseSharedSpaces: mapped heap regions are corrupt");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1572
      return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1573
    }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1574
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1575
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1576
  // 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
  1577
  *heap_mem = regions;
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1578
  *num = region_num;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1579
  return true;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1580
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1581
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1582
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
  1583
  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
  1584
    return;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1585
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1586
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1587
  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
  1588
                                        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
  1589
                                        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
  1590
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1591
  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
  1592
                                        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
  1593
                                        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
  1594
}
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
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
  1597
                                                        int first_region_idx) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1598
  for (int i=0; i<num_ranges; i++) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1599
    CDSFileMapRegion* si = space_at(i + first_region_idx);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1600
    HeapShared::patch_archived_heap_embedded_pointers(ranges[i], (address)si->_oopmap,
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1601
                                                      si->_oopmap_size_in_bits);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1602
  }
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1603
}
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
// 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
  1606
// 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
  1607
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
  1608
  // 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
  1609
  // 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
  1610
  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
  1611
    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
  1612
           "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
  1613
    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
  1614
                                                  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
  1615
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1616
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1617
  // 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
  1618
  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
  1619
    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
  1620
    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
  1621
                                                  num_open_archive_heap_ranges);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1622
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1623
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1624
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1625
// dealloc the archive regions from java heap
52674
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1626
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
  1627
  if (num > 0) {
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1628
    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
  1629
    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
  1630
  }
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1631
}
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1632
#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
  1633
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1634
bool FileMapInfo::region_crc_check(char* buf, size_t size, int expected_crc) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1635
  int crc = ClassLoader::crc32(0, buf, (jint)size);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1636
  if (crc != expected_crc) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1637
    fail_continue("Checksum verification failed.");
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1638
    return false;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1639
  }
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1640
  return true;
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1641
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1642
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1643
bool FileMapInfo::verify_region_checksum(int i) {
54838
d7819bedfaaf 8221478: Disable VerifySharedSpaces by default
redestad
parents: 54825
diff changeset
  1644
  assert(VerifySharedSpaces, "sanity");
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1645
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1646
  size_t sz = space_at(i)->_used;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1647
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1648
  if (sz == 0) {
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1649
    return true; // no data
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1650
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1651
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1652
  return region_crc_check(region_addr(i), sz, space_at(i)->_crc);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1653
}
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1654
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1655
void FileMapInfo::unmap_regions(int regions[], char* saved_base[], size_t len) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1656
  for (int i = 0; i < (int)len; i++) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1657
    if (saved_base[i] != NULL) {
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1658
      unmap_region(regions[i]);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1659
    }
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1660
  }
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1661
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1662
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1663
// Unmap a memory region in the address space.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1664
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1665
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
  1666
  assert(!HeapShared::is_heap_region(i), "sanity");
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1667
  CDSFileMapRegion* si = space_at(i);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1668
  size_t used = si->_used;
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 46560
diff changeset
  1669
  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
  1670
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1671
  if (used == 0) {
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1672
    return;
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1673
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1674
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1675
  char* addr = region_addr(i);
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1676
  if (!os::unmap_memory(addr, size)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1677
    fail_stop("Unable to unmap shared space.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1678
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1679
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1680
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1681
void FileMapInfo::assert_mark(bool check) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1682
  if (!check) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1683
    fail_stop("Mark mismatch while restoring from shared file.");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1684
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1685
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1686
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1687
void FileMapInfo::metaspace_pointers_do(MetaspaceClosure* it) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1688
  _shared_path_table.metaspace_pointers_do(it);
46746
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1689
}
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1690
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1691
FileMapInfo* FileMapInfo::_current_info = NULL;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1692
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
  1693
bool FileMapInfo::_heap_pointers_need_patching = false;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1694
SharedPathTable FileMapInfo::_shared_path_table;
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
  1695
bool FileMapInfo::_validating_shared_path_table = false;
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1696
bool FileMapInfo::_memory_mapping_failed = false;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1697
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1698
// Open the shared archive file, read and validate the header
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1699
// information (version, boot classpath, etc.).  If initialization
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1700
// fails, shared spaces are disabled and the file is closed. [See
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1701
// fail_continue.]
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1702
//
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1703
// Validation of the archive is done in two steps:
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1704
//
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1705
// [1] validate_header() - done here. This checks the header, including _paths_misc_info.
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
  1706
// [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
  1707
//     region of the archive, which is not mapped yet.
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1708
bool FileMapInfo::initialize(bool is_static) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1709
  assert(UseSharedSpaces, "UseSharedSpaces expected.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1710
52319
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1711
  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
  1712
    // 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
  1713
    // 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
  1714
    // 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
  1715
    // 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
  1716
    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
  1717
    return false;
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1718
  }
625f6c742392 8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents: 52314
diff changeset
  1719
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1720
  if (!open_for_read()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1721
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1722
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1723
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1724
  init_from_file(_fd, is_static);
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1725
  if (!validate_header(is_static)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1726
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1727
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1728
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1729
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1730
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1731
char* FileMapInfo::region_addr(int idx) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1732
  CDSFileMapRegion* 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
  1733
  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
  1734
    assert(DumpSharedSpaces, "The following doesn't work at runtime");
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1735
    return si->_used > 0 ?
51720
b7bfd64e43a6 8210523: runtime/appcds/cacheObject/DifferentHeapSizes.java crash
iklam
parents: 51491
diff changeset
  1736
          (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
  1737
  } else {
51491
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1738
    return si->_addr._base;
31345
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1739
  }
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1740
}
1bba15125d8d 8015086: add interned strings to the shared archive.
jiangli
parents: 31332
diff changeset
  1741
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1742
int FileMapHeader::compute_crc() {
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1743
  char* start = (char*)this;
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1744
  // start computing from the field after _crc
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1745
  char* buf = (char*)&_crc + sizeof(_crc);
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1746
  size_t sz = _header_size - (buf - start);
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1747
  int crc = ClassLoader::crc32(0, buf, (jint)sz);
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1748
  return crc;
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1749
}
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1750
49739
00805b129186 8194812: Extend class-data sharing to support the module path
ccheung
parents: 49592
diff changeset
  1751
// 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
  1752
bool FileMapHeader::validate() {
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1753
  if (VerifySharedSpaces && compute_crc() != _crc) {
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1754
    FileMapInfo::fail_continue("Header checksum verification failed.");
27025
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1755
    return false;
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1756
  }
f4805f778f16 8044269: Analysis of archive files.
jiangli
parents: 26296
diff changeset
  1757
40013
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
  1758
  if (!Arguments::has_jimage()) {
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
  1759
    FileMapInfo::fail_continue("The shared archive file cannot be used with an exploded module build.");
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
  1760
    return false;
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
  1761
  }
943cf01a6b82 8154239: -Xbootclasspath/a breaks exploded build
lfoltan
parents: 38207
diff changeset
  1762
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1763
  if (_version != CURRENT_CDS_ARCHIVE_VERSION) {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1764
    FileMapInfo::fail_continue("The shared archive file is the wrong version.");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1765
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1766
  }
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1767
  if (_magic != CDS_ARCHIVE_MAGIC && _magic != CDS_DYNAMIC_ARCHIVE_MAGIC) {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1768
    FileMapInfo::fail_continue("The shared archive file has a bad magic number.");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1769
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1770
  }
14577
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
  1771
  char header_version[JVM_IDENT_MAX];
fd68d810d86b 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 14120
diff changeset
  1772
  get_header_version(header_version);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1773
  if (strncmp(_jvm_ident, header_version, JVM_IDENT_MAX-1) != 0) {
38151
fffedc5e5cf8 8154110: Update class* and safepoint* logging subsystems
mockner
parents: 38108
diff changeset
  1774
    log_info(class, path)("expected: %s", header_version);
fffedc5e5cf8 8154110: Update class* and safepoint* logging subsystems
mockner
parents: 38108
diff changeset
  1775
    log_info(class, path)("actual:   %s", _jvm_ident);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1776
    FileMapInfo::fail_continue("The shared archive file was created by a different"
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1777
                  " version or build of HotSpot");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1778
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1779
  }
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1780
  if (_obj_alignment != ObjectAlignmentInBytes) {
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1781
    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
  1782
                  " does not equal the current ObjectAlignmentInBytes of " INTX_FORMAT ".",
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1783
                  _obj_alignment, ObjectAlignmentInBytes);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1784
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1785
  }
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1786
  if (_compact_strings != CompactStrings) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1787
    FileMapInfo::fail_continue("The shared archive file's CompactStrings setting (%s)"
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1788
                  " does not equal the current CompactStrings setting (%s).",
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1789
                  _compact_strings ? "enabled" : "disabled",
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1790
                  CompactStrings   ? "enabled" : "disabled");
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1791
    return false;
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33148
diff changeset
  1792
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1793
50039
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1794
  // 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
  1795
  // header data
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1796
  const char* prop = Arguments::get_property("java.system.class.loader");
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1797
  if (prop != NULL) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1798
    warning("Archived non-system classes are disabled because the "
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1799
            "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
  1800
            "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
  1801
    _has_platform_or_app_classes = false;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1802
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1803
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1804
  // For backwards compatibility, we don't check the verification setting
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1805
  // if the archive only contains system classes.
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1806
  if (_has_platform_or_app_classes &&
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1807
      ((!_verify_local && BytecodeVerificationLocal) ||
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1808
       (!_verify_remote && BytecodeVerificationRemote))) {
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1809
    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
  1810
                  "verification setting than the current setting.");
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1811
    return false;
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1812
  }
9fec54fe663d 8197954: Remove unnecessary intermediary APIs from AppCDS implementation
iklam
parents: 49982
diff changeset
  1813
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
  1814
  // 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
  1815
  // 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
  1816
  // 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
  1817
  // 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
  1818
  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
  1819
    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
  1820
                               "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
  1821
    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
  1822
  }
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1823
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1824
  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
  1825
    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
  1826
            "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
  1827
  }
dfa02b3f728c 8201375: Add the AllowArchivingWithJavaAgent diagnostic vm option to allow the use of the -javaagent option during CDS dumping
ccheung
parents: 52562
diff changeset
  1828
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1829
  return true;
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
bool FileMapInfo::validate_header(bool is_static) {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1833
  bool status = _header->validate();
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1834
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1835
  if (status) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1836
    if (!ClassLoader::check_shared_paths_misc_info(_paths_misc_info, _header->_paths_misc_info_size, is_static)) {
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1837
      if (!PrintSharedArchiveAndExit) {
38151
fffedc5e5cf8 8154110: Update class* and safepoint* logging subsystems
mockner
parents: 38108
diff changeset
  1838
        fail_continue("shared class paths mismatch (hint: enable -Xlog:class+path=info to diagnose the failure)");
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1839
        status = false;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1840
      }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1841
    }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1842
  }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1843
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1844
  if (_paths_misc_info != NULL) {
27880
afb974a04396 8060074: os::free() takes MemoryTrackingLevel but doesn't need it
coleenp
parents: 27025
diff changeset
  1845
    FREE_C_HEAP_ARRAY(char, _paths_misc_info);
26135
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1846
    _paths_misc_info = NULL;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1847
  }
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1848
  return status;
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1849
}
82b516c550f7 8046070: Class Data Sharing clean up and refactoring
iklam
parents: 25715
diff changeset
  1850
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1851
// 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
  1852
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
  1853
  assert(idx == MetaspaceShared::ro ||
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1854
         idx == MetaspaceShared::rw ||
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1855
         idx == MetaspaceShared::mc ||
ea379ebb9447 8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents: 46742
diff changeset
  1856
         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
  1857
  char* base = region_addr(idx);
51477
e77d7687c831 8209657: Refactor filemap.hpp to simplify integration with Serviceability Agent
iklam
parents: 51439
diff changeset
  1858
  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
  1859
    return true;
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1860
  }
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1861
  return false;
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1862
}
e8970711113b 8145221: Use trampolines for i2i and i2c entries in Methods that are stored in CDS archive
ccheung
parents: 37179
diff changeset
  1863
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1864
// Unmap mapped regions of shared space.
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1865
void FileMapInfo::stop_sharing_and_unmap(const char* msg) {
54927
1512d88b24c6 8207812: Implement Dynamic CDS Archive
ccheung
parents: 54838
diff changeset
  1866
  MetaspaceShared::set_shared_metaspace_range(NULL, NULL);
52314
e53af5fa0dae 8212205: VM asserts after CDS archive has been unmapped
iklam
parents: 52126
diff changeset
  1867
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1868
  FileMapInfo *map_info = FileMapInfo::current_info();
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1869
  if (map_info) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1870
    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
  1871
    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
  1872
      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
  1873
        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
  1874
        if (addr != NULL) {
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1875
          map_info->unmap_region(i);
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1876
          map_info->space_at(i)->_addr._base = NULL;
187c84a5efe1 8208658: Make CDS archived heap regions usable even if compressed oop encoding has changed
iklam
parents: 51480
diff changeset
  1877
        }
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1878
      }
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1879
    }
46810
7dad333205cd 8179302: Pre-resolve constant pool string entries and cache resolved_reference arrays in CDS archive.
jiangli
parents: 46746
diff changeset
  1880
    // 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
  1881
    // 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
  1882
    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
  1883
                                           num_open_archive_heap_ranges,
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1884
                                           true);
52402
72d4e10305b9 8212995: Placing the Integer.IntegerCache and cached Integer objects in the closed archive heap region.
jiangli
parents: 52319
diff changeset
  1885
    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
  1886
                                           num_closed_archive_heap_ranges,
c9325aa887da 8214118: HeapRegions marked as archive even if CDS mapping fails
sjohanss
parents: 52596
diff changeset
  1887
                                           false);
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1888
  } else if (DumpSharedSpaces) {
26296
fd6180a0e0ab 8055754: filemap.cpp does not compile with clang
sla
parents: 26135
diff changeset
  1889
    fail_stop("%s", msg);
19319
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1890
  }
0ad35be0733a 8003424: Enable Class Data Sharing for CompressedOops
hseigel
parents: 18483
diff changeset
  1891
}
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1892
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1893
#if INCLUDE_JVMTI
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1894
ClassPathEntry** FileMapInfo::_classpath_entries_for_jvmti = NULL;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1895
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1896
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
  1897
  ClassPathEntry* ent = _classpath_entries_for_jvmti[i];
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1898
  if (ent == NULL) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1899
    if (i == 0) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1900
      ent = ClassLoader:: get_jrt_entry();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1901
      assert(ent != NULL, "must be");
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1902
    } else {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1903
      SharedClassPathEntry* scpe = shared_path(i);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1904
      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
  1905
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1906
      const char* path = scpe->name();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1907
      struct stat st;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1908
      if (os::stat(path, &st) != 0) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1909
        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
  1910
        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
  1911
        THROW_MSG_(vmSymbols::java_io_IOException(), msg, NULL);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1912
      } 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
  1913
        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
  1914
      }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1915
    }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1916
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1917
    MutexLocker mu(CDSClassFileStream_lock, THREAD);
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1918
    if (_classpath_entries_for_jvmti[i] == NULL) {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1919
      _classpath_entries_for_jvmti[i] = ent;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1920
    } else {
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1921
      // 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
  1922
      delete ent;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1923
      ent = _classpath_entries_for_jvmti[i];
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1924
    }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1925
  }
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1926
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1927
  return ent;
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1928
}
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1929
54340
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  1930
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
  1931
  int path_index = ik->shared_classpath_index();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1932
  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
  1933
  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
  1934
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1935
  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
  1936
  assert(cpe != NULL, "must be");
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1937
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1938
  Symbol* name = ik->name();
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1939
  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
  1940
  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
  1941
                                                                      name->utf8_length());
54340
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  1942
  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
  1943
  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
  1944
  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
  1945
  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
  1946
                        cfs->source(), cfs->length());
2221f042556d 8221351: Crash in KlassFactory::check_shared_class_file_load_hook
iklam
parents: 53911
diff changeset
  1947
  return cfs;
53884
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1948
}
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1949
1a7b57d02107 8218751: Do not store original classfiles inside the CDS archive
iklam
parents: 52811
diff changeset
  1950
#endif