提交 4c304bf7 编写于 作者: M msheppar

8035340: (prefs) Check jdk/src/windows/native/java/util/WindowsPreference.c...

8035340: (prefs) Check jdk/src/windows/native/java/util/WindowsPreference.c for JNI pending exceptions
Summary: Check for JNI pending exceptions. Add null checks after malloc calls
Reviewed-by: alanb, chegar
上级 806ea6b9
/* /*
* Copyright (c) 2000, 2002, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2000, 2014, 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
...@@ -24,8 +24,10 @@ ...@@ -24,8 +24,10 @@
*/ */
#include <stdlib.h> #include <stdlib.h>
#include <jni.h>
#include <windows.h> #include <windows.h>
#include "jni.h"
#include "jni_util.h"
#include "jvm.h"
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
...@@ -37,12 +39,15 @@ extern "C" { ...@@ -37,12 +39,15 @@ extern "C" {
int errorCode=-1; int errorCode=-1;
jintArray result; jintArray result;
str = (*env)->GetByteArrayElements(env, lpSubKey, NULL); str = (*env)->GetByteArrayElements(env, lpSubKey, NULL);
CHECK_NULL_RETURN(str, NULL);
errorCode = RegOpenKeyEx((HKEY)hKey, str, 0, securityMask, &handle); errorCode = RegOpenKeyEx((HKEY)hKey, str, 0, securityMask, &handle);
(*env)->ReleaseByteArrayElements(env, lpSubKey, str, 0); (*env)->ReleaseByteArrayElements(env, lpSubKey, str, 0);
tmp[0]= (int) handle; tmp[0]= (int) handle;
tmp[1]= errorCode; tmp[1]= errorCode;
result = (*env)->NewIntArray(env,2); result = (*env)->NewIntArray(env,2);
(*env)->SetIntArrayRegion(env, result, 0, 2, tmp); if (result != NULL) {
(*env)->SetIntArrayRegion(env, result, 0, 2, tmp);
}
return result; return result;
} }
...@@ -58,8 +63,9 @@ extern "C" { ...@@ -58,8 +63,9 @@ extern "C" {
int tmp[3]; int tmp[3];
DWORD lpdwDisposition; DWORD lpdwDisposition;
int errorCode; int errorCode;
jintArray result; jintArray result = NULL;
str = (*env)->GetByteArrayElements(env, lpSubKey, NULL); str = (*env)->GetByteArrayElements(env, lpSubKey, NULL);
CHECK_NULL_RETURN(str, NULL);
errorCode = RegCreateKeyEx((HKEY)hKey, str, 0, NULL, errorCode = RegCreateKeyEx((HKEY)hKey, str, 0, NULL,
REG_OPTION_NON_VOLATILE, KEY_READ, REG_OPTION_NON_VOLATILE, KEY_READ,
NULL, &handle, &lpdwDisposition); NULL, &handle, &lpdwDisposition);
...@@ -68,7 +74,9 @@ extern "C" { ...@@ -68,7 +74,9 @@ extern "C" {
tmp[1]= errorCode; tmp[1]= errorCode;
tmp[2]= lpdwDisposition; tmp[2]= lpdwDisposition;
result = (*env)->NewIntArray(env,3); result = (*env)->NewIntArray(env,3);
(*env)->SetIntArrayRegion(env, result, 0, 3, tmp); if (result != NULL) {
(*env)->SetIntArrayRegion(env, result, 0, 3, tmp);
}
return result; return result;
} }
...@@ -77,6 +85,7 @@ extern "C" { ...@@ -77,6 +85,7 @@ extern "C" {
char* str; char* str;
int result; int result;
str = (*env)->GetByteArrayElements(env, lpSubKey, NULL); str = (*env)->GetByteArrayElements(env, lpSubKey, NULL);
CHECK_NULL_RETURN(str, -1);
result = RegDeleteKey((HKEY)hKey, str); result = RegDeleteKey((HKEY)hKey, str);
(*env)->ReleaseByteArrayElements(env, lpSubKey, str, 0); (*env)->ReleaseByteArrayElements(env, lpSubKey, str, 0);
return result; return result;
...@@ -96,6 +105,7 @@ extern "C" { ...@@ -96,6 +105,7 @@ extern "C" {
DWORD valueType; DWORD valueType;
DWORD valueSize; DWORD valueSize;
valueNameStr = (*env)->GetByteArrayElements(env, valueName, NULL); valueNameStr = (*env)->GetByteArrayElements(env, valueName, NULL);
CHECK_NULL_RETURN(valueNameStr, NULL);
if (RegQueryValueEx((HKEY)hKey, valueNameStr, NULL, &valueType, NULL, if (RegQueryValueEx((HKEY)hKey, valueNameStr, NULL, &valueType, NULL,
&valueSize) != ERROR_SUCCESS) { &valueSize) != ERROR_SUCCESS) {
(*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0); (*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0);
...@@ -104,18 +114,26 @@ extern "C" { ...@@ -104,18 +114,26 @@ extern "C" {
buffer = (char*)malloc(valueSize); buffer = (char*)malloc(valueSize);
if (RegQueryValueEx((HKEY)hKey, valueNameStr, NULL, &valueType, buffer, if (buffer != NULL) {
&valueSize) != ERROR_SUCCESS) { if (RegQueryValueEx((HKEY)hKey, valueNameStr, NULL, &valueType, buffer,
free(buffer); &valueSize) != ERROR_SUCCESS) {
free(buffer);
(*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0);
return NULL;
}
} else {
JNU_ThrowOutOfMemoryError(env, "native memory allocation failed");
(*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0); (*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0);
return NULL; return NULL;
} }
if (valueType == REG_SZ) { if (valueType == REG_SZ) {
result = (*env)->NewByteArray(env, valueSize); result = (*env)->NewByteArray(env, valueSize);
(*env)->SetByteArrayRegion(env, result, 0, valueSize, buffer); if (result != NULL) {
(*env)->SetByteArrayRegion(env, result, 0, valueSize, buffer);
}
} else { } else {
result = NULL; result = NULL;
} }
free(buffer); free(buffer);
(*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0); (*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0);
...@@ -135,7 +153,9 @@ extern "C" { ...@@ -135,7 +153,9 @@ extern "C" {
if ((valueName == NULL)||(data == NULL)) {return -1;} if ((valueName == NULL)||(data == NULL)) {return -1;}
size = (*env)->GetArrayLength(env, data); size = (*env)->GetArrayLength(env, data);
dataStr = (*env)->GetByteArrayElements(env, data, NULL); dataStr = (*env)->GetByteArrayElements(env, data, NULL);
CHECK_NULL_RETURN(dataStr, -1);
valueNameStr = (*env)->GetByteArrayElements(env, valueName, NULL); valueNameStr = (*env)->GetByteArrayElements(env, valueName, NULL);
CHECK_NULL_RETURN(valueNameStr, -1);
error_code = RegSetValueEx((HKEY)hKey, valueNameStr, 0, error_code = RegSetValueEx((HKEY)hKey, valueNameStr, 0,
REG_SZ, dataStr, size); REG_SZ, dataStr, size);
(*env)->ReleaseByteArrayElements(env, data, dataStr, 0); (*env)->ReleaseByteArrayElements(env, data, dataStr, 0);
...@@ -149,6 +169,7 @@ extern "C" { ...@@ -149,6 +169,7 @@ extern "C" {
int error_code = -1; int error_code = -1;
if (valueName == NULL) {return -1;} if (valueName == NULL) {return -1;}
valueNameStr = (*env)->GetByteArrayElements(env, valueName, NULL); valueNameStr = (*env)->GetByteArrayElements(env, valueName, NULL);
CHECK_NULL_RETURN(valueNameStr, -1);
error_code = RegDeleteValue((HKEY)hKey, valueNameStr); error_code = RegDeleteValue((HKEY)hKey, valueNameStr);
(*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0); (*env)->ReleaseByteArrayElements(env, valueName, valueNameStr, 0);
return error_code; return error_code;
...@@ -156,7 +177,7 @@ extern "C" { ...@@ -156,7 +177,7 @@ extern "C" {
JNIEXPORT jintArray JNICALL Java_java_util_prefs_WindowsPreferences_WindowsRegQueryInfoKey JNIEXPORT jintArray JNICALL Java_java_util_prefs_WindowsPreferences_WindowsRegQueryInfoKey
(JNIEnv* env, jclass this_class, jint hKey) { (JNIEnv* env, jclass this_class, jint hKey) {
jintArray result; jintArray result = NULL;
int tmp[5]; int tmp[5];
int valuesNumber = -1; int valuesNumber = -1;
int maxValueNameLength = -1; int maxValueNameLength = -1;
...@@ -173,7 +194,9 @@ extern "C" { ...@@ -173,7 +194,9 @@ extern "C" {
tmp[3]= maxSubKeyLength; tmp[3]= maxSubKeyLength;
tmp[4]= maxValueNameLength; tmp[4]= maxValueNameLength;
result = (*env)->NewIntArray(env,5); result = (*env)->NewIntArray(env,5);
(*env)->SetIntArrayRegion(env, result, 0, 5, tmp); if (result != NULL) {
(*env)->SetIntArrayRegion(env, result, 0, 5, tmp);
}
return result; return result;
} }
...@@ -183,13 +206,19 @@ extern "C" { ...@@ -183,13 +206,19 @@ extern "C" {
jbyteArray result; jbyteArray result;
char* buffer = NULL; char* buffer = NULL;
buffer = (char*)malloc(maxKeyLength); buffer = (char*)malloc(maxKeyLength);
if (buffer == NULL) {
JNU_ThrowOutOfMemoryError(env, "native memory allocation failed");
return NULL;
}
if (RegEnumKeyEx((HKEY) hKey, subKeyIndex, buffer, &size, NULL, NULL, if (RegEnumKeyEx((HKEY) hKey, subKeyIndex, buffer, &size, NULL, NULL,
NULL, NULL) != ERROR_SUCCESS){ NULL, NULL) != ERROR_SUCCESS){
free(buffer); free(buffer);
return NULL; return NULL;
} }
result = (*env)->NewByteArray(env, size + 1); result = (*env)->NewByteArray(env, size + 1);
(*env)->SetByteArrayRegion(env, result, 0, size + 1, buffer); if (result != NULL) {
(*env)->SetByteArrayRegion(env, result, 0, size + 1, buffer);
}
free(buffer); free(buffer);
return result; return result;
} }
...@@ -201,6 +230,10 @@ extern "C" { ...@@ -201,6 +230,10 @@ extern "C" {
char* buffer = NULL; char* buffer = NULL;
int error_code; int error_code;
buffer = (char*)malloc(maxValueNameLength); buffer = (char*)malloc(maxValueNameLength);
if (buffer == NULL) {
JNU_ThrowOutOfMemoryError(env, "native memory allocation failed");
return NULL;
}
error_code = RegEnumValue((HKEY) hKey, valueIndex, buffer, error_code = RegEnumValue((HKEY) hKey, valueIndex, buffer,
&size, NULL, NULL, NULL, NULL); &size, NULL, NULL, NULL, NULL);
if (error_code!= ERROR_SUCCESS){ if (error_code!= ERROR_SUCCESS){
...@@ -208,7 +241,9 @@ extern "C" { ...@@ -208,7 +241,9 @@ extern "C" {
return NULL; return NULL;
} }
result = (*env)->NewByteArray(env, size + 1); result = (*env)->NewByteArray(env, size + 1);
(*env)->SetByteArrayRegion(env, result, 0, size + 1, buffer); if (result != NULL) {
(*env)->SetByteArrayRegion(env, result, 0, size + 1, buffer);
}
free(buffer); free(buffer);
return result; return result;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册