annotate src/share/vm/memory/filemap.cpp @ 8804:91bf0bdae37b

8008217: CDS: Class data sharing limits the malloc heap on Solaris Summary: In 64bit VM move CDS archive address to 32G on all platforms using new flag SharedBaseAddress. In 32bit VM set CDS archive address to 3Gb on Linux and let other OSs pick the address. Reviewed-by: kvn, dcubed, zgu, hseigel
author coleenp
date Wed, 20 Mar 2013 08:04:54 -0400
parents c4ef3380a70b
children 868d87ed63c8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
7980
c4ef3380a70b 7197672: There are issues with shared data on windows
hseigel
parents: 7461
diff changeset
2 * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 605
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 605
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 605
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #include "classfile/classLoader.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "classfile/symbolTable.hpp"
7174
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
28 #include "classfile/altHashing.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "memory/filemap.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "runtime/arguments.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "runtime/java.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "runtime/os.hpp"
6882
716c64bda5ba 7199092: NMT: NMT needs to deal overlapped virtual memory ranges
zgu
parents: 6725
diff changeset
33 #include "services/memTracker.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
34 #include "utilities/defaultStream.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
35
0
a61af66fc99e Initial load
duke
parents:
diff changeset
36 # include <sys/stat.h>
a61af66fc99e Initial load
duke
parents:
diff changeset
37 # include <errno.h>
a61af66fc99e Initial load
duke
parents:
diff changeset
38
a61af66fc99e Initial load
duke
parents:
diff changeset
39 #ifndef O_BINARY // if defined (Win32) use binary files.
a61af66fc99e Initial load
duke
parents:
diff changeset
40 #define O_BINARY 0 // otherwise do nothing.
a61af66fc99e Initial load
duke
parents:
diff changeset
41 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
42
a61af66fc99e Initial load
duke
parents:
diff changeset
43
a61af66fc99e Initial load
duke
parents:
diff changeset
44 extern address JVM_FunctionAtStart();
a61af66fc99e Initial load
duke
parents:
diff changeset
45 extern address JVM_FunctionAtEnd();
a61af66fc99e Initial load
duke
parents:
diff changeset
46
605
98cb887364d3 6810672: Comment typos
twisti
parents: 0
diff changeset
47 // Complain and stop. All error conditions occurring during the writing of
0
a61af66fc99e Initial load
duke
parents:
diff changeset
48 // an archive file should stop the process. Unrecoverable errors during
a61af66fc99e Initial load
duke
parents:
diff changeset
49 // the reading of the archive file should stop the process.
a61af66fc99e Initial load
duke
parents:
diff changeset
50
a61af66fc99e Initial load
duke
parents:
diff changeset
51 static void fail(const char *msg, va_list ap) {
a61af66fc99e Initial load
duke
parents:
diff changeset
52 // This occurs very early during initialization: tty is not initialized.
a61af66fc99e Initial load
duke
parents:
diff changeset
53 jio_fprintf(defaultStream::error_stream(),
605
98cb887364d3 6810672: Comment typos
twisti
parents: 0
diff changeset
54 "An error has occurred while processing the"
0
a61af66fc99e Initial load
duke
parents:
diff changeset
55 " shared archive file.\n");
a61af66fc99e Initial load
duke
parents:
diff changeset
56 jio_vfprintf(defaultStream::error_stream(), msg, ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
57 jio_fprintf(defaultStream::error_stream(), "\n");
a61af66fc99e Initial load
duke
parents:
diff changeset
58 vm_exit_during_initialization("Unable to use shared archive.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
59 }
a61af66fc99e Initial load
duke
parents:
diff changeset
60
a61af66fc99e Initial load
duke
parents:
diff changeset
61
a61af66fc99e Initial load
duke
parents:
diff changeset
62 void FileMapInfo::fail_stop(const char *msg, ...) {
a61af66fc99e Initial load
duke
parents:
diff changeset
63 va_list ap;
a61af66fc99e Initial load
duke
parents:
diff changeset
64 va_start(ap, msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
65 fail(msg, ap); // Never returns.
a61af66fc99e Initial load
duke
parents:
diff changeset
66 va_end(ap); // for completeness.
a61af66fc99e Initial load
duke
parents:
diff changeset
67 }
a61af66fc99e Initial load
duke
parents:
diff changeset
68
a61af66fc99e Initial load
duke
parents:
diff changeset
69
a61af66fc99e Initial load
duke
parents:
diff changeset
70 // Complain and continue. Recoverable errors during the reading of the
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // archive file may continue (with sharing disabled).
a61af66fc99e Initial load
duke
parents:
diff changeset
72 //
a61af66fc99e Initial load
duke
parents:
diff changeset
73 // If we continue, then disable shared spaces and close the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
74
a61af66fc99e Initial load
duke
parents:
diff changeset
75 void FileMapInfo::fail_continue(const char *msg, ...) {
a61af66fc99e Initial load
duke
parents:
diff changeset
76 va_list ap;
a61af66fc99e Initial load
duke
parents:
diff changeset
77 va_start(ap, msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
78 if (RequireSharedSpaces) {
a61af66fc99e Initial load
duke
parents:
diff changeset
79 fail(msg, ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
80 }
a61af66fc99e Initial load
duke
parents:
diff changeset
81 va_end(ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
82 UseSharedSpaces = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
83 close();
a61af66fc99e Initial load
duke
parents:
diff changeset
84 }
a61af66fc99e Initial load
duke
parents:
diff changeset
85
7174
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
86 // Fill in the fileMapInfo structure with data about this VM instance.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
87
7174
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
88 // This method copies the vm version info into header_version. If the version is too
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
89 // long then a truncated version, which has a hash code appended to it, is copied.
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
90 //
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
91 // Using a template enables this method to verify that header_version is an array of
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
92 // length JVM_IDENT_MAX. This ensures that the code that writes to the CDS file and
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
93 // the code that reads the CDS file will both use the same size buffer. Hence, will
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
94 // use identical truncation. This is necessary for matching of truncated versions.
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
95 template <int N> static void get_header_version(char (&header_version) [N]) {
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
96 assert(N == JVM_IDENT_MAX, "Bad header_version size");
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
97
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
98 const char *vm_version = VM_Version::internal_vm_info_string();
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
99 const int version_len = (int)strlen(vm_version);
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
100
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
101 if (version_len < (JVM_IDENT_MAX-1)) {
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
102 strcpy(header_version, vm_version);
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
103
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
104 } else {
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
105 // Get the hash value. Use a static seed because the hash needs to return the same
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
106 // value over multiple jvm invocations.
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
107 unsigned int hash = AltHashing::murmur3_32(8191, (const jbyte*)vm_version, version_len);
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
108
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
109 // Truncate the ident, saving room for the 8 hex character hash value.
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
110 strncpy(header_version, vm_version, JVM_IDENT_MAX-9);
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
111
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
112 // Append the hash code as eight hex digits.
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
113 sprintf(&header_version[JVM_IDENT_MAX-9], "%08x", hash);
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
114 header_version[JVM_IDENT_MAX-1] = 0; // Null terminate.
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
115 }
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
116 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
117
a61af66fc99e Initial load
duke
parents:
diff changeset
118 void FileMapInfo::populate_header(size_t alignment) {
a61af66fc99e Initial load
duke
parents:
diff changeset
119 _header._magic = 0xf00baba2;
a61af66fc99e Initial load
duke
parents:
diff changeset
120 _header._version = _current_version;
a61af66fc99e Initial load
duke
parents:
diff changeset
121 _header._alignment = alignment;
7461
561148896559 8005076: Creating a CDS archive with one alignment and running another causes a crash.
hseigel
parents: 7460
diff changeset
122 _header._obj_alignment = ObjectAlignmentInBytes;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
123
a61af66fc99e Initial load
duke
parents:
diff changeset
124 // The following fields are for sanity checks for whether this archive
a61af66fc99e Initial load
duke
parents:
diff changeset
125 // will function correctly with this JVM and the bootclasspath it's
a61af66fc99e Initial load
duke
parents:
diff changeset
126 // invoked with.
a61af66fc99e Initial load
duke
parents:
diff changeset
127
a61af66fc99e Initial load
duke
parents:
diff changeset
128 // JVM version string ... changes on each build.
7174
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
129 get_header_version(_header._jvm_ident);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
130
a61af66fc99e Initial load
duke
parents:
diff changeset
131 // Build checks on classpath and jar files
a61af66fc99e Initial load
duke
parents:
diff changeset
132 _header._num_jars = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
133 ClassPathEntry *cpe = ClassLoader::classpath_entry(0);
a61af66fc99e Initial load
duke
parents:
diff changeset
134 for ( ; cpe != NULL; cpe = cpe->next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
135
a61af66fc99e Initial load
duke
parents:
diff changeset
136 if (cpe->is_jar_file()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
137 if (_header._num_jars >= JVM_SHARED_JARS_MAX) {
a61af66fc99e Initial load
duke
parents:
diff changeset
138 fail_stop("Too many jar files to share.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
139 }
a61af66fc99e Initial load
duke
parents:
diff changeset
140
a61af66fc99e Initial load
duke
parents:
diff changeset
141 // Jar file - record timestamp and file size.
a61af66fc99e Initial load
duke
parents:
diff changeset
142 struct stat st;
a61af66fc99e Initial load
duke
parents:
diff changeset
143 const char *path = cpe->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
144 if (os::stat(path, &st) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
145 // If we can't access a jar file in the boot path, then we can't
a61af66fc99e Initial load
duke
parents:
diff changeset
146 // make assumptions about where classes get loaded from.
a61af66fc99e Initial load
duke
parents:
diff changeset
147 fail_stop("Unable to open jar file %s.", path);
a61af66fc99e Initial load
duke
parents:
diff changeset
148 }
a61af66fc99e Initial load
duke
parents:
diff changeset
149 _header._jar[_header._num_jars]._timestamp = st.st_mtime;
a61af66fc99e Initial load
duke
parents:
diff changeset
150 _header._jar[_header._num_jars]._filesize = st.st_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
151 _header._num_jars++;
a61af66fc99e Initial load
duke
parents:
diff changeset
152 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
153
a61af66fc99e Initial load
duke
parents:
diff changeset
154 // If directories appear in boot classpath, they must be empty to
a61af66fc99e Initial load
duke
parents:
diff changeset
155 // avoid having to verify each individual class file.
a61af66fc99e Initial load
duke
parents:
diff changeset
156 const char* name = ((ClassPathDirEntry*)cpe)->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
157 if (!os::dir_is_empty(name)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
158 fail_stop("Boot classpath directory %s is not empty.", name);
a61af66fc99e Initial load
duke
parents:
diff changeset
159 }
a61af66fc99e Initial load
duke
parents:
diff changeset
160 }
a61af66fc99e Initial load
duke
parents:
diff changeset
161 }
a61af66fc99e Initial load
duke
parents:
diff changeset
162 }
a61af66fc99e Initial load
duke
parents:
diff changeset
163
a61af66fc99e Initial load
duke
parents:
diff changeset
164
a61af66fc99e Initial load
duke
parents:
diff changeset
165 // Read the FileMapInfo information from the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
166
a61af66fc99e Initial load
duke
parents:
diff changeset
167 bool FileMapInfo::init_from_file(int fd) {
a61af66fc99e Initial load
duke
parents:
diff changeset
168
a61af66fc99e Initial load
duke
parents:
diff changeset
169 size_t n = read(fd, &_header, sizeof(struct FileMapHeader));
a61af66fc99e Initial load
duke
parents:
diff changeset
170 if (n != sizeof(struct FileMapHeader)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
171 fail_continue("Unable to read the file header.");
a61af66fc99e Initial load
duke
parents:
diff changeset
172 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
173 }
a61af66fc99e Initial load
duke
parents:
diff changeset
174 if (_header._version != current_version()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
175 fail_continue("The shared archive file has the wrong version.");
a61af66fc99e Initial load
duke
parents:
diff changeset
176 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
177 }
a61af66fc99e Initial load
duke
parents:
diff changeset
178 _file_offset = (long)n;
a61af66fc99e Initial load
duke
parents:
diff changeset
179 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
180 }
a61af66fc99e Initial load
duke
parents:
diff changeset
181
a61af66fc99e Initial load
duke
parents:
diff changeset
182
a61af66fc99e Initial load
duke
parents:
diff changeset
183 // Read the FileMapInfo information from the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
184 bool FileMapInfo::open_for_read() {
a61af66fc99e Initial load
duke
parents:
diff changeset
185 _full_path = Arguments::GetSharedArchivePath();
a61af66fc99e Initial load
duke
parents:
diff changeset
186 int fd = open(_full_path, O_RDONLY | O_BINARY, 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
187 if (fd < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
188 if (errno == ENOENT) {
a61af66fc99e Initial load
duke
parents:
diff changeset
189 // Not locating the shared archive is ok.
a61af66fc99e Initial load
duke
parents:
diff changeset
190 fail_continue("Specified shared archive not found.");
a61af66fc99e Initial load
duke
parents:
diff changeset
191 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
192 fail_continue("Failed to open shared archive file (%s).",
a61af66fc99e Initial load
duke
parents:
diff changeset
193 strerror(errno));
a61af66fc99e Initial load
duke
parents:
diff changeset
194 }
a61af66fc99e Initial load
duke
parents:
diff changeset
195 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
196 }
a61af66fc99e Initial load
duke
parents:
diff changeset
197
a61af66fc99e Initial load
duke
parents:
diff changeset
198 _fd = fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
199 _file_open = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
200 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
201 }
a61af66fc99e Initial load
duke
parents:
diff changeset
202
a61af66fc99e Initial load
duke
parents:
diff changeset
203
a61af66fc99e Initial load
duke
parents:
diff changeset
204 // Write the FileMapInfo information to the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
205
a61af66fc99e Initial load
duke
parents:
diff changeset
206 void FileMapInfo::open_for_write() {
a61af66fc99e Initial load
duke
parents:
diff changeset
207 _full_path = Arguments::GetSharedArchivePath();
a61af66fc99e Initial load
duke
parents:
diff changeset
208 if (PrintSharedSpaces) {
a61af66fc99e Initial load
duke
parents:
diff changeset
209 tty->print_cr("Dumping shared data to file: ");
a61af66fc99e Initial load
duke
parents:
diff changeset
210 tty->print_cr(" %s", _full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
211 }
a61af66fc99e Initial load
duke
parents:
diff changeset
212
7980
c4ef3380a70b 7197672: There are issues with shared data on windows
hseigel
parents: 7461
diff changeset
213 #ifdef _WINDOWS // On Windows, need WRITE permission to remove the file.
c4ef3380a70b 7197672: There are issues with shared data on windows
hseigel
parents: 7461
diff changeset
214 chmod(_full_path, _S_IREAD | _S_IWRITE);
c4ef3380a70b 7197672: There are issues with shared data on windows
hseigel
parents: 7461
diff changeset
215 #endif
c4ef3380a70b 7197672: There are issues with shared data on windows
hseigel
parents: 7461
diff changeset
216
c4ef3380a70b 7197672: There are issues with shared data on windows
hseigel
parents: 7461
diff changeset
217 // Use remove() to delete the existing file because, on Unix, this will
c4ef3380a70b 7197672: There are issues with shared data on windows
hseigel
parents: 7461
diff changeset
218 // allow processes that have it open continued access to the file.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
219 remove(_full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
220 int fd = open(_full_path, O_RDWR | O_CREAT | O_TRUNC | O_BINARY, 0444);
a61af66fc99e Initial load
duke
parents:
diff changeset
221 if (fd < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
222 fail_stop("Unable to create shared archive file %s.", _full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
223 }
a61af66fc99e Initial load
duke
parents:
diff changeset
224 _fd = fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
225 _file_offset = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
226 _file_open = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
227 }
a61af66fc99e Initial load
duke
parents:
diff changeset
228
a61af66fc99e Initial load
duke
parents:
diff changeset
229
a61af66fc99e Initial load
duke
parents:
diff changeset
230 // Write the header to the file, seek to the next allocation boundary.
a61af66fc99e Initial load
duke
parents:
diff changeset
231
a61af66fc99e Initial load
duke
parents:
diff changeset
232 void FileMapInfo::write_header() {
a61af66fc99e Initial load
duke
parents:
diff changeset
233 write_bytes_aligned(&_header, sizeof(FileMapHeader));
a61af66fc99e Initial load
duke
parents:
diff changeset
234 }
a61af66fc99e Initial load
duke
parents:
diff changeset
235
a61af66fc99e Initial load
duke
parents:
diff changeset
236
a61af66fc99e Initial load
duke
parents:
diff changeset
237 // Dump shared spaces to file.
a61af66fc99e Initial load
duke
parents:
diff changeset
238
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
239 void FileMapInfo::write_space(int i, Metaspace* space, bool read_only) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
240 align_file_position();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
241 size_t used = space->used_words(Metaspace::NonClassType) * BytesPerWord;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
242 size_t capacity = space->capacity_words(Metaspace::NonClassType) * BytesPerWord;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
243 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
244 write_region(i, (char*)space->bottom(), used, capacity, read_only, false);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
245 }
a61af66fc99e Initial load
duke
parents:
diff changeset
246
a61af66fc99e Initial load
duke
parents:
diff changeset
247
a61af66fc99e Initial load
duke
parents:
diff changeset
248 // Dump region to file.
a61af66fc99e Initial load
duke
parents:
diff changeset
249
a61af66fc99e Initial load
duke
parents:
diff changeset
250 void FileMapInfo::write_region(int region, char* base, size_t size,
a61af66fc99e Initial load
duke
parents:
diff changeset
251 size_t capacity, bool read_only,
a61af66fc99e Initial load
duke
parents:
diff changeset
252 bool allow_exec) {
a61af66fc99e Initial load
duke
parents:
diff changeset
253 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[region];
a61af66fc99e Initial load
duke
parents:
diff changeset
254
a61af66fc99e Initial load
duke
parents:
diff changeset
255 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
256 guarantee(si->_file_offset == _file_offset, "file offset mismatch.");
a61af66fc99e Initial load
duke
parents:
diff changeset
257 if (PrintSharedSpaces) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
258 tty->print_cr("Shared file region %d: 0x%6x bytes, addr " INTPTR_FORMAT
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
259 " file offset 0x%6x", region, size, base, _file_offset);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
260 }
a61af66fc99e Initial load
duke
parents:
diff changeset
261 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
262 si->_file_offset = _file_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
263 }
a61af66fc99e Initial load
duke
parents:
diff changeset
264 si->_base = base;
a61af66fc99e Initial load
duke
parents:
diff changeset
265 si->_used = size;
a61af66fc99e Initial load
duke
parents:
diff changeset
266 si->_capacity = capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
267 si->_read_only = read_only;
a61af66fc99e Initial load
duke
parents:
diff changeset
268 si->_allow_exec = allow_exec;
a61af66fc99e Initial load
duke
parents:
diff changeset
269 write_bytes_aligned(base, (int)size);
a61af66fc99e Initial load
duke
parents:
diff changeset
270 }
a61af66fc99e Initial load
duke
parents:
diff changeset
271
a61af66fc99e Initial load
duke
parents:
diff changeset
272
a61af66fc99e Initial load
duke
parents:
diff changeset
273 // Dump bytes to file -- at the current file position.
a61af66fc99e Initial load
duke
parents:
diff changeset
274
a61af66fc99e Initial load
duke
parents:
diff changeset
275 void FileMapInfo::write_bytes(const void* buffer, int nbytes) {
a61af66fc99e Initial load
duke
parents:
diff changeset
276 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
277 int n = ::write(_fd, buffer, nbytes);
a61af66fc99e Initial load
duke
parents:
diff changeset
278 if (n != nbytes) {
a61af66fc99e Initial load
duke
parents:
diff changeset
279 // It is dangerous to leave the corrupted shared archive file around,
a61af66fc99e Initial load
duke
parents:
diff changeset
280 // close and remove the file. See bug 6372906.
a61af66fc99e Initial load
duke
parents:
diff changeset
281 close();
a61af66fc99e Initial load
duke
parents:
diff changeset
282 remove(_full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
283 fail_stop("Unable to write to shared archive file.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
284 }
a61af66fc99e Initial load
duke
parents:
diff changeset
285 }
a61af66fc99e Initial load
duke
parents:
diff changeset
286 _file_offset += nbytes;
a61af66fc99e Initial load
duke
parents:
diff changeset
287 }
a61af66fc99e Initial load
duke
parents:
diff changeset
288
a61af66fc99e Initial load
duke
parents:
diff changeset
289
a61af66fc99e Initial load
duke
parents:
diff changeset
290 // Align file position to an allocation unit boundary.
a61af66fc99e Initial load
duke
parents:
diff changeset
291
a61af66fc99e Initial load
duke
parents:
diff changeset
292 void FileMapInfo::align_file_position() {
a61af66fc99e Initial load
duke
parents:
diff changeset
293 long new_file_offset = align_size_up(_file_offset, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
294 if (new_file_offset != _file_offset) {
a61af66fc99e Initial load
duke
parents:
diff changeset
295 _file_offset = new_file_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
296 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
297 // Seek one byte back from the target and write a byte to insure
a61af66fc99e Initial load
duke
parents:
diff changeset
298 // that the written file is the correct length.
a61af66fc99e Initial load
duke
parents:
diff changeset
299 _file_offset -= 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
300 if (lseek(_fd, _file_offset, SEEK_SET) < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
301 fail_stop("Unable to seek.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
302 }
a61af66fc99e Initial load
duke
parents:
diff changeset
303 char zero = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
304 write_bytes(&zero, 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
305 }
a61af66fc99e Initial load
duke
parents:
diff changeset
306 }
a61af66fc99e Initial load
duke
parents:
diff changeset
307 }
a61af66fc99e Initial load
duke
parents:
diff changeset
308
a61af66fc99e Initial load
duke
parents:
diff changeset
309
a61af66fc99e Initial load
duke
parents:
diff changeset
310 // Dump bytes to file -- at the current file position.
a61af66fc99e Initial load
duke
parents:
diff changeset
311
a61af66fc99e Initial load
duke
parents:
diff changeset
312 void FileMapInfo::write_bytes_aligned(const void* buffer, int nbytes) {
a61af66fc99e Initial load
duke
parents:
diff changeset
313 align_file_position();
a61af66fc99e Initial load
duke
parents:
diff changeset
314 write_bytes(buffer, nbytes);
a61af66fc99e Initial load
duke
parents:
diff changeset
315 align_file_position();
a61af66fc99e Initial load
duke
parents:
diff changeset
316 }
a61af66fc99e Initial load
duke
parents:
diff changeset
317
a61af66fc99e Initial load
duke
parents:
diff changeset
318
a61af66fc99e Initial load
duke
parents:
diff changeset
319 // Close the shared archive file. This does NOT unmap mapped regions.
a61af66fc99e Initial load
duke
parents:
diff changeset
320
a61af66fc99e Initial load
duke
parents:
diff changeset
321 void FileMapInfo::close() {
a61af66fc99e Initial load
duke
parents:
diff changeset
322 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
323 if (::close(_fd) < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
324 fail_stop("Unable to close the shared archive file.");
a61af66fc99e Initial load
duke
parents:
diff changeset
325 }
a61af66fc99e Initial load
duke
parents:
diff changeset
326 _file_open = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
327 _fd = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
328 }
a61af66fc99e Initial load
duke
parents:
diff changeset
329 }
a61af66fc99e Initial load
duke
parents:
diff changeset
330
a61af66fc99e Initial load
duke
parents:
diff changeset
331
a61af66fc99e Initial load
duke
parents:
diff changeset
332 // JVM/TI RedefineClasses() support:
a61af66fc99e Initial load
duke
parents:
diff changeset
333 // Remap the shared readonly space to shared readwrite, private.
a61af66fc99e Initial load
duke
parents:
diff changeset
334 bool FileMapInfo::remap_shared_readonly_as_readwrite() {
a61af66fc99e Initial load
duke
parents:
diff changeset
335 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[0];
a61af66fc99e Initial load
duke
parents:
diff changeset
336 if (!si->_read_only) {
a61af66fc99e Initial load
duke
parents:
diff changeset
337 // the space is already readwrite so we are done
a61af66fc99e Initial load
duke
parents:
diff changeset
338 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
339 }
a61af66fc99e Initial load
duke
parents:
diff changeset
340 size_t used = si->_used;
a61af66fc99e Initial load
duke
parents:
diff changeset
341 size_t size = align_size_up(used, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
342 if (!open_for_read()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
343 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
344 }
a61af66fc99e Initial load
duke
parents:
diff changeset
345 char *base = os::remap_memory(_fd, _full_path, si->_file_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
346 si->_base, size, false /* !read_only */,
a61af66fc99e Initial load
duke
parents:
diff changeset
347 si->_allow_exec);
a61af66fc99e Initial load
duke
parents:
diff changeset
348 close();
a61af66fc99e Initial load
duke
parents:
diff changeset
349 if (base == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
350 fail_continue("Unable to remap shared readonly space (errno=%d).", errno);
a61af66fc99e Initial load
duke
parents:
diff changeset
351 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
352 }
a61af66fc99e Initial load
duke
parents:
diff changeset
353 if (base != si->_base) {
a61af66fc99e Initial load
duke
parents:
diff changeset
354 fail_continue("Unable to remap shared readonly space at required address.");
a61af66fc99e Initial load
duke
parents:
diff changeset
355 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
356 }
a61af66fc99e Initial load
duke
parents:
diff changeset
357 si->_read_only = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
358 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
359 }
a61af66fc99e Initial load
duke
parents:
diff changeset
360
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
361 // Map the whole region at once, assumed to be allocated contiguously.
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
362 ReservedSpace FileMapInfo::reserve_shared_memory() {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
363 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[0];
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
364 char* requested_addr = si->_base;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
365 size_t alignment = os::vm_allocation_granularity();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
366
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
367 size_t size = align_size_up(SharedReadOnlySize + SharedReadWriteSize +
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
368 SharedMiscDataSize + SharedMiscCodeSize,
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
369 alignment);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
370
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
371 // Reserve the space first, then map otherwise map will go right over some
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
372 // other reserved memory (like the code cache).
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
373 ReservedSpace rs(size, alignment, false, requested_addr);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
374 if (!rs.is_reserved()) {
8804
91bf0bdae37b 8008217: CDS: Class data sharing limits the malloc heap on Solaris
coleenp
parents: 7980
diff changeset
375 fail_continue(err_msg("Unable to reserve shared space at required address " INTPTR_FORMAT, requested_addr));
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
376 return rs;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
377 }
6882
716c64bda5ba 7199092: NMT: NMT needs to deal overlapped virtual memory ranges
zgu
parents: 6725
diff changeset
378 // the reserved virtual memory is for mapping class data sharing archive
7460
6c3f47d964f3 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 7174
diff changeset
379 MemTracker::record_virtual_memory_type((address)rs.base(), mtClassShared);
6c3f47d964f3 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 7174
diff changeset
380
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
381 return rs;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
382 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
383
a61af66fc99e Initial load
duke
parents:
diff changeset
384 // Memory map a region in the address space.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
385 static const char* shared_region_name[] = { "ReadOnly", "ReadWrite", "MiscData", "MiscCode"};
0
a61af66fc99e Initial load
duke
parents:
diff changeset
386
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
387 char* FileMapInfo::map_region(int i) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
388 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
389 size_t used = si->_used;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
390 size_t alignment = os::vm_allocation_granularity();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
391 size_t size = align_size_up(used, alignment);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
392 char *requested_addr = si->_base;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
393
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
394 // map the contents of the CDS archive in this memory
0
a61af66fc99e Initial load
duke
parents:
diff changeset
395 char *base = os::map_memory(_fd, _full_path, si->_file_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
396 requested_addr, size, si->_read_only,
a61af66fc99e Initial load
duke
parents:
diff changeset
397 si->_allow_exec);
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
398 if (base == NULL || base != si->_base) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
399 fail_continue(err_msg("Unable to map %s shared space at required address.", shared_region_name[i]));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
400 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
401 }
7460
6c3f47d964f3 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 7174
diff changeset
402 #ifdef _WINDOWS
6c3f47d964f3 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 7174
diff changeset
403 // This call is Windows-only because the memory_type gets recorded for the other platforms
6c3f47d964f3 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 7174
diff changeset
404 // in method FileMapInfo::reserve_shared_memory(), which is not called on Windows.
6c3f47d964f3 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 7174
diff changeset
405 MemTracker::record_virtual_memory_type((address)base, mtClassShared);
6c3f47d964f3 8003705: CDS failed on Windows: can not map in the CDS.
hseigel
parents: 7174
diff changeset
406 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
407 return base;
a61af66fc99e Initial load
duke
parents:
diff changeset
408 }
a61af66fc99e Initial load
duke
parents:
diff changeset
409
a61af66fc99e Initial load
duke
parents:
diff changeset
410
a61af66fc99e Initial load
duke
parents:
diff changeset
411 // Unmap a memory region in the address space.
a61af66fc99e Initial load
duke
parents:
diff changeset
412
a61af66fc99e Initial load
duke
parents:
diff changeset
413 void FileMapInfo::unmap_region(int i) {
a61af66fc99e Initial load
duke
parents:
diff changeset
414 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
415 size_t used = si->_used;
a61af66fc99e Initial load
duke
parents:
diff changeset
416 size_t size = align_size_up(used, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
417 if (!os::unmap_memory(si->_base, size)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
418 fail_stop("Unable to unmap shared space.");
a61af66fc99e Initial load
duke
parents:
diff changeset
419 }
a61af66fc99e Initial load
duke
parents:
diff changeset
420 }
a61af66fc99e Initial load
duke
parents:
diff changeset
421
a61af66fc99e Initial load
duke
parents:
diff changeset
422
a61af66fc99e Initial load
duke
parents:
diff changeset
423 void FileMapInfo::assert_mark(bool check) {
a61af66fc99e Initial load
duke
parents:
diff changeset
424 if (!check) {
a61af66fc99e Initial load
duke
parents:
diff changeset
425 fail_stop("Mark mismatch while restoring from shared file.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
426 }
a61af66fc99e Initial load
duke
parents:
diff changeset
427 }
a61af66fc99e Initial load
duke
parents:
diff changeset
428
a61af66fc99e Initial load
duke
parents:
diff changeset
429
a61af66fc99e Initial load
duke
parents:
diff changeset
430 FileMapInfo* FileMapInfo::_current_info = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
431
a61af66fc99e Initial load
duke
parents:
diff changeset
432
a61af66fc99e Initial load
duke
parents:
diff changeset
433 // Open the shared archive file, read and validate the header
a61af66fc99e Initial load
duke
parents:
diff changeset
434 // information (version, boot classpath, etc.). If initialization
a61af66fc99e Initial load
duke
parents:
diff changeset
435 // fails, shared spaces are disabled and the file is closed. [See
a61af66fc99e Initial load
duke
parents:
diff changeset
436 // fail_continue.]
a61af66fc99e Initial load
duke
parents:
diff changeset
437 bool FileMapInfo::initialize() {
a61af66fc99e Initial load
duke
parents:
diff changeset
438 assert(UseSharedSpaces, "UseSharedSpaces expected.");
a61af66fc99e Initial load
duke
parents:
diff changeset
439
a61af66fc99e Initial load
duke
parents:
diff changeset
440 if (JvmtiExport::can_modify_any_class() || JvmtiExport::can_walk_any_space()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
441 fail_continue("Tool agent requires sharing to be disabled.");
a61af66fc99e Initial load
duke
parents:
diff changeset
442 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
443 }
a61af66fc99e Initial load
duke
parents:
diff changeset
444
a61af66fc99e Initial load
duke
parents:
diff changeset
445 if (!open_for_read()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
446 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
447 }
a61af66fc99e Initial load
duke
parents:
diff changeset
448
a61af66fc99e Initial load
duke
parents:
diff changeset
449 init_from_file(_fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
450 if (!validate()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
451 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
452 }
a61af66fc99e Initial load
duke
parents:
diff changeset
453
a61af66fc99e Initial load
duke
parents:
diff changeset
454 SharedReadOnlySize = _header._space[0]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
455 SharedReadWriteSize = _header._space[1]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
456 SharedMiscDataSize = _header._space[2]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
457 SharedMiscCodeSize = _header._space[3]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
458 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
459 }
a61af66fc99e Initial load
duke
parents:
diff changeset
460
a61af66fc99e Initial load
duke
parents:
diff changeset
461
a61af66fc99e Initial load
duke
parents:
diff changeset
462 bool FileMapInfo::validate() {
a61af66fc99e Initial load
duke
parents:
diff changeset
463 if (_header._version != current_version()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
464 fail_continue("The shared archive file is the wrong version.");
a61af66fc99e Initial load
duke
parents:
diff changeset
465 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
466 }
a61af66fc99e Initial load
duke
parents:
diff changeset
467 if (_header._magic != (int)0xf00baba2) {
a61af66fc99e Initial load
duke
parents:
diff changeset
468 fail_continue("The shared archive file has a bad magic number.");
a61af66fc99e Initial load
duke
parents:
diff changeset
469 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
470 }
7174
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
471 char header_version[JVM_IDENT_MAX];
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
472 get_header_version(header_version);
fe81517cfb77 6924920: Class Data Sharing limit on the java version string can create failures
hseigel
parents: 6882
diff changeset
473 if (strncmp(_header._jvm_ident, header_version, JVM_IDENT_MAX-1) != 0) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
474 fail_continue("The shared archive file was created by a different"
a61af66fc99e Initial load
duke
parents:
diff changeset
475 " version or build of HotSpot.");
a61af66fc99e Initial load
duke
parents:
diff changeset
476 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
477 }
7461
561148896559 8005076: Creating a CDS archive with one alignment and running another causes a crash.
hseigel
parents: 7460
diff changeset
478 if (_header._obj_alignment != ObjectAlignmentInBytes) {
561148896559 8005076: Creating a CDS archive with one alignment and running another causes a crash.
hseigel
parents: 7460
diff changeset
479 fail_continue("The shared archive file's ObjectAlignmentInBytes of %d"
561148896559 8005076: Creating a CDS archive with one alignment and running another causes a crash.
hseigel
parents: 7460
diff changeset
480 " does not equal the current ObjectAlignmentInBytes of %d.",
561148896559 8005076: Creating a CDS archive with one alignment and running another causes a crash.
hseigel
parents: 7460
diff changeset
481 _header._obj_alignment, ObjectAlignmentInBytes);
561148896559 8005076: Creating a CDS archive with one alignment and running another causes a crash.
hseigel
parents: 7460
diff changeset
482 return false;
561148896559 8005076: Creating a CDS archive with one alignment and running another causes a crash.
hseigel
parents: 7460
diff changeset
483 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
484
a61af66fc99e Initial load
duke
parents:
diff changeset
485 // Cannot verify interpreter yet, as it can only be created after the GC
a61af66fc99e Initial load
duke
parents:
diff changeset
486 // heap has been initialized.
a61af66fc99e Initial load
duke
parents:
diff changeset
487
a61af66fc99e Initial load
duke
parents:
diff changeset
488 if (_header._num_jars >= JVM_SHARED_JARS_MAX) {
a61af66fc99e Initial load
duke
parents:
diff changeset
489 fail_continue("Too many jar files to share.");
a61af66fc99e Initial load
duke
parents:
diff changeset
490 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
491 }
a61af66fc99e Initial load
duke
parents:
diff changeset
492
a61af66fc99e Initial load
duke
parents:
diff changeset
493 // Build checks on classpath and jar files
a61af66fc99e Initial load
duke
parents:
diff changeset
494 int num_jars_now = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
495 ClassPathEntry *cpe = ClassLoader::classpath_entry(0);
a61af66fc99e Initial load
duke
parents:
diff changeset
496 for ( ; cpe != NULL; cpe = cpe->next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
497
a61af66fc99e Initial load
duke
parents:
diff changeset
498 if (cpe->is_jar_file()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
499 if (num_jars_now < _header._num_jars) {
a61af66fc99e Initial load
duke
parents:
diff changeset
500
a61af66fc99e Initial load
duke
parents:
diff changeset
501 // Jar file - verify timestamp and file size.
a61af66fc99e Initial load
duke
parents:
diff changeset
502 struct stat st;
a61af66fc99e Initial load
duke
parents:
diff changeset
503 const char *path = cpe->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
504 if (os::stat(path, &st) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
505 fail_continue("Unable to open jar file %s.", path);
a61af66fc99e Initial load
duke
parents:
diff changeset
506 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
507 }
a61af66fc99e Initial load
duke
parents:
diff changeset
508 if (_header._jar[num_jars_now]._timestamp != st.st_mtime ||
a61af66fc99e Initial load
duke
parents:
diff changeset
509 _header._jar[num_jars_now]._filesize != st.st_size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
510 fail_continue("A jar file is not the one used while building"
a61af66fc99e Initial load
duke
parents:
diff changeset
511 " the shared archive file.");
a61af66fc99e Initial load
duke
parents:
diff changeset
512 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
513 }
a61af66fc99e Initial load
duke
parents:
diff changeset
514 }
a61af66fc99e Initial load
duke
parents:
diff changeset
515 ++num_jars_now;
a61af66fc99e Initial load
duke
parents:
diff changeset
516 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
517
a61af66fc99e Initial load
duke
parents:
diff changeset
518 // If directories appear in boot classpath, they must be empty to
a61af66fc99e Initial load
duke
parents:
diff changeset
519 // avoid having to verify each individual class file.
a61af66fc99e Initial load
duke
parents:
diff changeset
520 const char* name = ((ClassPathDirEntry*)cpe)->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
521 if (!os::dir_is_empty(name)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
522 fail_continue("Boot classpath directory %s is not empty.", name);
a61af66fc99e Initial load
duke
parents:
diff changeset
523 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
524 }
a61af66fc99e Initial load
duke
parents:
diff changeset
525 }
a61af66fc99e Initial load
duke
parents:
diff changeset
526 }
a61af66fc99e Initial load
duke
parents:
diff changeset
527 if (num_jars_now < _header._num_jars) {
a61af66fc99e Initial load
duke
parents:
diff changeset
528 fail_continue("The number of jar files in the boot classpath is"
a61af66fc99e Initial load
duke
parents:
diff changeset
529 " less than the number the shared archive was created with.");
a61af66fc99e Initial load
duke
parents:
diff changeset
530 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
531 }
a61af66fc99e Initial load
duke
parents:
diff changeset
532
a61af66fc99e Initial load
duke
parents:
diff changeset
533 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
534 }
a61af66fc99e Initial load
duke
parents:
diff changeset
535
a61af66fc99e Initial load
duke
parents:
diff changeset
536 // The following method is provided to see whether a given pointer
a61af66fc99e Initial load
duke
parents:
diff changeset
537 // falls in the mapped shared space.
a61af66fc99e Initial load
duke
parents:
diff changeset
538 // Param:
a61af66fc99e Initial load
duke
parents:
diff changeset
539 // p, The given pointer
a61af66fc99e Initial load
duke
parents:
diff changeset
540 // Return:
a61af66fc99e Initial load
duke
parents:
diff changeset
541 // True if the p is within the mapped shared space, otherwise, false.
a61af66fc99e Initial load
duke
parents:
diff changeset
542 bool FileMapInfo::is_in_shared_space(const void* p) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 1980
diff changeset
543 for (int i = 0; i < MetaspaceShared::n_regions; i++) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
544 if (p >= _header._space[i]._base &&
a61af66fc99e Initial load
duke
parents:
diff changeset
545 p < _header._space[i]._base + _header._space[i]._used) {
a61af66fc99e Initial load
duke
parents:
diff changeset
546 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
547 }
a61af66fc99e Initial load
duke
parents:
diff changeset
548 }
a61af66fc99e Initial load
duke
parents:
diff changeset
549
a61af66fc99e Initial load
duke
parents:
diff changeset
550 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
551 }