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;
CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray);
if(*ckpLength == 0L) {
if (jArray == NULL) {
*ckpArray = NULL_PTR;
*ckpLength = 0UL;
return;
}
*ckpLength = (*env)->GetArrayLength(env, jArray);
jpTemp = (jboolean*) calloc(*ckpLength, sizeof(jboolean));
if (jpTemp == NULL) {
if (jpTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return;
}
@ -553,7 +554,7 @@ void jBooleanArrayToCKBBoolArray(JNIEnv *env, const jbooleanArray jArray, CK_BBO
}
*ckpArray = (CK_BBOOL*) calloc(*ckpLength, sizeof(CK_BBOOL));
if (*ckpArray == NULL) {
if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jpTemp);
p11ThrowOutOfMemoryError(env, 0);
return;
@ -577,13 +578,14 @@ void jByteArrayToCKByteArray(JNIEnv *env, const jbyteArray jArray, CK_BYTE_PTR *
jbyte* jpTemp;
CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray);
if(*ckpLength == 0L) {
if (jArray == NULL) {
*ckpArray = NULL_PTR;
*ckpLength = 0UL;
return;
}
*ckpLength = (*env)->GetArrayLength(env, jArray);
jpTemp = (jbyte*) calloc(*ckpLength, sizeof(jbyte));
if (jpTemp == NULL) {
if (jpTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return;
}
@ -598,7 +600,7 @@ void jByteArrayToCKByteArray(JNIEnv *env, const jbyteArray jArray, CK_BYTE_PTR *
*ckpArray = (CK_BYTE_PTR) jpTemp;
} else {
*ckpArray = (CK_BYTE_PTR) calloc(*ckpLength, sizeof(CK_BYTE));
if (*ckpArray == NULL) {
if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jpTemp);
p11ThrowOutOfMemoryError(env, 0);
return;
@ -623,13 +625,14 @@ void jLongArrayToCKULongArray(JNIEnv *env, const jlongArray jArray, CK_ULONG_PTR
jlong* jTemp;
CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray);
if(*ckpLength == 0L) {
if (jArray == NULL) {
*ckpArray = NULL_PTR;
*ckpLength = 0UL;
return;
}
*ckpLength = (*env)->GetArrayLength(env, jArray);
jTemp = (jlong*) calloc(*ckpLength, sizeof(jlong));
if (jTemp == NULL) {
if (jTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return;
}
@ -640,7 +643,7 @@ void jLongArrayToCKULongArray(JNIEnv *env, const jlongArray jArray, CK_ULONG_PTR
}
*ckpArray = (CK_ULONG_PTR) calloc(*ckpLength, sizeof(CK_ULONG));
if (*ckpArray == NULL) {
if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jTemp);
p11ThrowOutOfMemoryError(env, 0);
return;
@ -664,13 +667,14 @@ void jCharArrayToCKCharArray(JNIEnv *env, const jcharArray jArray, CK_CHAR_PTR *
jchar* jpTemp;
CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray);
if(*ckpLength == 0L) {
if (jArray == NULL) {
*ckpArray = NULL_PTR;
*ckpLength = 0UL;
return;
}
*ckpLength = (*env)->GetArrayLength(env, jArray);
jpTemp = (jchar*) calloc(*ckpLength, sizeof(jchar));
if (jpTemp == NULL) {
if (jpTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return;
}
@ -681,7 +685,7 @@ void jCharArrayToCKCharArray(JNIEnv *env, const jcharArray jArray, CK_CHAR_PTR *
}
*ckpArray = (CK_CHAR_PTR) calloc(*ckpLength, sizeof(CK_CHAR));
if (*ckpArray == NULL) {
if (*ckpArray == NULL && *ckpLength != 0UL) {
free(jpTemp);
p11ThrowOutOfMemoryError(env, 0);
return;
@ -705,13 +709,14 @@ void jCharArrayToCKUTF8CharArray(JNIEnv *env, const jcharArray jArray, CK_UTF8CH
jchar* jTemp;
CK_ULONG i;
*ckpLength = jArray == NULL ? 0L : (*env)->GetArrayLength(env, jArray);
if(*ckpLength == 0L) {
if (jArray == NULL) {
*ckpArray = NULL_PTR;
*ckpLength = 0UL;
return;
}
*ckpLength = (*env)->GetArrayLength(env, jArray);
jTemp = (jchar*) calloc(*ckpLength, sizeof(jchar));
if (jTemp == NULL) {
if (jTemp == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return;
}
@ -721,7 +726,7 @@ void jCharArrayToCKUTF8CharArray(JNIEnv *env, const jcharArray jArray, CK_UTF8CH
}
*ckpArray = (CK_UTF8CHAR_PTR) calloc(*ckpLength, sizeof(CK_UTF8CHAR));
if (*ckpArray == NULL) {
if (*ckpArray == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
goto cleanup;
}
@ -792,7 +797,7 @@ void jAttributeArrayToCKAttributeArray(JNIEnv *env, jobjectArray jArray, CK_ATTR
jLength = (*env)->GetArrayLength(env, jArray);
*ckpLength = jLongToCKULong(jLength);
*ckpArray = (CK_ATTRIBUTE_PTR) calloc(*ckpLength, sizeof(CK_ATTRIBUTE));
if (*ckpArray == NULL) {
if (*ckpArray == NULL && *ckpLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return;
}
@ -833,7 +838,7 @@ jbyteArray ckByteArrayToJByteArray(JNIEnv *env, const CK_BYTE_PTR ckpArray, CK_U
jpTemp = (jbyte*) ckpArray;
} else {
jpTemp = (jbyte*) calloc(ckLength, sizeof(jbyte));
if (jpTemp == NULL) {
if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return NULL;
}
@ -867,7 +872,7 @@ jlongArray ckULongArrayToJLongArray(JNIEnv *env, const CK_ULONG_PTR ckpArray, CK
jlongArray jArray;
jpTemp = (jlong*) calloc(ckLength, sizeof(jlong));
if (jpTemp == NULL) {
if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return NULL;
}
@ -898,7 +903,7 @@ jcharArray ckCharArrayToJCharArray(JNIEnv *env, const CK_CHAR_PTR ckpArray, CK_U
jcharArray jArray;
jpTemp = (jchar*) calloc(ckLength, sizeof(jchar));
if (jpTemp == NULL) {
if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
return NULL;
}
@ -929,7 +934,7 @@ jcharArray ckUTF8CharArrayToJCharArray(JNIEnv *env, const CK_UTF8CHAR_PTR ckpArr
jcharArray jArray;
jpTemp = (jchar*) calloc(ckLength, sizeof(jchar));
if (jpTemp == NULL) {
if (jpTemp == NULL && ckLength != 0UL) {
p11ThrowOutOfMemoryError(env, 0);
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/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/TestKeyPairGenerator.java 8295343 linux-all
sun/security/pkcs11/rsa/TestKeyFactory.java 8295343 linux-all