提交 391b39eb 编写于 作者: C cjplummer

Merge

...@@ -1198,19 +1198,20 @@ static bool file_exists(const char* filename) { ...@@ -1198,19 +1198,20 @@ static bool file_exists(const char* filename) {
return os::stat(filename, &statbuf) == 0; return os::stat(filename, &statbuf) == 0;
} }
void os::dll_build_name(char* buffer, size_t buflen, bool os::dll_build_name(char* buffer, size_t buflen,
const char* pname, const char* fname) { const char* pname, const char* fname) {
bool retval = false;
// Copied from libhpi // Copied from libhpi
const size_t pnamelen = pname ? strlen(pname) : 0; const size_t pnamelen = pname ? strlen(pname) : 0;
// Quietly truncate on buffer overflow. Should be an error. // Return error on buffer overflow.
if (pnamelen + strlen(fname) + strlen(JNI_LIB_PREFIX) + strlen(JNI_LIB_SUFFIX) + 2 > buflen) { if (pnamelen + strlen(fname) + strlen(JNI_LIB_PREFIX) + strlen(JNI_LIB_SUFFIX) + 2 > buflen) {
*buffer = '\0'; return retval;
return;
} }
if (pnamelen == 0) { if (pnamelen == 0) {
snprintf(buffer, buflen, JNI_LIB_PREFIX "%s" JNI_LIB_SUFFIX, fname); snprintf(buffer, buflen, JNI_LIB_PREFIX "%s" JNI_LIB_SUFFIX, fname);
retval = true;
} else if (strchr(pname, *os::path_separator()) != NULL) { } else if (strchr(pname, *os::path_separator()) != NULL) {
int n; int n;
char** pelements = split_path(pname, &n); char** pelements = split_path(pname, &n);
...@@ -1222,6 +1223,7 @@ void os::dll_build_name(char* buffer, size_t buflen, ...@@ -1222,6 +1223,7 @@ void os::dll_build_name(char* buffer, size_t buflen,
snprintf(buffer, buflen, "%s/" JNI_LIB_PREFIX "%s" JNI_LIB_SUFFIX, snprintf(buffer, buflen, "%s/" JNI_LIB_PREFIX "%s" JNI_LIB_SUFFIX,
pelements[i], fname); pelements[i], fname);
if (file_exists(buffer)) { if (file_exists(buffer)) {
retval = true;
break; break;
} }
} }
...@@ -1236,7 +1238,9 @@ void os::dll_build_name(char* buffer, size_t buflen, ...@@ -1236,7 +1238,9 @@ void os::dll_build_name(char* buffer, size_t buflen,
} }
} else { } else {
snprintf(buffer, buflen, "%s/" JNI_LIB_PREFIX "%s" JNI_LIB_SUFFIX, pname, fname); snprintf(buffer, buflen, "%s/" JNI_LIB_PREFIX "%s" JNI_LIB_SUFFIX, pname, fname);
retval = true;
} }
return retval;
} }
const char* os::get_current_directory(char *buf, int buflen) { const char* os::get_current_directory(char *buf, int buflen) {
......
...@@ -1650,19 +1650,20 @@ static bool file_exists(const char* filename) { ...@@ -1650,19 +1650,20 @@ static bool file_exists(const char* filename) {
return os::stat(filename, &statbuf) == 0; return os::stat(filename, &statbuf) == 0;
} }
void os::dll_build_name(char* buffer, size_t buflen, bool os::dll_build_name(char* buffer, size_t buflen,
const char* pname, const char* fname) { const char* pname, const char* fname) {
bool retval = false;
// Copied from libhpi // Copied from libhpi
const size_t pnamelen = pname ? strlen(pname) : 0; const size_t pnamelen = pname ? strlen(pname) : 0;
// Quietly truncate on buffer overflow. Should be an error. // Return error on buffer overflow.
if (pnamelen + strlen(fname) + 10 > (size_t) buflen) { if (pnamelen + strlen(fname) + 10 > (size_t) buflen) {
*buffer = '\0'; return retval;
return;
} }
if (pnamelen == 0) { if (pnamelen == 0) {
snprintf(buffer, buflen, "lib%s.so", fname); snprintf(buffer, buflen, "lib%s.so", fname);
retval = true;
} else if (strchr(pname, *os::path_separator()) != NULL) { } else if (strchr(pname, *os::path_separator()) != NULL) {
int n; int n;
char** pelements = split_path(pname, &n); char** pelements = split_path(pname, &n);
...@@ -1673,6 +1674,7 @@ void os::dll_build_name(char* buffer, size_t buflen, ...@@ -1673,6 +1674,7 @@ void os::dll_build_name(char* buffer, size_t buflen,
} }
snprintf(buffer, buflen, "%s/lib%s.so", pelements[i], fname); snprintf(buffer, buflen, "%s/lib%s.so", pelements[i], fname);
if (file_exists(buffer)) { if (file_exists(buffer)) {
retval = true;
break; break;
} }
} }
...@@ -1687,7 +1689,9 @@ void os::dll_build_name(char* buffer, size_t buflen, ...@@ -1687,7 +1689,9 @@ void os::dll_build_name(char* buffer, size_t buflen,
} }
} else { } else {
snprintf(buffer, buflen, "%s/lib%s.so", pname, fname); snprintf(buffer, buflen, "%s/lib%s.so", pname, fname);
retval = true;
} }
return retval;
} }
const char* os::get_current_directory(char *buf, int buflen) { const char* os::get_current_directory(char *buf, int buflen) {
......
...@@ -1894,18 +1894,19 @@ static bool file_exists(const char* filename) { ...@@ -1894,18 +1894,19 @@ static bool file_exists(const char* filename) {
return os::stat(filename, &statbuf) == 0; return os::stat(filename, &statbuf) == 0;
} }
void os::dll_build_name(char* buffer, size_t buflen, bool os::dll_build_name(char* buffer, size_t buflen,
const char* pname, const char* fname) { const char* pname, const char* fname) {
bool retval = false;
const size_t pnamelen = pname ? strlen(pname) : 0; const size_t pnamelen = pname ? strlen(pname) : 0;
// Quietly truncate on buffer overflow. Should be an error. // Return error on buffer overflow.
if (pnamelen + strlen(fname) + 10 > (size_t) buflen) { if (pnamelen + strlen(fname) + 10 > (size_t) buflen) {
*buffer = '\0'; return retval;
return;
} }
if (pnamelen == 0) { if (pnamelen == 0) {
snprintf(buffer, buflen, "lib%s.so", fname); snprintf(buffer, buflen, "lib%s.so", fname);
retval = true;
} else if (strchr(pname, *os::path_separator()) != NULL) { } else if (strchr(pname, *os::path_separator()) != NULL) {
int n; int n;
char** pelements = split_path(pname, &n); char** pelements = split_path(pname, &n);
...@@ -1916,6 +1917,7 @@ void os::dll_build_name(char* buffer, size_t buflen, ...@@ -1916,6 +1917,7 @@ void os::dll_build_name(char* buffer, size_t buflen,
} }
snprintf(buffer, buflen, "%s/lib%s.so", pelements[i], fname); snprintf(buffer, buflen, "%s/lib%s.so", pelements[i], fname);
if (file_exists(buffer)) { if (file_exists(buffer)) {
retval = true;
break; break;
} }
} }
...@@ -1930,7 +1932,9 @@ void os::dll_build_name(char* buffer, size_t buflen, ...@@ -1930,7 +1932,9 @@ void os::dll_build_name(char* buffer, size_t buflen,
} }
} else { } else {
snprintf(buffer, buflen, "%s/lib%s.so", pname, fname); snprintf(buffer, buflen, "%s/lib%s.so", pname, fname);
retval = true;
} }
return retval;
} }
const char* os::get_current_directory(char *buf, int buflen) { const char* os::get_current_directory(char *buf, int buflen) {
......
...@@ -1132,21 +1132,23 @@ static bool file_exists(const char* filename) { ...@@ -1132,21 +1132,23 @@ static bool file_exists(const char* filename) {
return GetFileAttributes(filename) != INVALID_FILE_ATTRIBUTES; return GetFileAttributes(filename) != INVALID_FILE_ATTRIBUTES;
} }
void os::dll_build_name(char *buffer, size_t buflen, bool os::dll_build_name(char *buffer, size_t buflen,
const char* pname, const char* fname) { const char* pname, const char* fname) {
bool retval = false;
const size_t pnamelen = pname ? strlen(pname) : 0; const size_t pnamelen = pname ? strlen(pname) : 0;
const char c = (pnamelen > 0) ? pname[pnamelen-1] : 0; const char c = (pnamelen > 0) ? pname[pnamelen-1] : 0;
// Quietly truncates on buffer overflow. Should be an error. // Return error on buffer overflow.
if (pnamelen + strlen(fname) + 10 > buflen) { if (pnamelen + strlen(fname) + 10 > buflen) {
*buffer = '\0'; return retval;
return;
} }
if (pnamelen == 0) { if (pnamelen == 0) {
jio_snprintf(buffer, buflen, "%s.dll", fname); jio_snprintf(buffer, buflen, "%s.dll", fname);
retval = true;
} else if (c == ':' || c == '\\') { } else if (c == ':' || c == '\\') {
jio_snprintf(buffer, buflen, "%s%s.dll", pname, fname); jio_snprintf(buffer, buflen, "%s%s.dll", pname, fname);
retval = true;
} else if (strchr(pname, *os::path_separator()) != NULL) { } else if (strchr(pname, *os::path_separator()) != NULL) {
int n; int n;
char** pelements = split_path(pname, &n); char** pelements = split_path(pname, &n);
...@@ -1164,6 +1166,7 @@ void os::dll_build_name(char *buffer, size_t buflen, ...@@ -1164,6 +1166,7 @@ void os::dll_build_name(char *buffer, size_t buflen,
jio_snprintf(buffer, buflen, "%s\\%s.dll", path, fname); jio_snprintf(buffer, buflen, "%s\\%s.dll", path, fname);
} }
if (file_exists(buffer)) { if (file_exists(buffer)) {
retval = true;
break; break;
} }
} }
...@@ -1178,7 +1181,9 @@ void os::dll_build_name(char *buffer, size_t buflen, ...@@ -1178,7 +1181,9 @@ void os::dll_build_name(char *buffer, size_t buflen,
} }
} else { } else {
jio_snprintf(buffer, buflen, "%s\\%s.dll", pname, fname); jio_snprintf(buffer, buflen, "%s\\%s.dll", pname, fname);
retval = true;
} }
return retval;
} }
// Needs to be in os specific directory because windows requires another // Needs to be in os specific directory because windows requires another
......
...@@ -605,8 +605,10 @@ void ClassLoader::load_zip_library() { ...@@ -605,8 +605,10 @@ void ClassLoader::load_zip_library() {
// Load zip library // Load zip library
char path[JVM_MAXPATHLEN]; char path[JVM_MAXPATHLEN];
char ebuf[1024]; char ebuf[1024];
os::dll_build_name(path, sizeof(path), Arguments::get_dll_dir(), "zip"); void* handle = NULL;
void* handle = os::dll_load(path, ebuf, sizeof ebuf); if (os::dll_build_name(path, sizeof(path), Arguments::get_dll_dir(), "zip")) {
handle = os::dll_load(path, ebuf, sizeof ebuf);
}
if (handle == NULL) { if (handle == NULL) {
vm_exit_during_initialization("Unable to load ZIP library", path); vm_exit_during_initialization("Unable to load ZIP library", path);
} }
......
...@@ -2177,7 +2177,7 @@ extern "C" { ...@@ -2177,7 +2177,7 @@ extern "C" {
jint JvmtiExport::load_agent_library(AttachOperation* op, outputStream* st) { jint JvmtiExport::load_agent_library(AttachOperation* op, outputStream* st) {
char ebuf[1024]; char ebuf[1024];
char buffer[JVM_MAXPATHLEN]; char buffer[JVM_MAXPATHLEN];
void* library; void* library = NULL;
jint result = JNI_ERR; jint result = JNI_ERR;
// get agent name and options // get agent name and options
...@@ -2196,13 +2196,16 @@ jint JvmtiExport::load_agent_library(AttachOperation* op, outputStream* st) { ...@@ -2196,13 +2196,16 @@ jint JvmtiExport::load_agent_library(AttachOperation* op, outputStream* st) {
library = os::dll_load(agent, ebuf, sizeof ebuf); library = os::dll_load(agent, ebuf, sizeof ebuf);
} else { } else {
// Try to load the agent from the standard dll directory // Try to load the agent from the standard dll directory
os::dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(), agent); if (os::dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(),
library = os::dll_load(buffer, ebuf, sizeof ebuf); agent)) {
library = os::dll_load(buffer, ebuf, sizeof ebuf);
}
if (library == NULL) { if (library == NULL) {
// not found - try local path // not found - try local path
char ns[1] = {0}; char ns[1] = {0};
os::dll_build_name(buffer, sizeof(buffer), ns, agent); if (os::dll_build_name(buffer, sizeof(buffer), ns, agent)) {
library = os::dll_load(buffer, ebuf, sizeof ebuf); library = os::dll_load(buffer, ebuf, sizeof ebuf);
}
} }
} }
......
...@@ -397,12 +397,16 @@ void* os::native_java_library() { ...@@ -397,12 +397,16 @@ void* os::native_java_library() {
// Try to load verify dll first. In 1.3 java dll depends on it and is not // Try to load verify dll first. In 1.3 java dll depends on it and is not
// always able to find it when the loading executable is outside the JDK. // always able to find it when the loading executable is outside the JDK.
// In order to keep working with 1.2 we ignore any loading errors. // In order to keep working with 1.2 we ignore any loading errors.
dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(), "verify"); if (dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(),
dll_load(buffer, ebuf, sizeof(ebuf)); "verify")) {
dll_load(buffer, ebuf, sizeof(ebuf));
}
// Load java dll // Load java dll
dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(), "java"); if (dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(),
_native_java_library = dll_load(buffer, ebuf, sizeof(ebuf)); "java")) {
_native_java_library = dll_load(buffer, ebuf, sizeof(ebuf));
}
if (_native_java_library == NULL) { if (_native_java_library == NULL) {
vm_exit_during_initialization("Unable to load native library", ebuf); vm_exit_during_initialization("Unable to load native library", ebuf);
} }
...@@ -410,8 +414,10 @@ void* os::native_java_library() { ...@@ -410,8 +414,10 @@ void* os::native_java_library() {
#if defined(__OpenBSD__) #if defined(__OpenBSD__)
// Work-around OpenBSD's lack of $ORIGIN support by pre-loading libnet.so // Work-around OpenBSD's lack of $ORIGIN support by pre-loading libnet.so
// ignore errors // ignore errors
dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(), "net"); if (dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(),
dll_load(buffer, ebuf, sizeof(ebuf)); "net")) {
dll_load(buffer, ebuf, sizeof(ebuf));
}
#endif #endif
} }
static jboolean onLoaded = JNI_FALSE; static jboolean onLoaded = JNI_FALSE;
...@@ -1156,7 +1162,7 @@ char** os::split_path(const char* path, int* n) { ...@@ -1156,7 +1162,7 @@ char** os::split_path(const char* path, int* n) {
if (inpath == NULL) { if (inpath == NULL) {
return NULL; return NULL;
} }
strncpy(inpath, path, strlen(path)); strcpy(inpath, path);
int count = 1; int count = 1;
char* p = strchr(inpath, psepchar); char* p = strchr(inpath, psepchar);
// Get a count of elements to allocate memory // Get a count of elements to allocate memory
......
...@@ -479,7 +479,8 @@ class os: AllStatic { ...@@ -479,7 +479,8 @@ class os: AllStatic {
static const char* get_current_directory(char *buf, int buflen); static const char* get_current_directory(char *buf, int buflen);
// Builds a platform-specific full library path given a ld path and lib name // Builds a platform-specific full library path given a ld path and lib name
static void dll_build_name(char* buffer, size_t size, // Returns true if buffer contains full path to existing file, false otherwise
static bool dll_build_name(char* buffer, size_t size,
const char* pathname, const char* fname); const char* pathname, const char* fname);
// Symbol lookup, find nearest function name; basically it implements // Symbol lookup, find nearest function name; basically it implements
......
...@@ -3753,8 +3753,10 @@ static OnLoadEntry_t lookup_on_load(AgentLibrary* agent, const char *on_load_sym ...@@ -3753,8 +3753,10 @@ static OnLoadEntry_t lookup_on_load(AgentLibrary* agent, const char *on_load_sym
} }
} else { } else {
// Try to load the agent from the standard dll directory // Try to load the agent from the standard dll directory
os::dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(), name); if (os::dll_build_name(buffer, sizeof(buffer), Arguments::get_dll_dir(),
library = os::dll_load(buffer, ebuf, sizeof ebuf); name)) {
library = os::dll_load(buffer, ebuf, sizeof ebuf);
}
#ifdef KERNEL #ifdef KERNEL
// Download instrument dll // Download instrument dll
if (library == NULL && strcmp(name, "instrument") == 0) { if (library == NULL && strcmp(name, "instrument") == 0) {
...@@ -3779,8 +3781,9 @@ static OnLoadEntry_t lookup_on_load(AgentLibrary* agent, const char *on_load_sym ...@@ -3779,8 +3781,9 @@ static OnLoadEntry_t lookup_on_load(AgentLibrary* agent, const char *on_load_sym
#endif // KERNEL #endif // KERNEL
if (library == NULL) { // Try the local directory if (library == NULL) { // Try the local directory
char ns[1] = {0}; char ns[1] = {0};
os::dll_build_name(buffer, sizeof(buffer), ns, name); if (os::dll_build_name(buffer, sizeof(buffer), ns, name)) {
library = os::dll_load(buffer, ebuf, sizeof ebuf); library = os::dll_load(buffer, ebuf, sizeof ebuf);
}
if (library == NULL) { if (library == NULL) {
const char *sub_msg = " on the library path, with error: "; const char *sub_msg = " on the library path, with error: ";
size_t len = strlen(msg) + strlen(name) + strlen(sub_msg) + strlen(ebuf) + 1; size_t len = strlen(msg) + strlen(name) + strlen(sub_msg) + strlen(ebuf) + 1;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册