8282077: PKCS11 provider C_sign() impl should handle CKR_BUFFER_TOO_SMALL error
Reviewed-by: mikael
This commit is contained in:
parent
d3749de478
commit
d7f31d0d53
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Copyright (c) 2002 Graz University of Technology. All rights reserved.
|
/* Copyright (c) 2002 Graz University of Technology. All rights reserved.
|
||||||
@ -144,11 +144,22 @@ JNIEXPORT jbyteArray JNICALL Java_sun_security_pkcs11_wrapper_PKCS11_C_1Sign
|
|||||||
|
|
||||||
TRACE1("DEBUG C_Sign: ret rv=0x%lX\n", rv);
|
TRACE1("DEBUG C_Sign: ret rv=0x%lX\n", rv);
|
||||||
|
|
||||||
|
if (rv == CKR_BUFFER_TOO_SMALL) {
|
||||||
|
bufP = (CK_BYTE_PTR) malloc(ckSignatureLength);
|
||||||
|
if (bufP == NULL) {
|
||||||
|
throwOutOfMemoryError(env, 0);
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
rv = (*ckpFunctions->C_Sign)(ckSessionHandle, ckpData, ckDataLength,
|
||||||
|
bufP, &ckSignatureLength);
|
||||||
|
}
|
||||||
|
|
||||||
if (ckAssertReturnValueOK(env, rv) == CK_ASSERT_OK) {
|
if (ckAssertReturnValueOK(env, rv) == CK_ASSERT_OK) {
|
||||||
jSignature = ckByteArrayToJByteArray(env, bufP, ckSignatureLength);
|
jSignature = ckByteArrayToJByteArray(env, bufP, ckSignatureLength);
|
||||||
TRACE1("DEBUG C_Sign: signature length = %lu\n", ckSignatureLength);
|
TRACE1("DEBUG C_Sign: signature length = %lu\n", ckSignatureLength);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cleanup:
|
||||||
free(ckpData);
|
free(ckpData);
|
||||||
if (bufP != BUF) { free(bufP); }
|
if (bufP != BUF) { free(bufP); }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user