mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-25 05:45:11 +02:00
8068687: Remove meta-index support and cleanup hotspot code for rt.jar etc in non-modular jdk image
Remove the meta-index code and rt.jar code and comments Reviewed-by: mchung, gtriantafill
This commit is contained in:
parent
9604a593ee
commit
ce4261471b
8 changed files with 16 additions and 252 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -152,40 +152,6 @@ bool string_ends_with(const char* str, const char* str_to_find) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
MetaIndex::MetaIndex(char** meta_package_names, int num_meta_package_names) {
|
|
||||||
if (num_meta_package_names == 0) {
|
|
||||||
_meta_package_names = NULL;
|
|
||||||
_num_meta_package_names = 0;
|
|
||||||
} else {
|
|
||||||
_meta_package_names = NEW_C_HEAP_ARRAY(char*, num_meta_package_names, mtClass);
|
|
||||||
_num_meta_package_names = num_meta_package_names;
|
|
||||||
memcpy(_meta_package_names, meta_package_names, num_meta_package_names * sizeof(char*));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
MetaIndex::~MetaIndex() {
|
|
||||||
FREE_C_HEAP_ARRAY(char*, _meta_package_names);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool MetaIndex::may_contain(const char* class_name) {
|
|
||||||
if ( _num_meta_package_names == 0) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
size_t class_name_len = strlen(class_name);
|
|
||||||
for (int i = 0; i < _num_meta_package_names; i++) {
|
|
||||||
char* pkg = _meta_package_names[i];
|
|
||||||
size_t pkg_len = strlen(pkg);
|
|
||||||
size_t min_len = MIN2(class_name_len, pkg_len);
|
|
||||||
if (!strncmp(class_name, pkg, min_len)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
ClassPathEntry::ClassPathEntry() {
|
ClassPathEntry::ClassPathEntry() {
|
||||||
set_next(NULL);
|
set_next(NULL);
|
||||||
}
|
}
|
||||||
|
@ -315,7 +281,6 @@ void ClassPathZipEntry::contents_do(void f(const char* name, void* context), voi
|
||||||
LazyClassPathEntry::LazyClassPathEntry(const char* path, const struct stat* st, bool throw_exception) : ClassPathEntry() {
|
LazyClassPathEntry::LazyClassPathEntry(const char* path, const struct stat* st, bool throw_exception) : ClassPathEntry() {
|
||||||
_path = os::strdup_check_oom(path);
|
_path = os::strdup_check_oom(path);
|
||||||
_st = *st;
|
_st = *st;
|
||||||
_meta_index = NULL;
|
|
||||||
_resolved_entry = NULL;
|
_resolved_entry = NULL;
|
||||||
_has_error = false;
|
_has_error = false;
|
||||||
_throw_exception = throw_exception;
|
_throw_exception = throw_exception;
|
||||||
|
@ -354,10 +319,6 @@ ClassPathEntry* LazyClassPathEntry::resolve_entry(TRAPS) {
|
||||||
}
|
}
|
||||||
|
|
||||||
ClassFileStream* LazyClassPathEntry::open_stream(const char* name, TRAPS) {
|
ClassFileStream* LazyClassPathEntry::open_stream(const char* name, TRAPS) {
|
||||||
if (_meta_index != NULL &&
|
|
||||||
!_meta_index->may_contain(name)) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
if (_has_error) {
|
if (_has_error) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -463,16 +424,6 @@ bool ClassPathImageEntry::is_jrt() {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void print_meta_index(LazyClassPathEntry* entry,
|
|
||||||
GrowableArray<char*>& meta_packages) {
|
|
||||||
tty->print("[Meta index for %s=", entry->name());
|
|
||||||
for (int i = 0; i < meta_packages.length(); i++) {
|
|
||||||
if (i > 0) tty->print(" ");
|
|
||||||
tty->print("%s", meta_packages.at(i));
|
|
||||||
}
|
|
||||||
tty->print_cr("]");
|
|
||||||
}
|
|
||||||
|
|
||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
void ClassLoader::exit_with_path_failure(const char* error, const char* message) {
|
void ClassLoader::exit_with_path_failure(const char* error, const char* message) {
|
||||||
assert(DumpSharedSpaces, "only called at dump time");
|
assert(DumpSharedSpaces, "only called at dump time");
|
||||||
|
@ -508,123 +459,6 @@ void ClassLoader::trace_class_path(const char* msg, const char* name) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClassLoader::setup_bootstrap_meta_index() {
|
|
||||||
// Set up meta index which allows us to open boot jars lazily if
|
|
||||||
// class data sharing is enabled
|
|
||||||
const char* meta_index_path = Arguments::get_meta_index_path();
|
|
||||||
const char* meta_index_dir = Arguments::get_meta_index_dir();
|
|
||||||
setup_meta_index(meta_index_path, meta_index_dir, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ClassLoader::setup_meta_index(const char* meta_index_path, const char* meta_index_dir, int start_index) {
|
|
||||||
const char* known_version = "% VERSION 2";
|
|
||||||
FILE* file = fopen(meta_index_path, "r");
|
|
||||||
int line_no = 0;
|
|
||||||
#if INCLUDE_CDS
|
|
||||||
if (DumpSharedSpaces) {
|
|
||||||
if (file != NULL) {
|
|
||||||
_shared_paths_misc_info->add_required_file(meta_index_path);
|
|
||||||
} else {
|
|
||||||
_shared_paths_misc_info->add_nonexist_path(meta_index_path);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (file != NULL) {
|
|
||||||
ResourceMark rm;
|
|
||||||
LazyClassPathEntry* cur_entry = NULL;
|
|
||||||
GrowableArray<char*> boot_class_path_packages(10);
|
|
||||||
char package_name[256];
|
|
||||||
bool skipCurrentJar = false;
|
|
||||||
while (fgets(package_name, sizeof(package_name), file) != NULL) {
|
|
||||||
++line_no;
|
|
||||||
// Remove trailing newline
|
|
||||||
package_name[strlen(package_name) - 1] = '\0';
|
|
||||||
switch(package_name[0]) {
|
|
||||||
case '%':
|
|
||||||
{
|
|
||||||
if ((line_no == 1) && (strcmp(package_name, known_version) != 0)) {
|
|
||||||
if (TraceClassLoading && Verbose) {
|
|
||||||
tty->print("[Unsupported meta index version]");
|
|
||||||
}
|
|
||||||
fclose(file);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// These directives indicate jar files which contain only
|
|
||||||
// classes, only non-classfile resources, or a combination of
|
|
||||||
// the two. See src/share/classes/sun/misc/MetaIndex.java and
|
|
||||||
// make/tools/MetaIndex/BuildMetaIndex.java in the J2SE
|
|
||||||
// workspace.
|
|
||||||
case '#':
|
|
||||||
case '!':
|
|
||||||
case '@':
|
|
||||||
{
|
|
||||||
// Hand off current packages to current lazy entry (if any)
|
|
||||||
if ((cur_entry != NULL) &&
|
|
||||||
(boot_class_path_packages.length() > 0)) {
|
|
||||||
if ((TraceClassLoading || TraceClassPaths) && Verbose) {
|
|
||||||
print_meta_index(cur_entry, boot_class_path_packages);
|
|
||||||
}
|
|
||||||
MetaIndex* index = new MetaIndex(boot_class_path_packages.adr_at(0),
|
|
||||||
boot_class_path_packages.length());
|
|
||||||
cur_entry->set_meta_index(index);
|
|
||||||
}
|
|
||||||
cur_entry = NULL;
|
|
||||||
boot_class_path_packages.clear();
|
|
||||||
|
|
||||||
// Find lazy entry corresponding to this jar file
|
|
||||||
int count = 0;
|
|
||||||
for (ClassPathEntry* entry = _first_entry; entry != NULL; entry = entry->next(), count++) {
|
|
||||||
if (count >= start_index &&
|
|
||||||
entry->is_lazy() &&
|
|
||||||
string_starts_with(entry->name(), meta_index_dir) &&
|
|
||||||
string_ends_with(entry->name(), &package_name[2])) {
|
|
||||||
cur_entry = (LazyClassPathEntry*) entry;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the first character is '@', it indicates the following jar
|
|
||||||
// file is a resource only jar file in which case, we should skip
|
|
||||||
// reading the subsequent entries since the resource loading is
|
|
||||||
// totally handled by J2SE side.
|
|
||||||
if (package_name[0] == '@') {
|
|
||||||
if (cur_entry != NULL) {
|
|
||||||
cur_entry->set_meta_index(new MetaIndex(NULL, 0));
|
|
||||||
}
|
|
||||||
cur_entry = NULL;
|
|
||||||
skipCurrentJar = true;
|
|
||||||
} else {
|
|
||||||
skipCurrentJar = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
if (!skipCurrentJar && cur_entry != NULL) {
|
|
||||||
char* new_name = os::strdup_check_oom(package_name);
|
|
||||||
boot_class_path_packages.append(new_name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Hand off current packages to current lazy entry (if any)
|
|
||||||
if ((cur_entry != NULL) &&
|
|
||||||
(boot_class_path_packages.length() > 0)) {
|
|
||||||
if ((TraceClassLoading || TraceClassPaths) && Verbose) {
|
|
||||||
print_meta_index(cur_entry, boot_class_path_packages);
|
|
||||||
}
|
|
||||||
MetaIndex* index = new MetaIndex(boot_class_path_packages.adr_at(0),
|
|
||||||
boot_class_path_packages.length());
|
|
||||||
cur_entry->set_meta_index(index);
|
|
||||||
}
|
|
||||||
fclose(file);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
void ClassLoader::check_shared_classpath(const char *path) {
|
void ClassLoader::check_shared_classpath(const char *path) {
|
||||||
if (strcmp(path, "") == 0) {
|
if (strcmp(path, "") == 0) {
|
||||||
|
@ -1315,10 +1149,6 @@ void ClassLoader::initialize() {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
setup_bootstrap_search_path();
|
setup_bootstrap_search_path();
|
||||||
if (LazyBootClassLoader) {
|
|
||||||
// set up meta index which makes boot classpath initialization lazier
|
|
||||||
setup_bootstrap_meta_index();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
|
@ -1486,12 +1316,7 @@ void ClassPathZipEntry::compile_the_world(Handle loader, TRAPS) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ClassPathZipEntry::is_jrt() {
|
bool ClassPathZipEntry::is_jrt() {
|
||||||
real_jzfile* zip = (real_jzfile*) _zip;
|
return false;
|
||||||
int len = (int)strlen(zip->name);
|
|
||||||
// Check whether zip name ends in "rt.jar"
|
|
||||||
// This will match other archives named rt.jar as well, but this is
|
|
||||||
// only used for debugging.
|
|
||||||
return string_ends_with(zip->name, "rt.jar");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void LazyClassPathEntry::compile_the_world(Handle loader, TRAPS) {
|
void LazyClassPathEntry::compile_the_world(Handle loader, TRAPS) {
|
||||||
|
@ -1519,7 +1344,7 @@ void ClassLoader::compile_the_world() {
|
||||||
ClassPathEntry* e = _first_entry;
|
ClassPathEntry* e = _first_entry;
|
||||||
jlong start = os::javaTimeMillis();
|
jlong start = os::javaTimeMillis();
|
||||||
while (e != NULL) {
|
while (e != NULL) {
|
||||||
// We stop at rt.jar, unless it is the first bootstrap path entry
|
// We stop at bootmodules.jimage, unless it is the first bootstrap path entry
|
||||||
if (e->is_jrt() && e != _first_entry) break;
|
if (e->is_jrt() && e != _first_entry) break;
|
||||||
e->compile_the_world(system_class_loader, CATCH);
|
e->compile_the_world(system_class_loader, CATCH);
|
||||||
e = e->next();
|
e = e->next();
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -33,18 +33,6 @@
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
|
|
||||||
// Meta-index (optional, to be able to skip opening boot classpath jar files)
|
|
||||||
class MetaIndex: public CHeapObj<mtClass> {
|
|
||||||
private:
|
|
||||||
char** _meta_package_names;
|
|
||||||
int _num_meta_package_names;
|
|
||||||
public:
|
|
||||||
MetaIndex(char** meta_package_names, int num_meta_package_names);
|
|
||||||
~MetaIndex();
|
|
||||||
bool may_contain(const char* class_name);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
// Class path entry (directory or zip file)
|
// Class path entry (directory or zip file)
|
||||||
|
|
||||||
class ClassPathEntry: public CHeapObj<mtClass> {
|
class ClassPathEntry: public CHeapObj<mtClass> {
|
||||||
|
@ -122,7 +110,6 @@ class LazyClassPathEntry: public ClassPathEntry {
|
||||||
private:
|
private:
|
||||||
const char* _path; // dir or file
|
const char* _path; // dir or file
|
||||||
struct stat _st;
|
struct stat _st;
|
||||||
MetaIndex* _meta_index;
|
|
||||||
bool _has_error;
|
bool _has_error;
|
||||||
bool _throw_exception;
|
bool _throw_exception;
|
||||||
volatile ClassPathEntry* _resolved_entry;
|
volatile ClassPathEntry* _resolved_entry;
|
||||||
|
@ -135,7 +122,6 @@ class LazyClassPathEntry: public ClassPathEntry {
|
||||||
u1* open_entry(const char* name, jint* filesize, bool nul_terminate, TRAPS);
|
u1* open_entry(const char* name, jint* filesize, bool nul_terminate, TRAPS);
|
||||||
|
|
||||||
ClassFileStream* open_stream(const char* name, TRAPS);
|
ClassFileStream* open_stream(const char* name, TRAPS);
|
||||||
void set_meta_index(MetaIndex* meta_index) { _meta_index = meta_index; }
|
|
||||||
virtual bool is_lazy();
|
virtual bool is_lazy();
|
||||||
// Debugging
|
// Debugging
|
||||||
NOT_PRODUCT(void compile_the_world(Handle loader, TRAPS);)
|
NOT_PRODUCT(void compile_the_world(Handle loader, TRAPS);)
|
||||||
|
@ -231,9 +217,6 @@ class ClassLoader: AllStatic {
|
||||||
static bool add_package(const char *pkgname, int classpath_index, TRAPS);
|
static bool add_package(const char *pkgname, int classpath_index, TRAPS);
|
||||||
|
|
||||||
// Initialization
|
// Initialization
|
||||||
static void setup_bootstrap_meta_index();
|
|
||||||
static void setup_meta_index(const char* meta_index_path, const char* meta_index_dir,
|
|
||||||
int start_index);
|
|
||||||
static void setup_bootstrap_search_path();
|
static void setup_bootstrap_search_path();
|
||||||
static void setup_search_path(const char *class_path);
|
static void setup_search_path(const char *class_path);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -1015,7 +1015,6 @@ const Type *PhiNode::Value( PhaseTransform *phase ) const {
|
||||||
if( jtip && ttip ) {
|
if( jtip && ttip ) {
|
||||||
if( jtip->is_loaded() && jtip->klass()->is_interface() &&
|
if( jtip->is_loaded() && jtip->klass()->is_interface() &&
|
||||||
ttip->is_loaded() && !ttip->klass()->is_interface() ) {
|
ttip->is_loaded() && !ttip->klass()->is_interface() ) {
|
||||||
// Happens in a CTW of rt.jar, 320-341, no extra flags
|
|
||||||
assert(ft == ttip->cast_to_ptr_type(jtip->ptr()) ||
|
assert(ft == ttip->cast_to_ptr_type(jtip->ptr()) ||
|
||||||
ft->isa_narrowoop() && ft->make_ptr() == ttip->cast_to_ptr_type(jtip->ptr()), "");
|
ft->isa_narrowoop() && ft->make_ptr() == ttip->cast_to_ptr_type(jtip->ptr()), "");
|
||||||
jt = ft;
|
jt = ft;
|
||||||
|
|
|
@ -2598,8 +2598,7 @@ bool LibraryCallKit::inline_unsafe_access(bool is_native_ptr, bool is_store, Bas
|
||||||
// bypassing each other. Happens after null checks, so the
|
// bypassing each other. Happens after null checks, so the
|
||||||
// exception paths do not take memory state from the memory barrier,
|
// exception paths do not take memory state from the memory barrier,
|
||||||
// so there's no problems making a strong assert about mixing users
|
// so there's no problems making a strong assert about mixing users
|
||||||
// of safe & unsafe memory. Otherwise fails in a CTW of rt.jar
|
// of safe & unsafe memory.
|
||||||
// around 5701, class sun/reflect/UnsafeBooleanFieldAccessorImpl.
|
|
||||||
if (need_mem_bar) insert_mem_bar(Op_MemBarCPUOrder);
|
if (need_mem_bar) insert_mem_bar(Op_MemBarCPUOrder);
|
||||||
|
|
||||||
if (!is_store) {
|
if (!is_store) {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -3122,7 +3122,6 @@ const Type *TypeOopPtr::filter_helper(const Type *kills, bool include_speculativ
|
||||||
if (ftip != NULL && ktip != NULL &&
|
if (ftip != NULL && ktip != NULL &&
|
||||||
ftip->is_loaded() && ftip->klass()->is_interface() &&
|
ftip->is_loaded() && ftip->klass()->is_interface() &&
|
||||||
ktip->is_loaded() && !ktip->klass()->is_interface()) {
|
ktip->is_loaded() && !ktip->klass()->is_interface()) {
|
||||||
// Happens in a CTW of rt.jar, 320-341, no extra flags
|
|
||||||
assert(!ftip->klass_is_exact(), "interface could not be exact");
|
assert(!ftip->klass_is_exact(), "interface could not be exact");
|
||||||
return ktip->cast_to_ptr_type(ftip->ptr());
|
return ktip->cast_to_ptr_type(ftip->ptr());
|
||||||
}
|
}
|
||||||
|
|
|
@ -109,8 +109,6 @@ SystemProperty *Arguments::_java_home = NULL;
|
||||||
SystemProperty *Arguments::_java_class_path = NULL;
|
SystemProperty *Arguments::_java_class_path = NULL;
|
||||||
SystemProperty *Arguments::_sun_boot_class_path = NULL;
|
SystemProperty *Arguments::_sun_boot_class_path = NULL;
|
||||||
|
|
||||||
char* Arguments::_meta_index_path = NULL;
|
|
||||||
char* Arguments::_meta_index_dir = NULL;
|
|
||||||
char* Arguments::_ext_dirs = NULL;
|
char* Arguments::_ext_dirs = NULL;
|
||||||
|
|
||||||
// Check if head of 'option' matches 'name', and sets 'tail' to the remaining
|
// Check if head of 'option' matches 'name', and sets 'tail' to the remaining
|
||||||
|
|
|
@ -260,10 +260,6 @@ class Arguments : AllStatic {
|
||||||
static SystemProperty *_java_class_path;
|
static SystemProperty *_java_class_path;
|
||||||
static SystemProperty *_sun_boot_class_path;
|
static SystemProperty *_sun_boot_class_path;
|
||||||
|
|
||||||
// Meta-index for knowing what packages are in the boot class path
|
|
||||||
static char* _meta_index_path;
|
|
||||||
static char* _meta_index_dir;
|
|
||||||
|
|
||||||
// temporary: to emit warning if the default ext dirs are not empty.
|
// temporary: to emit warning if the default ext dirs are not empty.
|
||||||
// remove this variable when the warning is no longer needed.
|
// remove this variable when the warning is no longer needed.
|
||||||
static char* _ext_dirs;
|
static char* _ext_dirs;
|
||||||
|
@ -600,16 +596,10 @@ class Arguments : AllStatic {
|
||||||
static void set_ext_dirs(char *value) { _ext_dirs = os::strdup_check_oom(value); }
|
static void set_ext_dirs(char *value) { _ext_dirs = os::strdup_check_oom(value); }
|
||||||
static void set_sysclasspath(char *value) { _sun_boot_class_path->set_value(value); }
|
static void set_sysclasspath(char *value) { _sun_boot_class_path->set_value(value); }
|
||||||
static void append_sysclasspath(const char *value) { _sun_boot_class_path->append_value(value); }
|
static void append_sysclasspath(const char *value) { _sun_boot_class_path->append_value(value); }
|
||||||
static void set_meta_index_path(char* meta_index_path, char* meta_index_dir) {
|
|
||||||
_meta_index_path = meta_index_path;
|
|
||||||
_meta_index_dir = meta_index_dir;
|
|
||||||
}
|
|
||||||
|
|
||||||
static char* get_java_home() { return _java_home->value(); }
|
static char* get_java_home() { return _java_home->value(); }
|
||||||
static char* get_dll_dir() { return _sun_boot_library_path->value(); }
|
static char* get_dll_dir() { return _sun_boot_library_path->value(); }
|
||||||
static char* get_sysclasspath() { return _sun_boot_class_path->value(); }
|
static char* get_sysclasspath() { return _sun_boot_class_path->value(); }
|
||||||
static char* get_meta_index_path() { return _meta_index_path; }
|
|
||||||
static char* get_meta_index_dir() { return _meta_index_dir; }
|
|
||||||
static char* get_ext_dirs() { return _ext_dirs; }
|
static char* get_ext_dirs() { return _ext_dirs; }
|
||||||
static char* get_appclasspath() { return _java_class_path->value(); }
|
static char* get_appclasspath() { return _java_class_path->value(); }
|
||||||
static void fix_appclasspath();
|
static void fix_appclasspath();
|
||||||
|
|
|
@ -1223,14 +1223,6 @@ bool os::set_boot_path(char fileSep, char pathSep) {
|
||||||
const char* home = Arguments::get_java_home();
|
const char* home = Arguments::get_java_home();
|
||||||
int home_len = (int)strlen(home);
|
int home_len = (int)strlen(home);
|
||||||
|
|
||||||
static const char* meta_index_dir_format = "%/lib/";
|
|
||||||
static const char* meta_index_format = "%/lib/meta-index";
|
|
||||||
char* meta_index = format_boot_path(meta_index_format, home, home_len, fileSep, pathSep);
|
|
||||||
if (meta_index == NULL) return false;
|
|
||||||
char* meta_index_dir = format_boot_path(meta_index_dir_format, home, home_len, fileSep, pathSep);
|
|
||||||
if (meta_index_dir == NULL) return false;
|
|
||||||
Arguments::set_meta_index_path(meta_index, meta_index_dir);
|
|
||||||
|
|
||||||
char* sysclasspath = NULL;
|
char* sysclasspath = NULL;
|
||||||
struct stat st;
|
struct stat st;
|
||||||
|
|
||||||
|
@ -1244,39 +1236,18 @@ bool os::set_boot_path(char fileSep, char pathSep) {
|
||||||
}
|
}
|
||||||
FREE_C_HEAP_ARRAY(char, jimage);
|
FREE_C_HEAP_ARRAY(char, jimage);
|
||||||
|
|
||||||
// images build if rt.jar exists
|
// check if developer build with exploded modules
|
||||||
char* rt_jar = format_boot_path("%/lib/rt.jar", home, home_len, fileSep, pathSep);
|
char* modules_dir = format_boot_path("%/modules", home, home_len, fileSep, pathSep);
|
||||||
if (rt_jar == NULL) return false;
|
if (os::stat(modules_dir, &st) == 0) {
|
||||||
bool has_rt_jar = (os::stat(rt_jar, &st) == 0);
|
if ((st.st_mode & S_IFDIR) == S_IFDIR) {
|
||||||
FREE_C_HEAP_ARRAY(char, rt_jar);
|
sysclasspath = expand_entries_to_path(modules_dir, fileSep, pathSep);
|
||||||
|
|
||||||
if (has_rt_jar) {
|
|
||||||
// Any modification to the JAR-file list, for the boot classpath must be
|
|
||||||
// aligned with install/install/make/common/Pack.gmk. Note: boot class
|
|
||||||
// path class JARs, are stripped for StackMapTable to reduce download size.
|
|
||||||
static const char classpath_format[] =
|
|
||||||
"%/lib/resources.jar:"
|
|
||||||
"%/lib/rt.jar:"
|
|
||||||
"%/lib/jsse.jar:"
|
|
||||||
"%/lib/jce.jar:"
|
|
||||||
"%/lib/charsets.jar:"
|
|
||||||
"%/lib/jfr.jar:"
|
|
||||||
"%/classes";
|
|
||||||
sysclasspath = format_boot_path(classpath_format, home, home_len, fileSep, pathSep);
|
|
||||||
} else {
|
|
||||||
// no rt.jar, check if developer build with exploded modules
|
|
||||||
char* modules_dir = format_boot_path("%/modules", home, home_len, fileSep, pathSep);
|
|
||||||
if (os::stat(modules_dir, &st) == 0) {
|
|
||||||
if ((st.st_mode & S_IFDIR) == S_IFDIR) {
|
|
||||||
sysclasspath = expand_entries_to_path(modules_dir, fileSep, pathSep);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// fallback to classes
|
|
||||||
if (sysclasspath == NULL)
|
|
||||||
sysclasspath = format_boot_path("%/classes", home, home_len, fileSep, pathSep);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// fallback to classes
|
||||||
|
if (sysclasspath == NULL)
|
||||||
|
sysclasspath = format_boot_path("%/classes", home, home_len, fileSep, pathSep);
|
||||||
|
|
||||||
if (sysclasspath == NULL) return false;
|
if (sysclasspath == NULL) return false;
|
||||||
Arguments::set_sysclasspath(sysclasspath);
|
Arguments::set_sysclasspath(sysclasspath);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue