annotate src/share/vm/memory/filemap.cpp @ 2368:dde920245681

6896099: Integrate CMS heap ergo with default heap sizing ergo 6627787: CMS: JVM refuses to start up with -Xms16m -Xmx16m 7000125: CMS: Anti-monotone young gen sizing with respect to maximum whole heap size specification 7027529: CMS: retire CMSUseOldDefaults flag Summary: Simplify CMS heap sizing code, relying on ergonomic initial sizing consistent with other collectors for the most part, controlling only young gen sizing to rein in pause times. Make CMS young gen sizing default statically cpu-dependant. Remove inconsistencies wrt generation sizing and policy code, allowing for the fixing for 6627787 and 7000125. For 7027529, retire the flag CMSUseOldDefaults which had been introduced as a bridge from JDK 5 to JDK 6 a number of years ago. Reviewed-by: brutisso, poonam
author ysr
date Wed, 16 Mar 2011 10:37:08 -0700
parents 828eafbd85cc
children da91efe96a93
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
2 * Copyright (c) 2003, 2010, 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"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "memory/filemap.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "runtime/arguments.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "runtime/java.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "runtime/os.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "utilities/defaultStream.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
33
0
a61af66fc99e Initial load
duke
parents:
diff changeset
34 # include <sys/stat.h>
a61af66fc99e Initial load
duke
parents:
diff changeset
35 # include <errno.h>
a61af66fc99e Initial load
duke
parents:
diff changeset
36
a61af66fc99e Initial load
duke
parents:
diff changeset
37 #ifndef O_BINARY // if defined (Win32) use binary files.
a61af66fc99e Initial load
duke
parents:
diff changeset
38 #define O_BINARY 0 // otherwise do nothing.
a61af66fc99e Initial load
duke
parents:
diff changeset
39 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
40
a61af66fc99e Initial load
duke
parents:
diff changeset
41
a61af66fc99e Initial load
duke
parents:
diff changeset
42 extern address JVM_FunctionAtStart();
a61af66fc99e Initial load
duke
parents:
diff changeset
43 extern address JVM_FunctionAtEnd();
a61af66fc99e Initial load
duke
parents:
diff changeset
44
605
98cb887364d3 6810672: Comment typos
twisti
parents: 0
diff changeset
45 // Complain and stop. All error conditions occurring during the writing of
0
a61af66fc99e Initial load
duke
parents:
diff changeset
46 // an archive file should stop the process. Unrecoverable errors during
a61af66fc99e Initial load
duke
parents:
diff changeset
47 // the reading of the archive file should stop the process.
a61af66fc99e Initial load
duke
parents:
diff changeset
48
a61af66fc99e Initial load
duke
parents:
diff changeset
49 static void fail(const char *msg, va_list ap) {
a61af66fc99e Initial load
duke
parents:
diff changeset
50 // This occurs very early during initialization: tty is not initialized.
a61af66fc99e Initial load
duke
parents:
diff changeset
51 jio_fprintf(defaultStream::error_stream(),
605
98cb887364d3 6810672: Comment typos
twisti
parents: 0
diff changeset
52 "An error has occurred while processing the"
0
a61af66fc99e Initial load
duke
parents:
diff changeset
53 " shared archive file.\n");
a61af66fc99e Initial load
duke
parents:
diff changeset
54 jio_vfprintf(defaultStream::error_stream(), msg, ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
55 jio_fprintf(defaultStream::error_stream(), "\n");
a61af66fc99e Initial load
duke
parents:
diff changeset
56 vm_exit_during_initialization("Unable to use shared archive.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
57 }
a61af66fc99e Initial load
duke
parents:
diff changeset
58
a61af66fc99e Initial load
duke
parents:
diff changeset
59
a61af66fc99e Initial load
duke
parents:
diff changeset
60 void FileMapInfo::fail_stop(const char *msg, ...) {
a61af66fc99e Initial load
duke
parents:
diff changeset
61 va_list ap;
a61af66fc99e Initial load
duke
parents:
diff changeset
62 va_start(ap, msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
63 fail(msg, ap); // Never returns.
a61af66fc99e Initial load
duke
parents:
diff changeset
64 va_end(ap); // for completeness.
a61af66fc99e Initial load
duke
parents:
diff changeset
65 }
a61af66fc99e Initial load
duke
parents:
diff changeset
66
a61af66fc99e Initial load
duke
parents:
diff changeset
67
a61af66fc99e Initial load
duke
parents:
diff changeset
68 // Complain and continue. Recoverable errors during the reading of the
a61af66fc99e Initial load
duke
parents:
diff changeset
69 // archive file may continue (with sharing disabled).
a61af66fc99e Initial load
duke
parents:
diff changeset
70 //
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // If we continue, then disable shared spaces and close the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
72
a61af66fc99e Initial load
duke
parents:
diff changeset
73 void FileMapInfo::fail_continue(const char *msg, ...) {
a61af66fc99e Initial load
duke
parents:
diff changeset
74 va_list ap;
a61af66fc99e Initial load
duke
parents:
diff changeset
75 va_start(ap, msg);
a61af66fc99e Initial load
duke
parents:
diff changeset
76 if (RequireSharedSpaces) {
a61af66fc99e Initial load
duke
parents:
diff changeset
77 fail(msg, ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
78 }
a61af66fc99e Initial load
duke
parents:
diff changeset
79 va_end(ap);
a61af66fc99e Initial load
duke
parents:
diff changeset
80 UseSharedSpaces = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
81 close();
a61af66fc99e Initial load
duke
parents:
diff changeset
82 }
a61af66fc99e Initial load
duke
parents:
diff changeset
83
a61af66fc99e Initial load
duke
parents:
diff changeset
84
a61af66fc99e Initial load
duke
parents:
diff changeset
85 // Fill in the fileMapInfo structure with data about this VM instance.
a61af66fc99e Initial load
duke
parents:
diff changeset
86
a61af66fc99e Initial load
duke
parents:
diff changeset
87 void FileMapInfo::populate_header(size_t alignment) {
a61af66fc99e Initial load
duke
parents:
diff changeset
88 _header._magic = 0xf00baba2;
a61af66fc99e Initial load
duke
parents:
diff changeset
89 _header._version = _current_version;
a61af66fc99e Initial load
duke
parents:
diff changeset
90 _header._alignment = alignment;
a61af66fc99e Initial load
duke
parents:
diff changeset
91
a61af66fc99e Initial load
duke
parents:
diff changeset
92 // The following fields are for sanity checks for whether this archive
a61af66fc99e Initial load
duke
parents:
diff changeset
93 // will function correctly with this JVM and the bootclasspath it's
a61af66fc99e Initial load
duke
parents:
diff changeset
94 // invoked with.
a61af66fc99e Initial load
duke
parents:
diff changeset
95
a61af66fc99e Initial load
duke
parents:
diff changeset
96 // JVM version string ... changes on each build.
a61af66fc99e Initial load
duke
parents:
diff changeset
97 const char *vm_version = VM_Version::internal_vm_info_string();
a61af66fc99e Initial load
duke
parents:
diff changeset
98 if (strlen(vm_version) < (JVM_IDENT_MAX-1)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
99 strcpy(_header._jvm_ident, vm_version);
a61af66fc99e Initial load
duke
parents:
diff changeset
100 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
101 fail_stop("JVM Ident field for shared archive is too long"
a61af66fc99e Initial load
duke
parents:
diff changeset
102 " - truncated to <%s>", _header._jvm_ident);
a61af66fc99e Initial load
duke
parents:
diff changeset
103 }
a61af66fc99e Initial load
duke
parents:
diff changeset
104
a61af66fc99e Initial load
duke
parents:
diff changeset
105 // Build checks on classpath and jar files
a61af66fc99e Initial load
duke
parents:
diff changeset
106 _header._num_jars = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
107 ClassPathEntry *cpe = ClassLoader::classpath_entry(0);
a61af66fc99e Initial load
duke
parents:
diff changeset
108 for ( ; cpe != NULL; cpe = cpe->next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
109
a61af66fc99e Initial load
duke
parents:
diff changeset
110 if (cpe->is_jar_file()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
111 if (_header._num_jars >= JVM_SHARED_JARS_MAX) {
a61af66fc99e Initial load
duke
parents:
diff changeset
112 fail_stop("Too many jar files to share.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
113 }
a61af66fc99e Initial load
duke
parents:
diff changeset
114
a61af66fc99e Initial load
duke
parents:
diff changeset
115 // Jar file - record timestamp and file size.
a61af66fc99e Initial load
duke
parents:
diff changeset
116 struct stat st;
a61af66fc99e Initial load
duke
parents:
diff changeset
117 const char *path = cpe->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
118 if (os::stat(path, &st) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
119 // If we can't access a jar file in the boot path, then we can't
a61af66fc99e Initial load
duke
parents:
diff changeset
120 // make assumptions about where classes get loaded from.
a61af66fc99e Initial load
duke
parents:
diff changeset
121 fail_stop("Unable to open jar file %s.", path);
a61af66fc99e Initial load
duke
parents:
diff changeset
122 }
a61af66fc99e Initial load
duke
parents:
diff changeset
123 _header._jar[_header._num_jars]._timestamp = st.st_mtime;
a61af66fc99e Initial load
duke
parents:
diff changeset
124 _header._jar[_header._num_jars]._filesize = st.st_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
125 _header._num_jars++;
a61af66fc99e Initial load
duke
parents:
diff changeset
126 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
127
a61af66fc99e Initial load
duke
parents:
diff changeset
128 // If directories appear in boot classpath, they must be empty to
a61af66fc99e Initial load
duke
parents:
diff changeset
129 // avoid having to verify each individual class file.
a61af66fc99e Initial load
duke
parents:
diff changeset
130 const char* name = ((ClassPathDirEntry*)cpe)->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
131 if (!os::dir_is_empty(name)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
132 fail_stop("Boot classpath directory %s is not empty.", name);
a61af66fc99e Initial load
duke
parents:
diff changeset
133 }
a61af66fc99e Initial load
duke
parents:
diff changeset
134 }
a61af66fc99e Initial load
duke
parents:
diff changeset
135 }
a61af66fc99e Initial load
duke
parents:
diff changeset
136 }
a61af66fc99e Initial load
duke
parents:
diff changeset
137
a61af66fc99e Initial load
duke
parents:
diff changeset
138
a61af66fc99e Initial load
duke
parents:
diff changeset
139 // Read the FileMapInfo information from the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
140
a61af66fc99e Initial load
duke
parents:
diff changeset
141 bool FileMapInfo::init_from_file(int fd) {
a61af66fc99e Initial load
duke
parents:
diff changeset
142
a61af66fc99e Initial load
duke
parents:
diff changeset
143 size_t n = read(fd, &_header, sizeof(struct FileMapHeader));
a61af66fc99e Initial load
duke
parents:
diff changeset
144 if (n != sizeof(struct FileMapHeader)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
145 fail_continue("Unable to read the file header.");
a61af66fc99e Initial load
duke
parents:
diff changeset
146 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
147 }
a61af66fc99e Initial load
duke
parents:
diff changeset
148 if (_header._version != current_version()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
149 fail_continue("The shared archive file has the wrong version.");
a61af66fc99e Initial load
duke
parents:
diff changeset
150 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
151 }
a61af66fc99e Initial load
duke
parents:
diff changeset
152 _file_offset = (long)n;
a61af66fc99e Initial load
duke
parents:
diff changeset
153 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
154 }
a61af66fc99e Initial load
duke
parents:
diff changeset
155
a61af66fc99e Initial load
duke
parents:
diff changeset
156
a61af66fc99e Initial load
duke
parents:
diff changeset
157 // Read the FileMapInfo information from the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
158 bool FileMapInfo::open_for_read() {
a61af66fc99e Initial load
duke
parents:
diff changeset
159 _full_path = Arguments::GetSharedArchivePath();
a61af66fc99e Initial load
duke
parents:
diff changeset
160 int fd = open(_full_path, O_RDONLY | O_BINARY, 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
161 if (fd < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
162 if (errno == ENOENT) {
a61af66fc99e Initial load
duke
parents:
diff changeset
163 // Not locating the shared archive is ok.
a61af66fc99e Initial load
duke
parents:
diff changeset
164 fail_continue("Specified shared archive not found.");
a61af66fc99e Initial load
duke
parents:
diff changeset
165 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
166 fail_continue("Failed to open shared archive file (%s).",
a61af66fc99e Initial load
duke
parents:
diff changeset
167 strerror(errno));
a61af66fc99e Initial load
duke
parents:
diff changeset
168 }
a61af66fc99e Initial load
duke
parents:
diff changeset
169 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
170 }
a61af66fc99e Initial load
duke
parents:
diff changeset
171
a61af66fc99e Initial load
duke
parents:
diff changeset
172 _fd = fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
173 _file_open = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
174 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
175 }
a61af66fc99e Initial load
duke
parents:
diff changeset
176
a61af66fc99e Initial load
duke
parents:
diff changeset
177
a61af66fc99e Initial load
duke
parents:
diff changeset
178 // Write the FileMapInfo information to the file.
a61af66fc99e Initial load
duke
parents:
diff changeset
179
a61af66fc99e Initial load
duke
parents:
diff changeset
180 void FileMapInfo::open_for_write() {
a61af66fc99e Initial load
duke
parents:
diff changeset
181 _full_path = Arguments::GetSharedArchivePath();
a61af66fc99e Initial load
duke
parents:
diff changeset
182 if (PrintSharedSpaces) {
a61af66fc99e Initial load
duke
parents:
diff changeset
183 tty->print_cr("Dumping shared data to file: ");
a61af66fc99e Initial load
duke
parents:
diff changeset
184 tty->print_cr(" %s", _full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
185 }
a61af66fc99e Initial load
duke
parents:
diff changeset
186
a61af66fc99e Initial load
duke
parents:
diff changeset
187 // Remove the existing file in case another process has it open.
a61af66fc99e Initial load
duke
parents:
diff changeset
188 remove(_full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
189 int fd = open(_full_path, O_RDWR | O_CREAT | O_TRUNC | O_BINARY, 0444);
a61af66fc99e Initial load
duke
parents:
diff changeset
190 if (fd < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
191 fail_stop("Unable to create shared archive file %s.", _full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
192 }
a61af66fc99e Initial load
duke
parents:
diff changeset
193 _fd = fd;
a61af66fc99e Initial load
duke
parents:
diff changeset
194 _file_offset = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
195 _file_open = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
196 }
a61af66fc99e Initial load
duke
parents:
diff changeset
197
a61af66fc99e Initial load
duke
parents:
diff changeset
198
a61af66fc99e Initial load
duke
parents:
diff changeset
199 // Write the header to the file, seek to the next allocation boundary.
a61af66fc99e Initial load
duke
parents:
diff changeset
200
a61af66fc99e Initial load
duke
parents:
diff changeset
201 void FileMapInfo::write_header() {
a61af66fc99e Initial load
duke
parents:
diff changeset
202 write_bytes_aligned(&_header, sizeof(FileMapHeader));
a61af66fc99e Initial load
duke
parents:
diff changeset
203 }
a61af66fc99e Initial load
duke
parents:
diff changeset
204
a61af66fc99e Initial load
duke
parents:
diff changeset
205
a61af66fc99e Initial load
duke
parents:
diff changeset
206 // Dump shared spaces to file.
a61af66fc99e Initial load
duke
parents:
diff changeset
207
a61af66fc99e Initial load
duke
parents:
diff changeset
208 void FileMapInfo::write_space(int i, CompactibleSpace* space, bool read_only) {
a61af66fc99e Initial load
duke
parents:
diff changeset
209 align_file_position();
a61af66fc99e Initial load
duke
parents:
diff changeset
210 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
211 write_region(i, (char*)space->bottom(), space->used(),
a61af66fc99e Initial load
duke
parents:
diff changeset
212 space->capacity(), read_only, false);
a61af66fc99e Initial load
duke
parents:
diff changeset
213 }
a61af66fc99e Initial load
duke
parents:
diff changeset
214
a61af66fc99e Initial load
duke
parents:
diff changeset
215
a61af66fc99e Initial load
duke
parents:
diff changeset
216 // Dump region to file.
a61af66fc99e Initial load
duke
parents:
diff changeset
217
a61af66fc99e Initial load
duke
parents:
diff changeset
218 void FileMapInfo::write_region(int region, char* base, size_t size,
a61af66fc99e Initial load
duke
parents:
diff changeset
219 size_t capacity, bool read_only,
a61af66fc99e Initial load
duke
parents:
diff changeset
220 bool allow_exec) {
a61af66fc99e Initial load
duke
parents:
diff changeset
221 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[region];
a61af66fc99e Initial load
duke
parents:
diff changeset
222
a61af66fc99e Initial load
duke
parents:
diff changeset
223 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
224 guarantee(si->_file_offset == _file_offset, "file offset mismatch.");
a61af66fc99e Initial load
duke
parents:
diff changeset
225 if (PrintSharedSpaces) {
a61af66fc99e Initial load
duke
parents:
diff changeset
226 tty->print_cr("Shared file region %d: 0x%x bytes, addr 0x%x,"
a61af66fc99e Initial load
duke
parents:
diff changeset
227 " file offset 0x%x", region, size, base, _file_offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
228 }
a61af66fc99e Initial load
duke
parents:
diff changeset
229 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
230 si->_file_offset = _file_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
231 }
a61af66fc99e Initial load
duke
parents:
diff changeset
232 si->_base = base;
a61af66fc99e Initial load
duke
parents:
diff changeset
233 si->_used = size;
a61af66fc99e Initial load
duke
parents:
diff changeset
234 si->_capacity = capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
235 si->_read_only = read_only;
a61af66fc99e Initial load
duke
parents:
diff changeset
236 si->_allow_exec = allow_exec;
a61af66fc99e Initial load
duke
parents:
diff changeset
237 write_bytes_aligned(base, (int)size);
a61af66fc99e Initial load
duke
parents:
diff changeset
238 }
a61af66fc99e Initial load
duke
parents:
diff changeset
239
a61af66fc99e Initial load
duke
parents:
diff changeset
240
a61af66fc99e Initial load
duke
parents:
diff changeset
241 // Dump bytes to file -- at the current file position.
a61af66fc99e Initial load
duke
parents:
diff changeset
242
a61af66fc99e Initial load
duke
parents:
diff changeset
243 void FileMapInfo::write_bytes(const void* buffer, int nbytes) {
a61af66fc99e Initial load
duke
parents:
diff changeset
244 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
245 int n = ::write(_fd, buffer, nbytes);
a61af66fc99e Initial load
duke
parents:
diff changeset
246 if (n != nbytes) {
a61af66fc99e Initial load
duke
parents:
diff changeset
247 // It is dangerous to leave the corrupted shared archive file around,
a61af66fc99e Initial load
duke
parents:
diff changeset
248 // close and remove the file. See bug 6372906.
a61af66fc99e Initial load
duke
parents:
diff changeset
249 close();
a61af66fc99e Initial load
duke
parents:
diff changeset
250 remove(_full_path);
a61af66fc99e Initial load
duke
parents:
diff changeset
251 fail_stop("Unable to write to shared archive file.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
252 }
a61af66fc99e Initial load
duke
parents:
diff changeset
253 }
a61af66fc99e Initial load
duke
parents:
diff changeset
254 _file_offset += nbytes;
a61af66fc99e Initial load
duke
parents:
diff changeset
255 }
a61af66fc99e Initial load
duke
parents:
diff changeset
256
a61af66fc99e Initial load
duke
parents:
diff changeset
257
a61af66fc99e Initial load
duke
parents:
diff changeset
258 // Align file position to an allocation unit boundary.
a61af66fc99e Initial load
duke
parents:
diff changeset
259
a61af66fc99e Initial load
duke
parents:
diff changeset
260 void FileMapInfo::align_file_position() {
a61af66fc99e Initial load
duke
parents:
diff changeset
261 long new_file_offset = align_size_up(_file_offset, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
262 if (new_file_offset != _file_offset) {
a61af66fc99e Initial load
duke
parents:
diff changeset
263 _file_offset = new_file_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
264 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
265 // Seek one byte back from the target and write a byte to insure
a61af66fc99e Initial load
duke
parents:
diff changeset
266 // that the written file is the correct length.
a61af66fc99e Initial load
duke
parents:
diff changeset
267 _file_offset -= 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
268 if (lseek(_fd, _file_offset, SEEK_SET) < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
269 fail_stop("Unable to seek.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
270 }
a61af66fc99e Initial load
duke
parents:
diff changeset
271 char zero = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
272 write_bytes(&zero, 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
273 }
a61af66fc99e Initial load
duke
parents:
diff changeset
274 }
a61af66fc99e Initial load
duke
parents:
diff changeset
275 }
a61af66fc99e Initial load
duke
parents:
diff changeset
276
a61af66fc99e Initial load
duke
parents:
diff changeset
277
a61af66fc99e Initial load
duke
parents:
diff changeset
278 // Dump bytes to file -- at the current file position.
a61af66fc99e Initial load
duke
parents:
diff changeset
279
a61af66fc99e Initial load
duke
parents:
diff changeset
280 void FileMapInfo::write_bytes_aligned(const void* buffer, int nbytes) {
a61af66fc99e Initial load
duke
parents:
diff changeset
281 align_file_position();
a61af66fc99e Initial load
duke
parents:
diff changeset
282 write_bytes(buffer, nbytes);
a61af66fc99e Initial load
duke
parents:
diff changeset
283 align_file_position();
a61af66fc99e Initial load
duke
parents:
diff changeset
284 }
a61af66fc99e Initial load
duke
parents:
diff changeset
285
a61af66fc99e Initial load
duke
parents:
diff changeset
286
a61af66fc99e Initial load
duke
parents:
diff changeset
287 // Close the shared archive file. This does NOT unmap mapped regions.
a61af66fc99e Initial load
duke
parents:
diff changeset
288
a61af66fc99e Initial load
duke
parents:
diff changeset
289 void FileMapInfo::close() {
a61af66fc99e Initial load
duke
parents:
diff changeset
290 if (_file_open) {
a61af66fc99e Initial load
duke
parents:
diff changeset
291 if (::close(_fd) < 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
292 fail_stop("Unable to close the shared archive file.");
a61af66fc99e Initial load
duke
parents:
diff changeset
293 }
a61af66fc99e Initial load
duke
parents:
diff changeset
294 _file_open = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
295 _fd = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
296 }
a61af66fc99e Initial load
duke
parents:
diff changeset
297 }
a61af66fc99e Initial load
duke
parents:
diff changeset
298
a61af66fc99e Initial load
duke
parents:
diff changeset
299
a61af66fc99e Initial load
duke
parents:
diff changeset
300 // Memory map a shared space from the archive file.
a61af66fc99e Initial load
duke
parents:
diff changeset
301
a61af66fc99e Initial load
duke
parents:
diff changeset
302 bool FileMapInfo::map_space(int i, ReservedSpace rs, ContiguousSpace* space) {
a61af66fc99e Initial load
duke
parents:
diff changeset
303 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
304 if (space != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
305 if (si->_base != (char*)space->bottom() ||
a61af66fc99e Initial load
duke
parents:
diff changeset
306 si->_capacity != space->capacity()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
307 fail_continue("Shared space base address does not match.");
a61af66fc99e Initial load
duke
parents:
diff changeset
308 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
309 }
a61af66fc99e Initial load
duke
parents:
diff changeset
310 }
a61af66fc99e Initial load
duke
parents:
diff changeset
311 bool result = (map_region(i, rs) != NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
312 if (space != NULL && result) {
a61af66fc99e Initial load
duke
parents:
diff changeset
313 space->set_top((HeapWord*)(si->_base + si->_used));
a61af66fc99e Initial load
duke
parents:
diff changeset
314 space->set_saved_mark();
a61af66fc99e Initial load
duke
parents:
diff changeset
315 }
a61af66fc99e Initial load
duke
parents:
diff changeset
316 return result;
a61af66fc99e Initial load
duke
parents:
diff changeset
317 }
a61af66fc99e Initial load
duke
parents:
diff changeset
318
a61af66fc99e Initial load
duke
parents:
diff changeset
319
a61af66fc99e Initial load
duke
parents:
diff changeset
320 // JVM/TI RedefineClasses() support:
a61af66fc99e Initial load
duke
parents:
diff changeset
321 // Remap the shared readonly space to shared readwrite, private.
a61af66fc99e Initial load
duke
parents:
diff changeset
322 bool FileMapInfo::remap_shared_readonly_as_readwrite() {
a61af66fc99e Initial load
duke
parents:
diff changeset
323 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[0];
a61af66fc99e Initial load
duke
parents:
diff changeset
324 if (!si->_read_only) {
a61af66fc99e Initial load
duke
parents:
diff changeset
325 // the space is already readwrite so we are done
a61af66fc99e Initial load
duke
parents:
diff changeset
326 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
327 }
a61af66fc99e Initial load
duke
parents:
diff changeset
328 size_t used = si->_used;
a61af66fc99e Initial load
duke
parents:
diff changeset
329 size_t size = align_size_up(used, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
330 if (!open_for_read()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
331 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
332 }
a61af66fc99e Initial load
duke
parents:
diff changeset
333 char *base = os::remap_memory(_fd, _full_path, si->_file_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
334 si->_base, size, false /* !read_only */,
a61af66fc99e Initial load
duke
parents:
diff changeset
335 si->_allow_exec);
a61af66fc99e Initial load
duke
parents:
diff changeset
336 close();
a61af66fc99e Initial load
duke
parents:
diff changeset
337 if (base == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
338 fail_continue("Unable to remap shared readonly space (errno=%d).", errno);
a61af66fc99e Initial load
duke
parents:
diff changeset
339 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
340 }
a61af66fc99e Initial load
duke
parents:
diff changeset
341 if (base != si->_base) {
a61af66fc99e Initial load
duke
parents:
diff changeset
342 fail_continue("Unable to remap shared readonly space at required address.");
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 si->_read_only = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
346 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
347 }
a61af66fc99e Initial load
duke
parents:
diff changeset
348
a61af66fc99e Initial load
duke
parents:
diff changeset
349
a61af66fc99e Initial load
duke
parents:
diff changeset
350 // Memory map a region in the address space.
a61af66fc99e Initial load
duke
parents:
diff changeset
351
a61af66fc99e Initial load
duke
parents:
diff changeset
352 char* FileMapInfo::map_region(int i, ReservedSpace rs) {
a61af66fc99e Initial load
duke
parents:
diff changeset
353 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
354 size_t used = si->_used;
a61af66fc99e Initial load
duke
parents:
diff changeset
355 size_t size = align_size_up(used, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
356
a61af66fc99e Initial load
duke
parents:
diff changeset
357 ReservedSpace mapped_rs = rs.first_part(size, true, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
358 ReservedSpace unmapped_rs = rs.last_part(size);
a61af66fc99e Initial load
duke
parents:
diff changeset
359 mapped_rs.release();
a61af66fc99e Initial load
duke
parents:
diff changeset
360
a61af66fc99e Initial load
duke
parents:
diff changeset
361 return map_region(i, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
362 }
a61af66fc99e Initial load
duke
parents:
diff changeset
363
a61af66fc99e Initial load
duke
parents:
diff changeset
364
a61af66fc99e Initial load
duke
parents:
diff changeset
365 // Memory map a region in the address space.
a61af66fc99e Initial load
duke
parents:
diff changeset
366
a61af66fc99e Initial load
duke
parents:
diff changeset
367 char* FileMapInfo::map_region(int i, bool address_must_match) {
a61af66fc99e Initial load
duke
parents:
diff changeset
368 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
369 size_t used = si->_used;
a61af66fc99e Initial load
duke
parents:
diff changeset
370 size_t size = align_size_up(used, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
371 char *requested_addr = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
372 if (address_must_match) {
a61af66fc99e Initial load
duke
parents:
diff changeset
373 requested_addr = si->_base;
a61af66fc99e Initial load
duke
parents:
diff changeset
374 }
a61af66fc99e Initial load
duke
parents:
diff changeset
375 char *base = os::map_memory(_fd, _full_path, si->_file_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
376 requested_addr, size, si->_read_only,
a61af66fc99e Initial load
duke
parents:
diff changeset
377 si->_allow_exec);
a61af66fc99e Initial load
duke
parents:
diff changeset
378 if (base == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
379 fail_continue("Unable to map shared space.");
a61af66fc99e Initial load
duke
parents:
diff changeset
380 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
381 }
a61af66fc99e Initial load
duke
parents:
diff changeset
382 if (address_must_match) {
a61af66fc99e Initial load
duke
parents:
diff changeset
383 if (base != si->_base) {
a61af66fc99e Initial load
duke
parents:
diff changeset
384 fail_continue("Unable to map shared space at required address.");
a61af66fc99e Initial load
duke
parents:
diff changeset
385 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
386 }
a61af66fc99e Initial load
duke
parents:
diff changeset
387 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
388 si->_base = base; // save mapped address for unmapping.
a61af66fc99e Initial load
duke
parents:
diff changeset
389 }
a61af66fc99e Initial load
duke
parents:
diff changeset
390 return base;
a61af66fc99e Initial load
duke
parents:
diff changeset
391 }
a61af66fc99e Initial load
duke
parents:
diff changeset
392
a61af66fc99e Initial load
duke
parents:
diff changeset
393
a61af66fc99e Initial load
duke
parents:
diff changeset
394 // Unmap a memory region in the address space.
a61af66fc99e Initial load
duke
parents:
diff changeset
395
a61af66fc99e Initial load
duke
parents:
diff changeset
396 void FileMapInfo::unmap_region(int i) {
a61af66fc99e Initial load
duke
parents:
diff changeset
397 struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
398 size_t used = si->_used;
a61af66fc99e Initial load
duke
parents:
diff changeset
399 size_t size = align_size_up(used, os::vm_allocation_granularity());
a61af66fc99e Initial load
duke
parents:
diff changeset
400 if (!os::unmap_memory(si->_base, size)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
401 fail_stop("Unable to unmap shared space.");
a61af66fc99e Initial load
duke
parents:
diff changeset
402 }
a61af66fc99e Initial load
duke
parents:
diff changeset
403 }
a61af66fc99e Initial load
duke
parents:
diff changeset
404
a61af66fc99e Initial load
duke
parents:
diff changeset
405
a61af66fc99e Initial load
duke
parents:
diff changeset
406 void FileMapInfo::assert_mark(bool check) {
a61af66fc99e Initial load
duke
parents:
diff changeset
407 if (!check) {
a61af66fc99e Initial load
duke
parents:
diff changeset
408 fail_stop("Mark mismatch while restoring from shared file.", NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
409 }
a61af66fc99e Initial load
duke
parents:
diff changeset
410 }
a61af66fc99e Initial load
duke
parents:
diff changeset
411
a61af66fc99e Initial load
duke
parents:
diff changeset
412
a61af66fc99e Initial load
duke
parents:
diff changeset
413 FileMapInfo* FileMapInfo::_current_info = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
414
a61af66fc99e Initial load
duke
parents:
diff changeset
415
a61af66fc99e Initial load
duke
parents:
diff changeset
416 // Open the shared archive file, read and validate the header
a61af66fc99e Initial load
duke
parents:
diff changeset
417 // information (version, boot classpath, etc.). If initialization
a61af66fc99e Initial load
duke
parents:
diff changeset
418 // fails, shared spaces are disabled and the file is closed. [See
a61af66fc99e Initial load
duke
parents:
diff changeset
419 // fail_continue.]
a61af66fc99e Initial load
duke
parents:
diff changeset
420
a61af66fc99e Initial load
duke
parents:
diff changeset
421
a61af66fc99e Initial load
duke
parents:
diff changeset
422 bool FileMapInfo::initialize() {
a61af66fc99e Initial load
duke
parents:
diff changeset
423 assert(UseSharedSpaces, "UseSharedSpaces expected.");
a61af66fc99e Initial load
duke
parents:
diff changeset
424
a61af66fc99e Initial load
duke
parents:
diff changeset
425 if (JvmtiExport::can_modify_any_class() || JvmtiExport::can_walk_any_space()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
426 fail_continue("Tool agent requires sharing to be disabled.");
a61af66fc99e Initial load
duke
parents:
diff changeset
427 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
428 }
a61af66fc99e Initial load
duke
parents:
diff changeset
429
a61af66fc99e Initial load
duke
parents:
diff changeset
430 if (!open_for_read()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
431 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
432 }
a61af66fc99e Initial load
duke
parents:
diff changeset
433
a61af66fc99e Initial load
duke
parents:
diff changeset
434 init_from_file(_fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
435 if (!validate()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
436 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
437 }
a61af66fc99e Initial load
duke
parents:
diff changeset
438
a61af66fc99e Initial load
duke
parents:
diff changeset
439 SharedReadOnlySize = _header._space[0]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
440 SharedReadWriteSize = _header._space[1]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
441 SharedMiscDataSize = _header._space[2]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
442 SharedMiscCodeSize = _header._space[3]._capacity;
a61af66fc99e Initial load
duke
parents:
diff changeset
443 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
444 }
a61af66fc99e Initial load
duke
parents:
diff changeset
445
a61af66fc99e Initial load
duke
parents:
diff changeset
446
a61af66fc99e Initial load
duke
parents:
diff changeset
447 bool FileMapInfo::validate() {
a61af66fc99e Initial load
duke
parents:
diff changeset
448 if (_header._version != current_version()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
449 fail_continue("The shared archive file is the wrong version.");
a61af66fc99e Initial load
duke
parents:
diff changeset
450 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
451 }
a61af66fc99e Initial load
duke
parents:
diff changeset
452 if (_header._magic != (int)0xf00baba2) {
a61af66fc99e Initial load
duke
parents:
diff changeset
453 fail_continue("The shared archive file has a bad magic number.");
a61af66fc99e Initial load
duke
parents:
diff changeset
454 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
455 }
a61af66fc99e Initial load
duke
parents:
diff changeset
456 if (strncmp(_header._jvm_ident, VM_Version::internal_vm_info_string(),
a61af66fc99e Initial load
duke
parents:
diff changeset
457 JVM_IDENT_MAX-1) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
458 fail_continue("The shared archive file was created by a different"
a61af66fc99e Initial load
duke
parents:
diff changeset
459 " version or build of HotSpot.");
a61af66fc99e Initial load
duke
parents:
diff changeset
460 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
461 }
a61af66fc99e Initial load
duke
parents:
diff changeset
462
a61af66fc99e Initial load
duke
parents:
diff changeset
463 // Cannot verify interpreter yet, as it can only be created after the GC
a61af66fc99e Initial load
duke
parents:
diff changeset
464 // heap has been initialized.
a61af66fc99e Initial load
duke
parents:
diff changeset
465
a61af66fc99e Initial load
duke
parents:
diff changeset
466 if (_header._num_jars >= JVM_SHARED_JARS_MAX) {
a61af66fc99e Initial load
duke
parents:
diff changeset
467 fail_continue("Too many jar files to share.");
a61af66fc99e Initial load
duke
parents:
diff changeset
468 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
469 }
a61af66fc99e Initial load
duke
parents:
diff changeset
470
a61af66fc99e Initial load
duke
parents:
diff changeset
471 // Build checks on classpath and jar files
a61af66fc99e Initial load
duke
parents:
diff changeset
472 int num_jars_now = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
473 ClassPathEntry *cpe = ClassLoader::classpath_entry(0);
a61af66fc99e Initial load
duke
parents:
diff changeset
474 for ( ; cpe != NULL; cpe = cpe->next()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
475
a61af66fc99e Initial load
duke
parents:
diff changeset
476 if (cpe->is_jar_file()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
477 if (num_jars_now < _header._num_jars) {
a61af66fc99e Initial load
duke
parents:
diff changeset
478
a61af66fc99e Initial load
duke
parents:
diff changeset
479 // Jar file - verify timestamp and file size.
a61af66fc99e Initial load
duke
parents:
diff changeset
480 struct stat st;
a61af66fc99e Initial load
duke
parents:
diff changeset
481 const char *path = cpe->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
482 if (os::stat(path, &st) != 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
483 fail_continue("Unable to open jar file %s.", path);
a61af66fc99e Initial load
duke
parents:
diff changeset
484 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
485 }
a61af66fc99e Initial load
duke
parents:
diff changeset
486 if (_header._jar[num_jars_now]._timestamp != st.st_mtime ||
a61af66fc99e Initial load
duke
parents:
diff changeset
487 _header._jar[num_jars_now]._filesize != st.st_size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
488 fail_continue("A jar file is not the one used while building"
a61af66fc99e Initial load
duke
parents:
diff changeset
489 " the shared archive file.");
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 ++num_jars_now;
a61af66fc99e Initial load
duke
parents:
diff changeset
494 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
495
a61af66fc99e Initial load
duke
parents:
diff changeset
496 // If directories appear in boot classpath, they must be empty to
a61af66fc99e Initial load
duke
parents:
diff changeset
497 // avoid having to verify each individual class file.
a61af66fc99e Initial load
duke
parents:
diff changeset
498 const char* name = ((ClassPathDirEntry*)cpe)->name();
a61af66fc99e Initial load
duke
parents:
diff changeset
499 if (!os::dir_is_empty(name)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
500 fail_continue("Boot classpath directory %s is not empty.", name);
a61af66fc99e Initial load
duke
parents:
diff changeset
501 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
502 }
a61af66fc99e Initial load
duke
parents:
diff changeset
503 }
a61af66fc99e Initial load
duke
parents:
diff changeset
504 }
a61af66fc99e Initial load
duke
parents:
diff changeset
505 if (num_jars_now < _header._num_jars) {
a61af66fc99e Initial load
duke
parents:
diff changeset
506 fail_continue("The number of jar files in the boot classpath is"
a61af66fc99e Initial load
duke
parents:
diff changeset
507 " less than the number the shared archive was created with.");
a61af66fc99e Initial load
duke
parents:
diff changeset
508 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
509 }
a61af66fc99e Initial load
duke
parents:
diff changeset
510
a61af66fc99e Initial load
duke
parents:
diff changeset
511 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
512 }
a61af66fc99e Initial load
duke
parents:
diff changeset
513
a61af66fc99e Initial load
duke
parents:
diff changeset
514 // The following method is provided to see whether a given pointer
a61af66fc99e Initial load
duke
parents:
diff changeset
515 // falls in the mapped shared space.
a61af66fc99e Initial load
duke
parents:
diff changeset
516 // Param:
a61af66fc99e Initial load
duke
parents:
diff changeset
517 // p, The given pointer
a61af66fc99e Initial load
duke
parents:
diff changeset
518 // Return:
a61af66fc99e Initial load
duke
parents:
diff changeset
519 // True if the p is within the mapped shared space, otherwise, false.
a61af66fc99e Initial load
duke
parents:
diff changeset
520 bool FileMapInfo::is_in_shared_space(const void* p) {
a61af66fc99e Initial load
duke
parents:
diff changeset
521 for (int i = 0; i < CompactingPermGenGen::n_regions; i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
522 if (p >= _header._space[i]._base &&
a61af66fc99e Initial load
duke
parents:
diff changeset
523 p < _header._space[i]._base + _header._space[i]._used) {
a61af66fc99e Initial load
duke
parents:
diff changeset
524 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
525 }
a61af66fc99e Initial load
duke
parents:
diff changeset
526 }
a61af66fc99e Initial load
duke
parents:
diff changeset
527
a61af66fc99e Initial load
duke
parents:
diff changeset
528 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
529 }