8309569: sun/security/pkcs11/Signature/TestRSAKeyLength.java fails after JDK-8301553

Co-authored-by: Martin Balao <mbalao@openjdk.org>
Co-authored-by: Francisco Ferrari Bihurriet <fferrari@redhat.com>
Reviewed-by: valeriep
This commit is contained in:
Martin Balao 2023-06-08 01:24:26 +00:00
parent e8a59843f2
commit 760cb04a2e
2 changed files with 34 additions and 29 deletions

View File

@ -536,13 +536,14 @@ void jBooleanArrayToCKBBoolArray(JNIEnv *env, const jbooleanArray jArray, CK_BBO
jboolean* jpTemp; jboolean* jpTemp;
CK_ULONG i; CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray); if (jArray == NULL) {
if(*ckpLength == 0L) {
*ckpArray = NULL_PTR; *ckpArray = NULL_PTR;
*ckpLength = 0UL;
return; return;
} }
*ckpLength = (*env)->GetArrayLength(env, jArray);
jpTemp = (jboolean*) calloc(*ckpLength, sizeof(jboolean)); jpTemp = (jboolean*) calloc(*ckpLength, sizeof(jboolean));
if (jpTemp == NULL) { if (jpTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
} }
@ -552,8 +553,8 @@ void jBooleanArrayToCKBBoolArray(JNIEnv *env, const jbooleanArray jArray, CK_BBO
return; return;
} }
*ckpArray = (CK_BBOOL*) calloc (*ckpLength, sizeof(CK_BBOOL)); *ckpArray = (CK_BBOOL*) calloc(*ckpLength, sizeof(CK_BBOOL));
if (*ckpArray == NULL) { if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jpTemp); free(jpTemp);
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
@ -577,13 +578,14 @@ void jByteArrayToCKByteArray(JNIEnv *env, const jbyteArray jArray, CK_BYTE_PTR *
jbyte* jpTemp; jbyte* jpTemp;
CK_ULONG i; CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray); if (jArray == NULL) {
if(*ckpLength == 0L) {
*ckpArray = NULL_PTR; *ckpArray = NULL_PTR;
*ckpLength = 0UL;
return; return;
} }
*ckpLength = (*env)->GetArrayLength(env, jArray);
jpTemp = (jbyte*) calloc(*ckpLength, sizeof(jbyte)); jpTemp = (jbyte*) calloc(*ckpLength, sizeof(jbyte));
if (jpTemp == NULL) { if (jpTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
} }
@ -597,8 +599,8 @@ void jByteArrayToCKByteArray(JNIEnv *env, const jbyteArray jArray, CK_BYTE_PTR *
if (sizeof(CK_BYTE) == sizeof(jbyte)) { if (sizeof(CK_BYTE) == sizeof(jbyte)) {
*ckpArray = (CK_BYTE_PTR) jpTemp; *ckpArray = (CK_BYTE_PTR) jpTemp;
} else { } else {
*ckpArray = (CK_BYTE_PTR) calloc (*ckpLength, sizeof(CK_BYTE)); *ckpArray = (CK_BYTE_PTR) calloc(*ckpLength, sizeof(CK_BYTE));
if (*ckpArray == NULL) { if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jpTemp); free(jpTemp);
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
@ -623,13 +625,14 @@ void jLongArrayToCKULongArray(JNIEnv *env, const jlongArray jArray, CK_ULONG_PTR
jlong* jTemp; jlong* jTemp;
CK_ULONG i; CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray); if (jArray == NULL) {
if(*ckpLength == 0L) {
*ckpArray = NULL_PTR; *ckpArray = NULL_PTR;
*ckpLength = 0UL;
return; return;
} }
*ckpLength = (*env)->GetArrayLength(env, jArray);
jTemp = (jlong*) calloc(*ckpLength, sizeof(jlong)); jTemp = (jlong*) calloc(*ckpLength, sizeof(jlong));
if (jTemp == NULL) { if (jTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
} }
@ -640,7 +643,7 @@ void jLongArrayToCKULongArray(JNIEnv *env, const jlongArray jArray, CK_ULONG_PTR
} }
*ckpArray = (CK_ULONG_PTR) calloc(*ckpLength, sizeof(CK_ULONG)); *ckpArray = (CK_ULONG_PTR) calloc(*ckpLength, sizeof(CK_ULONG));
if (*ckpArray == NULL) { if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jTemp); free(jTemp);
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
@ -664,13 +667,14 @@ void jCharArrayToCKCharArray(JNIEnv *env, const jcharArray jArray, CK_CHAR_PTR *
jchar* jpTemp; jchar* jpTemp;
CK_ULONG i; CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray); if (jArray == NULL) {
if(*ckpLength == 0L) {
*ckpArray = NULL_PTR; *ckpArray = NULL_PTR;
*ckpLength = 0UL;
return; return;
} }
*ckpLength = (*env)->GetArrayLength(env, jArray);
jpTemp = (jchar*) calloc(*ckpLength, sizeof(jchar)); jpTemp = (jchar*) calloc(*ckpLength, sizeof(jchar));
if (jpTemp == NULL) { if (jpTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
} }
@ -680,8 +684,8 @@ void jCharArrayToCKCharArray(JNIEnv *env, const jcharArray jArray, CK_CHAR_PTR *
return; return;
} }
*ckpArray = (CK_CHAR_PTR) calloc (*ckpLength, sizeof(CK_CHAR)); *ckpArray = (CK_CHAR_PTR) calloc(*ckpLength, sizeof(CK_CHAR));
if (*ckpArray == NULL) { if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jpTemp); free(jpTemp);
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
@ -705,13 +709,14 @@ void jCharArrayToCKUTF8CharArray(JNIEnv *env, const jcharArray jArray, CK_UTF8CH
jchar* jTemp; jchar* jTemp;
CK_ULONG i; CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray); if (jArray == NULL) {
if(*ckpLength == 0L) {
*ckpArray = NULL_PTR; *ckpArray = NULL_PTR;
*ckpLength = 0UL;
return; return;
} }
*ckpLength = (*env)->GetArrayLength(env, jArray);
jTemp = (jchar*) calloc(*ckpLength, sizeof(jchar)); jTemp = (jchar*) calloc(*ckpLength, sizeof(jchar));
if (jTemp == NULL) { if (jTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
} }
@ -721,7 +726,7 @@ void jCharArrayToCKUTF8CharArray(JNIEnv *env, const jcharArray jArray, CK_UTF8CH
} }
*ckpArray = (CK_UTF8CHAR_PTR) calloc(*ckpLength, sizeof(CK_UTF8CHAR)); *ckpArray = (CK_UTF8CHAR_PTR) calloc(*ckpLength, sizeof(CK_UTF8CHAR));
if (*ckpArray == NULL) { if (*ckpArray == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
goto cleanup; goto cleanup;
} }
@ -792,7 +797,7 @@ void jAttributeArrayToCKAttributeArray(JNIEnv *env, jobjectArray jArray, CK_ATTR
jLength = (*env)->GetArrayLength(env, jArray); jLength = (*env)->GetArrayLength(env, jArray);
*ckpLength = jLongToCKULong(jLength); *ckpLength = jLongToCKULong(jLength);
*ckpArray = (CK_ATTRIBUTE_PTR) calloc(*ckpLength, sizeof(CK_ATTRIBUTE)); *ckpArray = (CK_ATTRIBUTE_PTR) calloc(*ckpLength, sizeof(CK_ATTRIBUTE));
if (*ckpArray == NULL) { if (*ckpArray == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return; return;
} }
@ -833,7 +838,7 @@ jbyteArray ckByteArrayToJByteArray(JNIEnv *env, const CK_BYTE_PTR ckpArray, CK_U
jpTemp = (jbyte*) ckpArray; jpTemp = (jbyte*) ckpArray;
} else { } else {
jpTemp = (jbyte*) calloc(ckLength, sizeof(jbyte)); jpTemp = (jbyte*) calloc(ckLength, sizeof(jbyte));
if (jpTemp == NULL) { if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return NULL; return NULL;
} }
@ -867,7 +872,7 @@ jlongArray ckULongArrayToJLongArray(JNIEnv *env, const CK_ULONG_PTR ckpArray, CK
jlongArray jArray; jlongArray jArray;
jpTemp = (jlong*) calloc(ckLength, sizeof(jlong)); jpTemp = (jlong*) calloc(ckLength, sizeof(jlong));
if (jpTemp == NULL) { if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return NULL; return NULL;
} }
@ -898,7 +903,7 @@ jcharArray ckCharArrayToJCharArray(JNIEnv *env, const CK_CHAR_PTR ckpArray, CK_U
jcharArray jArray; jcharArray jArray;
jpTemp = (jchar*) calloc(ckLength, sizeof(jchar)); jpTemp = (jchar*) calloc(ckLength, sizeof(jchar));
if (jpTemp == NULL) { if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return NULL; return NULL;
} }
@ -929,7 +934,7 @@ jcharArray ckUTF8CharArrayToJCharArray(JNIEnv *env, const CK_UTF8CHAR_PTR ckpArr
jcharArray jArray; jcharArray jArray;
jpTemp = (jchar*) calloc(ckLength, sizeof(jchar)); jpTemp = (jchar*) calloc(ckLength, sizeof(jchar));
if (jpTemp == NULL) { if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0); p11ThrowOutOfMemoryError(env, 0);
return NULL; return NULL;
} }

View File

@ -606,7 +606,7 @@ sun/security/provider/PolicyFile/GrantAllPermToExtWhenNoPolicy.java 8039280 gene
sun/security/provider/PolicyParser/PrincipalExpansionError.java 8039280 generic-all sun/security/provider/PolicyParser/PrincipalExpansionError.java 8039280 generic-all
sun/security/tools/keytool/NssTest.java 8295343 linux-all sun/security/tools/keytool/NssTest.java 8295343 linux-all
sun/security/pkcs11/Signature/TestRSAKeyLength.java 8295343,8309569 linux-all,macosx-x64,windows-x64 sun/security/pkcs11/Signature/TestRSAKeyLength.java 8295343 linux-all
sun/security/pkcs11/rsa/TestSignatures.java 8295343 linux-all sun/security/pkcs11/rsa/TestSignatures.java 8295343 linux-all
sun/security/pkcs11/rsa/TestKeyPairGenerator.java 8295343 linux-all sun/security/pkcs11/rsa/TestKeyPairGenerator.java 8295343 linux-all
sun/security/pkcs11/rsa/TestKeyFactory.java 8295343 linux-all sun/security/pkcs11/rsa/TestKeyFactory.java 8295343 linux-all