From 7ab6dc83df2e19a57ff0dcdc87598c54cd949a7c Mon Sep 17 00:00:00 2001 From: Valerie Peng Date: Fri, 14 May 2021 23:04:37 +0000 Subject: [PATCH] 6676643: Improve current C_GetAttributeValue native implementation Reviewed-by: xuelei --- .../sun/security/pkcs11/P11AEADCipher.java | 1 + .../sun/security/pkcs11/P11Cipher.java | 1 + .../sun/security/pkcs11/P11KeyStore.java | 3 +- .../classes/sun/security/pkcs11/P11Mac.java | 1 + .../sun/security/pkcs11/P11PSSSignature.java | 2 +- .../sun/security/pkcs11/P11Signature.java | 1 + .../sun/security/pkcs11/SunPKCS11.java | 1 + .../classes/sun/security/pkcs11/Token.java | 5 +- .../sun/security/pkcs11/wrapper/PKCS11.java | 3 +- .../pkcs11/wrapper/PKCS11Constants.java | 127 +----- .../pkcs11/wrapper/PKCS11Exception.java | 378 ++++++++---------- .../share/native/libj2pkcs11/p11_objmgmt.c | 39 +- .../share/native/libj2pkcs11/p11_util.c | 83 ++-- .../share/native/libj2pkcs11/pkcs11wrapper.h | 1 + 14 files changed, 258 insertions(+), 388 deletions(-) diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java index 81800a58217..df9addcdb72 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java @@ -39,6 +39,7 @@ import sun.nio.ch.DirectBuffer; import sun.security.jca.JCAUtil; import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; /** * P11 AEAD Cipher implementation class. This class currently supports diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java index 3085585cc67..d2830b0db0c 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java @@ -38,6 +38,7 @@ import sun.nio.ch.DirectBuffer; import sun.security.jca.JCAUtil; import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; /** * Cipher implementation class. This class currently supports diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11KeyStore.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11KeyStore.java index 835961fbc9a..51fc6f0a71b 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11KeyStore.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11KeyStore.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -73,6 +73,7 @@ import static sun.security.pkcs11.P11Util.*; import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; import sun.security.rsa.RSAKeyFactory; diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Mac.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Mac.java index 29b26651c39..ba0b7faf3f8 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Mac.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Mac.java @@ -36,6 +36,7 @@ import sun.nio.ch.DirectBuffer; import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; /** * MAC implementation class. This class currently supports HMAC using diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11PSSSignature.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11PSSSignature.java index 36d0d67593c..5e608bbb8d8 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11PSSSignature.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11PSSSignature.java @@ -40,7 +40,7 @@ import java.security.interfaces.*; import sun.security.pkcs11.wrapper.*; import sun.security.util.KnownOIDs; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; - +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; /** * RSASSA-PSS Signature implementation class. This class currently supports the diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Signature.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Signature.java index 31c5d34a968..2ed207790bb 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Signature.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Signature.java @@ -42,6 +42,7 @@ import sun.security.rsa.RSAPadding; import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; import sun.security.util.KeyUtil; /** diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/SunPKCS11.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/SunPKCS11.java index 94692ad3529..0f72c167f6f 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/SunPKCS11.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/SunPKCS11.java @@ -53,6 +53,7 @@ import sun.security.pkcs11.Secmod.*; import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; /** * PKCS#11 provider main class. diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/Token.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/Token.java index 2aded7918fa..25b43aa68cc 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/Token.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/Token.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -38,6 +38,7 @@ import sun.security.jca.JCAUtil; import sun.security.pkcs11.wrapper.*; import static sun.security.pkcs11.TemplateManager.*; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; /** * PKCS#11 token. @@ -385,7 +386,7 @@ class Token implements Serializable { mechanism); mechInfoMap.put(mechanism, result); } catch (PKCS11Exception e) { - if (e.getErrorCode() != PKCS11Constants.CKR_MECHANISM_INVALID) { + if (e.getErrorCode() != CKR_MECHANISM_INVALID) { throw e; } else { mechInfoMap.put(mechanism, INVALID_MECH); diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11.java index d0830dc0add..895d8150863 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. */ /* Copyright (c) 2002 Graz University of Technology. All rights reserved. @@ -57,6 +57,7 @@ import java.security.PrivilegedAction; import sun.security.util.Debug; import static sun.security.pkcs11.wrapper.PKCS11Constants.*; +import static sun.security.pkcs11.wrapper.PKCS11Exception.*; /** * This is the default implementation of the PKCS11 interface. IT connects to diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Constants.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Constants.java index 8746192098a..d22844cfba8 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Constants.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Constants.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. */ /* Copyright (c) 2002 Graz University of Technology. All rights reserved. @@ -1043,130 +1043,7 @@ public interface PKCS11Constants { public static final long CKF_EXTENSION = 0x80000000L; /* Identifies the return value of a Cryptoki function */ - public static final long CKR_OK = 0x00000000L; - public static final long CKR_CANCEL = 0x00000001L; - public static final long CKR_HOST_MEMORY = 0x00000002L; - public static final long CKR_SLOT_ID_INVALID = 0x00000003L; - - public static final long CKR_GENERAL_ERROR = 0x00000005L; - public static final long CKR_FUNCTION_FAILED = 0x00000006L; - - public static final long CKR_ARGUMENTS_BAD = 0x00000007L; - public static final long CKR_NO_EVENT = 0x00000008L; - public static final long CKR_NEED_TO_CREATE_THREADS - = 0x00000009L; - public static final long CKR_CANT_LOCK = 0x0000000AL; - - public static final long CKR_ATTRIBUTE_READ_ONLY = 0x00000010L; - public static final long CKR_ATTRIBUTE_SENSITIVE = 0x00000011L; - public static final long CKR_ATTRIBUTE_TYPE_INVALID = 0x00000012L; - public static final long CKR_ATTRIBUTE_VALUE_INVALID = 0x00000013L; - public static final long CKR_ACTION_PROHIBITED = 0x0000001BL; - - public static final long CKR_DATA_INVALID = 0x00000020L; - public static final long CKR_DATA_LEN_RANGE = 0x00000021L; - public static final long CKR_DEVICE_ERROR = 0x00000030L; - public static final long CKR_DEVICE_MEMORY = 0x00000031L; - public static final long CKR_DEVICE_REMOVED = 0x00000032L; - public static final long CKR_ENCRYPTED_DATA_INVALID = 0x00000040L; - public static final long CKR_ENCRYPTED_DATA_LEN_RANGE = 0x00000041L; - public static final long CKR_AEAD_DECRYPT_FAILED = 0x00000042L; - public static final long CKR_FUNCTION_CANCELED = 0x00000050L; - public static final long CKR_FUNCTION_NOT_PARALLEL = 0x00000051L; - - public static final long CKR_FUNCTION_NOT_SUPPORTED = 0x00000054L; - - public static final long CKR_KEY_HANDLE_INVALID = 0x00000060L; - - public static final long CKR_KEY_SIZE_RANGE = 0x00000062L; - public static final long CKR_KEY_TYPE_INCONSISTENT = 0x00000063L; - - public static final long CKR_KEY_NOT_NEEDED = 0x00000064L; - public static final long CKR_KEY_CHANGED = 0x00000065L; - public static final long CKR_KEY_NEEDED = 0x00000066L; - public static final long CKR_KEY_INDIGESTIBLE = 0x00000067L; - public static final long CKR_KEY_FUNCTION_NOT_PERMITTED = 0x00000068L; - public static final long CKR_KEY_NOT_WRAPPABLE = 0x00000069L; - public static final long CKR_KEY_UNEXTRACTABLE = 0x0000006AL; - - public static final long CKR_MECHANISM_INVALID = 0x00000070L; - public static final long CKR_MECHANISM_PARAM_INVALID = 0x00000071L; - - public static final long CKR_OBJECT_HANDLE_INVALID = 0x00000082L; - public static final long CKR_OPERATION_ACTIVE = 0x00000090L; - public static final long CKR_OPERATION_NOT_INITIALIZED = 0x00000091L; - public static final long CKR_PIN_INCORRECT = 0x000000A0L; - public static final long CKR_PIN_INVALID = 0x000000A1L; - public static final long CKR_PIN_LEN_RANGE = 0x000000A2L; - - public static final long CKR_PIN_EXPIRED = 0x000000A3L; - public static final long CKR_PIN_LOCKED = 0x000000A4L; - - public static final long CKR_SESSION_CLOSED = 0x000000B0L; - public static final long CKR_SESSION_COUNT = 0x000000B1L; - public static final long CKR_SESSION_HANDLE_INVALID = 0x000000B3L; - public static final long CKR_SESSION_PARALLEL_NOT_SUPPORTED = 0x000000B4L; - public static final long CKR_SESSION_READ_ONLY = 0x000000B5L; - public static final long CKR_SESSION_EXISTS = 0x000000B6L; - - public static final long CKR_SESSION_READ_ONLY_EXISTS = 0x000000B7L; - public static final long CKR_SESSION_READ_WRITE_SO_EXISTS = 0x000000B8L; - - public static final long CKR_SIGNATURE_INVALID = 0x000000C0L; - public static final long CKR_SIGNATURE_LEN_RANGE = 0x000000C1L; - public static final long CKR_TEMPLATE_INCOMPLETE = 0x000000D0L; - public static final long CKR_TEMPLATE_INCONSISTENT = 0x000000D1L; - public static final long CKR_TOKEN_NOT_PRESENT = 0x000000E0L; - public static final long CKR_TOKEN_NOT_RECOGNIZED = 0x000000E1L; - public static final long CKR_TOKEN_WRITE_PROTECTED = 0x000000E2L; - public static final long CKR_UNWRAPPING_KEY_HANDLE_INVALID = 0x000000F0L; - public static final long CKR_UNWRAPPING_KEY_SIZE_RANGE = 0x000000F1L; - public static final long CKR_UNWRAPPING_KEY_TYPE_INCONSISTENT - = 0x000000F2L; - public static final long CKR_USER_ALREADY_LOGGED_IN = 0x00000100L; - public static final long CKR_USER_NOT_LOGGED_IN = 0x00000101L; - public static final long CKR_USER_PIN_NOT_INITIALIZED = 0x00000102L; - public static final long CKR_USER_TYPE_INVALID = 0x00000103L; - - public static final long CKR_USER_ANOTHER_ALREADY_LOGGED_IN = 0x00000104L; - public static final long CKR_USER_TOO_MANY_TYPES = 0x00000105L; - - public static final long CKR_WRAPPED_KEY_INVALID = 0x00000110L; - public static final long CKR_WRAPPED_KEY_LEN_RANGE = 0x00000112L; - public static final long CKR_WRAPPING_KEY_HANDLE_INVALID = 0x00000113L; - public static final long CKR_WRAPPING_KEY_SIZE_RANGE = 0x00000114L; - public static final long CKR_WRAPPING_KEY_TYPE_INCONSISTENT = 0x00000115L; - public static final long CKR_RANDOM_SEED_NOT_SUPPORTED = 0x00000120L; - - public static final long CKR_RANDOM_NO_RNG = 0x00000121L; - - public static final long CKR_DOMAIN_PARAMS_INVALID = 0x00000130L; - - public static final long CKR_CURVE_NOT_SUPPORTED = 0x00000140L; - - public static final long CKR_BUFFER_TOO_SMALL = 0x00000150L; - public static final long CKR_SAVED_STATE_INVALID = 0x00000160L; - public static final long CKR_INFORMATION_SENSITIVE = 0x00000170L; - public static final long CKR_STATE_UNSAVEABLE = 0x00000180L; - - public static final long CKR_CRYPTOKI_NOT_INITIALIZED = 0x00000190L; - public static final long CKR_CRYPTOKI_ALREADY_INITIALIZED = 0x00000191L; - public static final long CKR_MUTEX_BAD = 0x000001A0L; - public static final long CKR_MUTEX_NOT_LOCKED = 0x000001A1L; - - public static final long CKR_NEW_PIN_MODE = 0x000001B0L; - public static final long CKR_NEXT_OTP = 0x000001B1L; - - public static final long CKR_EXCEEDED_MAX_ITERATIONS = 0x000001B5L; - public static final long CKR_FIPS_SELF_TEST_FAILED = 0x000001B6L; - public static final long CKR_LIBRARY_LOAD_FAILED = 0x000001B7L; - public static final long CKR_PIN_TOO_WEAK = 0x000001B8L; - public static final long CKR_PUBLIC_KEY_INVALID = 0x000001B9L; - public static final long CKR_FUNCTION_REJECTED = 0x00000200L; - public static final long CKR_TOKEN_RESOURCE_EXCEEDED = 0x00000201L; - public static final long CKR_OPERATION_CANCEL_FAILED = 0x00000202L; - - public static final long CKR_VENDOR_DEFINED = 0x80000000L; + // These CKR_xxx constants are stored/defined in PKCS11Exception class /* Uncomment when actually used public static final long CKF_END_OF_MESSAGE = 0x00000001L; diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Exception.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Exception.java index 271ded6cc2f..e2d6d371bec 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Exception.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/wrapper/PKCS11Exception.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. */ /* Copyright (c) 2002 Graz University of Technology. All rights reserved. @@ -63,229 +63,172 @@ import static sun.security.pkcs11.wrapper.PKCS11Constants.*; * @invariants */ public class PKCS11Exception extends Exception { - private static final long serialVersionUID = 4877072363729195L; + private static final long serialVersionUID = 4077027363729192L; /** * The code of the error which was the reason for this exception. */ - protected long errorCode_; + protected long errorCode; - private static final Map errorMap; + protected String errorMsg; - static { - long[] errorCodes = new long[] { - CKR_OK, - CKR_CANCEL, - CKR_HOST_MEMORY, - CKR_SLOT_ID_INVALID, - CKR_GENERAL_ERROR, - CKR_FUNCTION_FAILED, - CKR_ARGUMENTS_BAD, - CKR_NO_EVENT, - CKR_NEED_TO_CREATE_THREADS, - CKR_CANT_LOCK, - CKR_ATTRIBUTE_READ_ONLY, - CKR_ATTRIBUTE_SENSITIVE, - CKR_ATTRIBUTE_TYPE_INVALID, - CKR_ATTRIBUTE_VALUE_INVALID, - CKR_ACTION_PROHIBITED, - CKR_DATA_INVALID, - CKR_DATA_LEN_RANGE, - CKR_DEVICE_ERROR, - CKR_DEVICE_MEMORY, - CKR_DEVICE_REMOVED, - CKR_ENCRYPTED_DATA_INVALID, - CKR_ENCRYPTED_DATA_LEN_RANGE, - CKR_AEAD_DECRYPT_FAILED, - CKR_FUNCTION_CANCELED, - CKR_FUNCTION_NOT_PARALLEL, - CKR_FUNCTION_NOT_SUPPORTED, - CKR_KEY_HANDLE_INVALID, - CKR_KEY_SIZE_RANGE, - CKR_KEY_TYPE_INCONSISTENT, - CKR_KEY_NOT_NEEDED, - CKR_KEY_CHANGED, - CKR_KEY_NEEDED, - CKR_KEY_INDIGESTIBLE, - CKR_KEY_FUNCTION_NOT_PERMITTED, - CKR_KEY_NOT_WRAPPABLE, - CKR_KEY_UNEXTRACTABLE, - CKR_MECHANISM_INVALID, - CKR_MECHANISM_PARAM_INVALID, - CKR_OBJECT_HANDLE_INVALID, - CKR_OPERATION_ACTIVE, - CKR_OPERATION_NOT_INITIALIZED, - CKR_PIN_INCORRECT, - CKR_PIN_INVALID, - CKR_PIN_LEN_RANGE, - CKR_PIN_EXPIRED, - CKR_PIN_LOCKED, - CKR_SESSION_CLOSED, - CKR_SESSION_COUNT, - CKR_SESSION_HANDLE_INVALID, - CKR_SESSION_PARALLEL_NOT_SUPPORTED, - CKR_SESSION_READ_ONLY, - CKR_SESSION_EXISTS, - CKR_SESSION_READ_ONLY_EXISTS, - CKR_SESSION_READ_WRITE_SO_EXISTS, - CKR_SIGNATURE_INVALID, - CKR_SIGNATURE_LEN_RANGE, - CKR_TEMPLATE_INCOMPLETE, - CKR_TEMPLATE_INCONSISTENT, - CKR_TOKEN_NOT_PRESENT, - CKR_TOKEN_NOT_RECOGNIZED, - CKR_TOKEN_WRITE_PROTECTED, - CKR_UNWRAPPING_KEY_HANDLE_INVALID, - CKR_UNWRAPPING_KEY_SIZE_RANGE, - CKR_UNWRAPPING_KEY_TYPE_INCONSISTENT, - CKR_USER_ALREADY_LOGGED_IN, - CKR_USER_NOT_LOGGED_IN, - CKR_USER_PIN_NOT_INITIALIZED, - CKR_USER_TYPE_INVALID, - CKR_USER_ANOTHER_ALREADY_LOGGED_IN, - CKR_USER_TOO_MANY_TYPES, - CKR_WRAPPED_KEY_INVALID, - CKR_WRAPPED_KEY_LEN_RANGE, - CKR_WRAPPING_KEY_HANDLE_INVALID, - CKR_WRAPPING_KEY_SIZE_RANGE, - CKR_WRAPPING_KEY_TYPE_INCONSISTENT, - CKR_RANDOM_SEED_NOT_SUPPORTED, - CKR_RANDOM_NO_RNG, - CKR_DOMAIN_PARAMS_INVALID, - CKR_CURVE_NOT_SUPPORTED, - CKR_BUFFER_TOO_SMALL, - CKR_SAVED_STATE_INVALID, - CKR_INFORMATION_SENSITIVE, - CKR_STATE_UNSAVEABLE, - CKR_CRYPTOKI_NOT_INITIALIZED, - CKR_CRYPTOKI_ALREADY_INITIALIZED, - CKR_MUTEX_BAD, - CKR_MUTEX_NOT_LOCKED, - CKR_NEW_PIN_MODE, - CKR_NEXT_OTP, - CKR_EXCEEDED_MAX_ITERATIONS, - CKR_FIPS_SELF_TEST_FAILED, - CKR_LIBRARY_LOAD_FAILED, - CKR_PIN_TOO_WEAK, - CKR_PUBLIC_KEY_INVALID, - CKR_FUNCTION_REJECTED, - CKR_TOKEN_RESOURCE_EXCEEDED, - CKR_OPERATION_CANCEL_FAILED, - CKR_VENDOR_DEFINED, - }; - String[] errorMessages = new String[] { - "CKR_OK", - "CKR_CANCEL", - "CKR_HOST_MEMORY", - "CKR_SLOT_ID_INVALID", - "CKR_GENERAL_ERROR", - "CKR_FUNCTION_FAILED", - "CKR_ARGUMENTS_BAD", - "CKR_NO_EVENT", - "CKR_NEED_TO_CREATE_THREADS", - "CKR_CANT_LOCK", - "CKR_ATTRIBUTE_READ_ONLY", - "CKR_ATTRIBUTE_SENSITIVE", - "CKR_ATTRIBUTE_TYPE_INVALID", - "CKR_ATTRIBUTE_VALUE_INVALID", - "CKR_ACTION_PROHIBITED", - "CKR_DATA_INVALID", - "CKR_DATA_LEN_RANGE", - "CKR_DEVICE_ERROR", - "CKR_DEVICE_MEMORY", - "CKR_DEVICE_REMOVED", - "CKR_ENCRYPTED_DATA_INVALID", - "CKR_ENCRYPTED_DATA_LEN_RANGE", - "CKR_AEAD_DECRYPT_FAILED", - "CKR_FUNCTION_CANCELED", - "CKR_FUNCTION_NOT_PARALLEL", - "CKR_FUNCTION_NOT_SUPPORTED", - "CKR_KEY_HANDLE_INVALID", - "CKR_KEY_SIZE_RANGE", - "CKR_KEY_TYPE_INCONSISTENT", - "CKR_KEY_NOT_NEEDED", - "CKR_KEY_CHANGED", - "CKR_KEY_NEEDED", - "CKR_KEY_INDIGESTIBLE", - "CKR_KEY_FUNCTION_NOT_PERMITTED", - "CKR_KEY_NOT_WRAPPABLE", - "CKR_KEY_UNEXTRACTABLE", - "CKR_MECHANISM_INVALID", - "CKR_MECHANISM_PARAM_INVALID", - "CKR_OBJECT_HANDLE_INVALID", - "CKR_OPERATION_ACTIVE", - "CKR_OPERATION_NOT_INITIALIZED", - "CKR_PIN_INCORRECT", - "CKR_PIN_INVALID", - "CKR_PIN_LEN_RANGE", - "CKR_PIN_EXPIRED", - "CKR_PIN_LOCKED", - "CKR_SESSION_CLOSED", - "CKR_SESSION_COUNT", - "CKR_SESSION_HANDLE_INVALID", - "CKR_SESSION_PARALLEL_NOT_SUPPORTED", - "CKR_SESSION_READ_ONLY", - "CKR_SESSION_EXISTS", - "CKR_SESSION_READ_ONLY_EXISTS", - "CKR_SESSION_READ_WRITE_SO_EXISTS", - "CKR_SIGNATURE_INVALID", - "CKR_SIGNATURE_LEN_RANGE", - "CKR_TEMPLATE_INCOMPLETE", - "CKR_TEMPLATE_INCONSISTENT", - "CKR_TOKEN_NOT_PRESENT", - "CKR_TOKEN_NOT_RECOGNIZED", - "CKR_TOKEN_WRITE_PROTECTED", - "CKR_UNWRAPPING_KEY_HANDLE_INVALID", - "CKR_UNWRAPPING_KEY_SIZE_RANGE", - "CKR_UNWRAPPING_KEY_TYPE_INCONSISTENT", - "CKR_USER_ALREADY_LOGGED_IN", - "CKR_USER_NOT_LOGGED_IN", - "CKR_USER_PIN_NOT_INITIALIZED", - "CKR_USER_TYPE_INVALID", - "CKR_USER_ANOTHER_ALREADY_LOGGED_IN", - "CKR_USER_TOO_MANY_TYPES", - "CKR_WRAPPED_KEY_INVALID", - "CKR_WRAPPED_KEY_LEN_RANGE", - "CKR_WRAPPING_KEY_HANDLE_INVALID", - "CKR_WRAPPING_KEY_SIZE_RANGE", - "CKR_WRAPPING_KEY_TYPE_INCONSISTENT", - "CKR_RANDOM_SEED_NOT_SUPPORTED", - "CKR_RANDOM_NO_RNG", - "CKR_DOMAIN_PARAMS_INVALID", - "CKR_CURVE_NOT_SUPPORTED", - "CKR_BUFFER_TOO_SMALL", - "CKR_SAVED_STATE_INVALID", - "CKR_INFORMATION_SENSITIVE", - "CKR_STATE_UNSAVEABLE", - "CKR_CRYPTOKI_NOT_INITIALIZED", - "CKR_CRYPTOKI_ALREADY_INITIALIZED", - "CKR_MUTEX_BAD", - "CKR_MUTEX_NOT_LOCKED", - "CKR_NEW_PIN_MODE", - "CKR_NEXT_OTP", - "CKR_EXCEEDED_MAX_ITERATIONS", - "CKR_FIPS_SELF_TEST_FAILED", - "CKR_LIBRARY_LOAD_FAILED", - "CKR_PIN_TOO_WEAK", - "CKR_PUBLIC_KEY_INVALID", - "CKR_FUNCTION_REJECTED", - "CKR_TOKEN_RESOURCE_EXCEEDED", - "CKR_OPERATION_CANCEL_FAILED", - "CKR_VENDOR_DEFINED", - }; - errorMap = new HashMap(); - for (int i = 0; i < errorCodes.length; i++) { - errorMap.put(Long.valueOf(errorCodes[i]), errorMessages[i]); + public static final long CKR_GENERAL_ERROR = RV.CKR_GENERAL_ERROR.value; + public static final long CKR_ATTRIBUTE_TYPE_INVALID = + RV.CKR_ATTRIBUTE_TYPE_INVALID.value; + public static final long CKR_DATA_LEN_RANGE = RV.CKR_DATA_LEN_RANGE.value; + public static final long CKR_ENCRYPTED_DATA_INVALID = + RV.CKR_ENCRYPTED_DATA_INVALID.value; + public static final long CKR_ENCRYPTED_DATA_LEN_RANGE = + RV.CKR_ENCRYPTED_DATA_LEN_RANGE.value; + public static final long CKR_MECHANISM_INVALID = + RV.CKR_MECHANISM_INVALID.value; + public static final long CKR_MECHANISM_PARAM_INVALID = + RV.CKR_MECHANISM_PARAM_INVALID.value; + public static final long CKR_OPERATION_NOT_INITIALIZED = + RV.CKR_OPERATION_NOT_INITIALIZED.value; + public static final long CKR_PIN_INCORRECT = + RV.CKR_PIN_INCORRECT.value; + public static final long CKR_SIGNATURE_INVALID = + RV.CKR_SIGNATURE_INVALID.value; + public static final long CKR_SIGNATURE_LEN_RANGE = + RV.CKR_SIGNATURE_LEN_RANGE.value; + public static final long CKR_USER_ALREADY_LOGGED_IN = + RV.CKR_USER_ALREADY_LOGGED_IN.value; + public static final long CKR_USER_NOT_LOGGED_IN = + RV.CKR_USER_NOT_LOGGED_IN.value; + public static final long CKR_BUFFER_TOO_SMALL = + RV.CKR_BUFFER_TOO_SMALL.value; + public static final long CKR_CRYPTOKI_ALREADY_INITIALIZED = + RV.CKR_CRYPTOKI_ALREADY_INITIALIZED.value; + + // enum for all PKCS#11 return value + static enum RV { + CKR_OK(0x00000000L), + CKR_CANCEL(0x00000001L), + CKR_HOST_MEMORY(0x00000002L), + CKR_SLOT_ID_INVALID(0x00000003L), + CKR_GENERAL_ERROR(0x00000005L), + CKR_FUNCTION_FAILED(0x00000006L), + CKR_ARGUMENTS_BAD(0x00000007L), + CKR_NO_EVENT(0x00000008L), + CKR_NEED_TO_CREATE_THREADS(0x00000009L), + CKR_CANT_LOCK(0x0000000AL), + CKR_ATTRIBUTE_READ_ONLY(0x00000010L), + CKR_ATTRIBUTE_SENSITIVE(0x00000011L), + CKR_ATTRIBUTE_TYPE_INVALID(0x00000012L), + CKR_ATTRIBUTE_VALUE_INVALID(0x00000013L), + CKR_ACTION_PROHIBITED(0x0000001BL), + CKR_DATA_INVALID(0x00000020L), + CKR_DATA_LEN_RANGE(0x00000021L), + CKR_DEVICE_ERROR(0x00000030L), + CKR_DEVICE_MEMORY(0x00000031L), + CKR_DEVICE_REMOVED(0x00000032L), + CKR_ENCRYPTED_DATA_INVALID(0x00000040L), + CKR_ENCRYPTED_DATA_LEN_RANGE(0x00000041L), + CKR_AEAD_DECRYPT_FAILED(0x00000042L), + CKR_FUNCTION_CANCELED(0x00000050L), + CKR_FUNCTION_NOT_PARALLEL(0x00000051L), + CKR_FUNCTION_NOT_SUPPORTED(0x00000054L), + CKR_KEY_HANDLE_INVALID(0x00000060L), + CKR_KEY_SIZE_RANGE(0x00000062L), + CKR_KEY_TYPE_INCONSISTENT(0x00000063L), + CKR_KEY_NOT_NEEDED(0x00000064L), + CKR_KEY_CHANGED(0x00000065L), + CKR_KEY_NEEDED(0x00000066L), + CKR_KEY_INDIGESTIBLE(0x00000067L), + CKR_KEY_FUNCTION_NOT_PERMITTED(0x00000068L), + CKR_KEY_NOT_WRAPPABLE(0x00000069L), + CKR_KEY_UNEXTRACTABLE(0x0000006AL), + CKR_MECHANISM_INVALID(0x00000070L), + CKR_MECHANISM_PARAM_INVALID(0x00000071L), + CKR_OBJECT_HANDLE_INVALID(0x00000082L), + CKR_OPERATION_ACTIVE(0x00000090L), + CKR_OPERATION_NOT_INITIALIZED(0x00000091L), + CKR_PIN_INCORRECT(0x000000A0L), + CKR_PIN_INVALID(0x000000A1L), + CKR_PIN_LEN_RANGE(0x000000A2L), + CKR_PIN_EXPIRED(0x000000A3L), + CKR_PIN_LOCKED(0x000000A4L), + CKR_SESSION_CLOSED(0x000000B0L), + CKR_SESSION_COUNT(0x000000B1L), + CKR_SESSION_HANDLE_INVALID(0x000000B3L), + CKR_SESSION_PARALLEL_NOT_SUPPORTED(0x000000B4L), + CKR_SESSION_READ_ONLY(0x000000B5L), + CKR_SESSION_EXISTS(0x000000B6L), + CKR_SESSION_READ_ONLY_EXISTS(0x000000B7L), + CKR_SESSION_READ_WRITE_SO_EXISTS(0x000000B8L), + CKR_SIGNATURE_INVALID(0x000000C0L), + CKR_SIGNATURE_LEN_RANGE(0x000000C1L), + CKR_TEMPLATE_INCOMPLETE(0x000000D0L), + CKR_TEMPLATE_INCONSISTENT(0x000000D1L), + CKR_TOKEN_NOT_PRESENT(0x000000E0L), + CKR_TOKEN_NOT_RECOGNIZED(0x000000E1L), + CKR_TOKEN_WRITE_PROTECTED(0x000000E2L), + CKR_UNWRAPPING_KEY_HANDLE_INVALID(0x000000F0L), + CKR_UNWRAPPING_KEY_SIZE_RANGE(0x000000F1L), + CKR_UNWRAPPING_KEY_TYPE_INCONSISTENT(0x000000F2L), + CKR_USER_ALREADY_LOGGED_IN(0x00000100L), + CKR_USER_NOT_LOGGED_IN(0x00000101L), + CKR_USER_PIN_NOT_INITIALIZED(0x00000102L), + CKR_USER_TYPE_INVALID(0x00000103L), + CKR_USER_ANOTHER_ALREADY_LOGGED_IN(0x00000104L), + CKR_USER_TOO_MANY_TYPES(0x00000105L), + CKR_WRAPPED_KEY_INVALID(0x00000110L), + CKR_WRAPPED_KEY_LEN_RANGE(0x00000112L), + CKR_WRAPPING_KEY_HANDLE_INVALID(0x00000113L), + CKR_WRAPPING_KEY_SIZE_RANGE(0x00000114L), + CKR_WRAPPING_KEY_TYPE_INCONSISTENT(0x00000115L), + CKR_RANDOM_SEED_NOT_SUPPORTED(0x00000120L), + CKR_RANDOM_NO_RNG(0x00000121L), + CKR_DOMAIN_PARAMS_INVALID(0x00000130L), + CKR_CURVE_NOT_SUPPORTED(0x00000140L), + CKR_BUFFER_TOO_SMALL(0x00000150L), + CKR_SAVED_STATE_INVALID(0x00000160L), + CKR_INFORMATION_SENSITIVE(0x00000170L), + CKR_STATE_UNSAVEABLE(0x00000180L), + CKR_CRYPTOKI_NOT_INITIALIZED(0x00000190L), + CKR_CRYPTOKI_ALREADY_INITIALIZED(0x00000191L), + CKR_MUTEX_BAD(0x000001A0L), + CKR_MUTEX_NOT_LOCKED(0x000001A1L), + CKR_NEW_PIN_MODE(0x000001B0L), + CKR_NEXT_OTP(0x000001B1L), + CKR_EXCEEDED_MAX_ITERATIONS(0x000001B5L), + CKR_FIPS_SELF_TEST_FAILED(0x000001B6L), + CKR_LIBRARY_LOAD_FAILED(0x000001B7L), + CKR_PIN_TOO_WEAK(0x000001B8L), + CKR_PUBLIC_KEY_INVALID(0x000001B9L), + CKR_FUNCTION_REJECTED(0x00000200L), + CKR_TOKEN_RESOURCE_EXCEEDED(0x00000201L), + CKR_OPERATION_CANCEL_FAILED(0x00000202L), + CKR_VENDOR_DEFINED(0x80000000L); + + private final long value; + + RV(long value) { + this.value = value; } + }; + + private static String lookup(long errorCode) { + for (RV r : RV.values()) { + if (r.value == errorCode) { + return r.name(); + } + } + // for unknown PKCS11 return values, just use hex as its string + return "0x" + Functions.toFullHexString((int)errorCode); } - /** - * Constructor taking the error code as defined for the CKR_* constants - * in PKCS#11. + * Constructor taking the error code (the CKR_* constants in PKCS#11) and + * extra info for error message. */ - public PKCS11Exception(long errorCode) { - errorCode_ = errorCode; + public PKCS11Exception(long errorCode, String extraInfo) { + this.errorCode = errorCode; + this.errorMsg = lookup(errorCode); + if (extraInfo != null) { + this.errorMsg += extraInfo; + } } /** @@ -299,11 +242,7 @@ public class PKCS11Exception extends Exception { * @postconditions (result <> null) */ public String getMessage() { - String message = errorMap.get(Long.valueOf(errorCode_)); - if (message == null) { - message = "0x" + Functions.toFullHexString((int)errorCode_); - } - return message; + return errorMsg; } /** @@ -314,7 +253,6 @@ public class PKCS11Exception extends Exception { * @postconditions */ public long getErrorCode() { - return errorCode_ ; + return errorCode; } - } diff --git a/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_objmgmt.c b/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_objmgmt.c index d9d2e68bccc..55537bf8f83 100644 --- a/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_objmgmt.c +++ b/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_objmgmt.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. */ /* Copyright (c) 2002 Graz University of Technology. All rights reserved. @@ -218,6 +218,8 @@ JNIEXPORT void JNICALL Java_sun_security_pkcs11_wrapper_PKCS11_C_1GetAttributeVa CK_ULONG i; jobject jAttribute; CK_RV rv; + char* msg = NULL; + char* temp1, *temp2; CK_FUNCTION_LIST_PTR ckpFunctions = getFunctionList(env, obj); if (ckpFunctions == NULL) { return; } @@ -245,13 +247,35 @@ JNIEXPORT void JNICALL Java_sun_security_pkcs11_wrapper_PKCS11_C_1GetAttributeVa } rv = (*ckpFunctions->C_GetAttributeValue)(ckSessionHandle, ckObjectHandle, ckpAttributes, ckAttributesLength); - if (ckAssertReturnValueOK(env, rv) != CK_ASSERT_OK) { + + if (rv != CKR_OK) { + if (rv == CKR_ATTRIBUTE_SENSITIVE || rv == CKR_ATTRIBUTE_TYPE_INVALID) { + msg = malloc(80); // should be more than sufficient + if (msg == NULL) { + throwOutOfMemoryError(env, 0); + free(ckpAttributes); + return; + } + // format msg w/ attribute(s) whose value is unavailable + temp1 = msg; + temp2 = msg + 80; + for (i = 0; i < ckAttributesLength && temp1 < temp2; i++) { + if (ckpAttributes[i].ulValueLen == CK_UNAVAILABLE_INFORMATION) { + temp1 += snprintf(temp1, (temp2-temp1), " 0x%lX", + ckpAttributes[i].type); + } + } + ckAssertReturnValueOK2(env, rv, msg); + free(msg); + } else { + ckAssertReturnValueOK(env, rv); + } free(ckpAttributes); - return ; + return; } - /* now, the ulValueLength field of each attribute should hold the exact buffer length needed - * allocate the needed buffers accordingly + /* now, the ulValueLength field of each attribute should hold the exact + * buffer length needed. */ for (i = 0; i < ckAttributesLength; i++) { ckBufferLength = sizeof(CK_BYTE) * ckpAttributes[i].ulValueLen; @@ -264,8 +288,9 @@ JNIEXPORT void JNICALL Java_sun_security_pkcs11_wrapper_PKCS11_C_1GetAttributeVa ckpAttributes[i].ulValueLen = ckBufferLength; } - /* now get the attributes with all values */ - rv = (*ckpFunctions->C_GetAttributeValue)(ckSessionHandle, ckObjectHandle, ckpAttributes, ckAttributesLength); + /* now get all attribute values */ + rv = (*ckpFunctions->C_GetAttributeValue)(ckSessionHandle, + ckObjectHandle, ckpAttributes, ckAttributesLength); if (ckAssertReturnValueOK(env, rv) == CK_ASSERT_OK) { /* copy back the values to the Java attributes */ diff --git a/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_util.c b/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_util.c index 27006b9da0e..520bd52a2cd 100644 --- a/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_util.c +++ b/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/p11_util.c @@ -95,7 +95,7 @@ void destroyLockObject(JNIEnv *env, jobject jLockObject) { /* * Add the given pkcs11Implementation object to the list of present modules. * Attach the given data to the entry. If the given pkcs11Implementation is - * already in the lsit, just override its old module data with the new one. + * already in the list, just override its old module data with the new one. * None of the arguments can be NULL. If one of the arguments is NULL, this * function does nothing. */ @@ -182,27 +182,48 @@ void removeAllModuleEntries(JNIEnv *env) { /* * function to convert a PKCS#11 return value into a PKCS#11Exception * - * This function generates a PKCS#11Exception with the returnValue as the errorcode - * if the returnValue is not CKR_OK. The functin returns 0, if the returnValue is - * CKR_OK. Otherwise, it returns the returnValue as a jLong. + * This function generates a PKCS#11Exception with the returnValue as the + * errorcode. If the returnValue is not CKR_OK. The function returns 0, if the + * returnValue is CKR_OK. Otherwise, it returns the returnValue as a jLong. * - * @param env - used to call JNI funktions and to get the Exception class + * @param env - used to call JNI functions and to get the Exception class * @param returnValue - of the PKCS#11 function */ -jlong ckAssertReturnValueOK(JNIEnv *env, CK_RV returnValue) -{ +jlong ckAssertReturnValueOK(JNIEnv *env, CK_RV returnValue) { + return ckAssertReturnValueOK2(env, returnValue, NULL); +} + +/* + * function to convert a PKCS#11 return value and additional message into a + * PKCS#11Exception + * + * This function generates a PKCS#11Exception with the returnValue as the + * errorcode. If the returnValue is not CKR_OK. The function returns 0, if the + * returnValue is CKR_OK. Otherwise, it returns the returnValue as a jLong. + * + * @param env - used to call JNI functions and to get the Exception class + * @param returnValue - of the PKCS#11 function + * @param msg - additional message for the generated PKCS11Exception + */ +jlong ckAssertReturnValueOK2(JNIEnv *env, CK_RV returnValue, const char* msg) { jclass jPKCS11ExceptionClass; jmethodID jConstructor; jthrowable jPKCS11Exception; jlong jErrorCode = 0L; + jstring jMsg = NULL; if (returnValue != CKR_OK) { jErrorCode = ckULongToJLong(returnValue); jPKCS11ExceptionClass = (*env)->FindClass(env, CLASS_PKCS11EXCEPTION); if (jPKCS11ExceptionClass != NULL) { - jConstructor = (*env)->GetMethodID(env, jPKCS11ExceptionClass, "", "(J)V"); + jConstructor = (*env)->GetMethodID(env, jPKCS11ExceptionClass, + "", "(JLjava/lang/String;)V"); if (jConstructor != NULL) { - jPKCS11Exception = (jthrowable) (*env)->NewObject(env, jPKCS11ExceptionClass, jConstructor, jErrorCode); + if (msg != NULL) { + jMsg = (*env)->NewStringUTF(env, msg); + } + jPKCS11Exception = (jthrowable) (*env)->NewObject(env, + jPKCS11ExceptionClass, jConstructor, jErrorCode, jMsg); if (jPKCS11Exception != NULL) { (*env)->Throw(env, jPKCS11Exception); } @@ -210,7 +231,7 @@ jlong ckAssertReturnValueOK(JNIEnv *env, CK_RV returnValue) } (*env)->DeleteLocalRef(env, jPKCS11ExceptionClass); } - return jErrorCode ; + return jErrorCode; } @@ -253,7 +274,7 @@ void throwIOException(JNIEnv *env, const char *msg) * This function simply throws a PKCS#11RuntimeException with the given * string as its message. * - * @param env Used to call JNI funktions and to get the Exception class. + * @param env Used to call JNI functions and to get the Exception class. * @param jmessage The message string of the Exception object. */ void throwPKCS11RuntimeException(JNIEnv *env, const char *message) @@ -265,7 +286,7 @@ void throwPKCS11RuntimeException(JNIEnv *env, const char *message) * This function simply throws a PKCS#11RuntimeException. The message says that * the object is not connected to the module. * - * @param env Used to call JNI funktions and to get the Exception class. + * @param env Used to call JNI functions and to get the Exception class. */ void throwDisconnectedRuntimeException(JNIEnv *env) { @@ -486,7 +507,7 @@ CK_MECHANISM_PTR updateGCMParams(JNIEnv *env, CK_MECHANISM_PTR mechPtr) { /* * converts a jbooleanArray to a CK_BBOOL array. The allocated memory has to be freed after use! * - * @param env - used to call JNI funktions to get the array informtaion + * @param env - used to call JNI functions to get the array informtaion * @param jArray - the Java array to convert * @param ckpArray - the reference, where the pointer to the new CK_BBOOL array will be stored * @param ckpLength - the reference, where the array length will be stored @@ -528,7 +549,7 @@ void jBooleanArrayToCKBBoolArray(JNIEnv *env, const jbooleanArray jArray, CK_BBO /* * converts a jbyteArray to a CK_BYTE array. The allocated memory has to be freed after use! * - * @param env - used to call JNI funktions to get the array informtaion + * @param env - used to call JNI functions to get the array informtaion * @param jArray - the Java array to convert * @param ckpArray - the reference, where the pointer to the new CK_BYTE array will be stored * @param ckpLength - the reference, where the array length will be stored @@ -575,7 +596,7 @@ void jByteArrayToCKByteArray(JNIEnv *env, const jbyteArray jArray, CK_BYTE_PTR * /* * converts a jlongArray to a CK_ULONG array. The allocated memory has to be freed after use! * - * @param env - used to call JNI funktions to get the array informtaion + * @param env - used to call JNI functions to get the array informtaion * @param jArray - the Java array to convert * @param ckpArray - the reference, where the pointer to the new CK_ULONG array will be stored * @param ckpLength - the reference, where the array length will be stored @@ -617,7 +638,7 @@ void jLongArrayToCKULongArray(JNIEnv *env, const jlongArray jArray, CK_ULONG_PTR /* * converts a jcharArray to a CK_CHAR array. The allocated memory has to be freed after use! * - * @param env - used to call JNI funktions to get the array informtaion + * @param env - used to call JNI functions to get the array informtaion * @param jArray - the Java array to convert * @param ckpArray - the reference, where the pointer to the new CK_CHAR array will be stored * @param ckpLength - the reference, where the array length will be stored @@ -659,7 +680,7 @@ void jCharArrayToCKCharArray(JNIEnv *env, const jcharArray jArray, CK_CHAR_PTR * /* * converts a jcharArray to a CK_UTF8CHAR array. The allocated memory has to be freed after use! * - * @param env - used to call JNI funktions to get the array informtaion + * @param env - used to call JNI functions to get the array informtaion * @param jArray - the Java array to convert * @param ckpArray - the reference, where the pointer to the new CK_UTF8CHAR array will be stored * @param ckpLength - the reference, where the array length will be stored @@ -701,7 +722,7 @@ void jCharArrayToCKUTF8CharArray(JNIEnv *env, const jcharArray jArray, CK_UTF8CH /* * converts a jstring to a CK_CHAR array. The allocated memory has to be freed after use! * - * @param env - used to call JNI funktions to get the array informtaion + * @param env - used to call JNI functions to get the array informtaion * @param jArray - the Java array to convert * @param ckpArray - the reference, where the pointer to the new CK_CHAR array will be stored * @param ckpLength - the reference, where the array length will be stored @@ -735,7 +756,7 @@ void jStringToCKUTF8CharArray(JNIEnv *env, const jstring jArray, CK_UTF8CHAR_PTR * converts a jobjectArray with Java Attributes to a CK_ATTRIBUTE array. The allocated memory * has to be freed after use! * - * @param env - used to call JNI funktions to get the array informtaion + * @param env - used to call JNI functions to get the array informtaion * @param jArray - the Java Attribute array (template) to convert * @param ckpArray - the reference, where the pointer to the new CK_ATTRIBUTE array will be * stored @@ -781,7 +802,7 @@ void jAttributeArrayToCKAttributeArray(JNIEnv *env, jobjectArray jArray, CK_ATTR /* * converts a CK_BYTE array and its length to a jbyteArray. * - * @param env - used to call JNI funktions to create the new Java array + * @param env - used to call JNI functions to create the new Java array * @param ckpArray - the pointer to the CK_BYTE array to convert * @param ckpLength - the length of the array to convert * @return - the new Java byte array or NULL if error occurred @@ -819,7 +840,7 @@ jbyteArray ckByteArrayToJByteArray(JNIEnv *env, const CK_BYTE_PTR ckpArray, CK_U /* * converts a CK_ULONG array and its length to a jlongArray. * - * @param env - used to call JNI funktions to create the new Java array + * @param env - used to call JNI functions to create the new Java array * @param ckpArray - the pointer to the CK_ULONG array to convert * @param ckpLength - the length of the array to convert * @return - the new Java long array @@ -850,7 +871,7 @@ jlongArray ckULongArrayToJLongArray(JNIEnv *env, const CK_ULONG_PTR ckpArray, CK /* * converts a CK_CHAR array and its length to a jcharArray. * - * @param env - used to call JNI funktions to create the new Java array + * @param env - used to call JNI functions to create the new Java array * @param ckpArray - the pointer to the CK_CHAR array to convert * @param ckpLength - the length of the array to convert * @return - the new Java char array @@ -881,7 +902,7 @@ jcharArray ckCharArrayToJCharArray(JNIEnv *env, const CK_CHAR_PTR ckpArray, CK_U /* * converts a CK_UTF8CHAR array and its length to a jcharArray. * - * @param env - used to call JNI funktions to create the new Java array + * @param env - used to call JNI functions to create the new Java array * @param ckpArray - the pointer to the CK_UTF8CHAR array to convert * @param ckpLength - the length of the array to convert * @return - the new Java char array @@ -930,7 +951,7 @@ jcharArray ckUTF8CharArrayToJCharArray(JNIEnv *env, const CK_UTF8CHAR_PTR ckpArr /* * converts a CK_BBOOL pointer to a Java boolean Object. * - * @param env - used to call JNI funktions to create the new Java object + * @param env - used to call JNI functions to create the new Java object * @param ckpValue - the pointer to the CK_BBOOL value * @return - the new Java boolean object with the boolean value */ @@ -954,7 +975,7 @@ jobject ckBBoolPtrToJBooleanObject(JNIEnv *env, const CK_BBOOL *ckpValue) /* * converts a CK_ULONG pointer to a Java long Object. * - * @param env - used to call JNI funktions to create the new Java object + * @param env - used to call JNI functions to create the new Java object * @param ckpValue - the pointer to the CK_ULONG value * @return - the new Java long object with the long value */ @@ -979,7 +1000,7 @@ jobject ckULongPtrToJLongObject(JNIEnv *env, const CK_ULONG_PTR ckpValue) * converts a Java boolean object into a pointer to a CK_BBOOL value. The memory has to be * freed after use! * - * @param env - used to call JNI funktions to get the value out of the Java object + * @param env - used to call JNI functions to get the value out of the Java object * @param jObject - the "java/lang/Boolean" object to convert * @return - the pointer to the new CK_BBOOL value */ @@ -1009,7 +1030,7 @@ CK_BBOOL* jBooleanObjectToCKBBoolPtr(JNIEnv *env, jobject jObject) * converts a Java byte object into a pointer to a CK_BYTE value. The memory has to be * freed after use! * - * @param env - used to call JNI funktions to get the value out of the Java object + * @param env - used to call JNI functions to get the value out of the Java object * @param jObject - the "java/lang/Byte" object to convert * @return - the pointer to the new CK_BYTE value */ @@ -1038,7 +1059,7 @@ CK_BYTE_PTR jByteObjectToCKBytePtr(JNIEnv *env, jobject jObject) * converts a Java integer object into a pointer to a CK_ULONG value. The memory has to be * freed after use! * - * @param env - used to call JNI funktions to get the value out of the Java object + * @param env - used to call JNI functions to get the value out of the Java object * @param jObject - the "java/lang/Integer" object to convert * @return - the pointer to the new CK_ULONG value */ @@ -1067,7 +1088,7 @@ CK_ULONG* jIntegerObjectToCKULongPtr(JNIEnv *env, jobject jObject) * converts a Java long object into a pointer to a CK_ULONG value. The memory has to be * freed after use! * - * @param env - used to call JNI funktions to get the value out of the Java object + * @param env - used to call JNI functions to get the value out of the Java object * @param jObject - the "java/lang/Long" object to convert * @return - the pointer to the new CK_ULONG value */ @@ -1097,7 +1118,7 @@ CK_ULONG* jLongObjectToCKULongPtr(JNIEnv *env, jobject jObject) * converts a Java char object into a pointer to a CK_CHAR value. The memory has to be * freed after use! * - * @param env - used to call JNI funktions to get the value out of the Java object + * @param env - used to call JNI functions to get the value out of the Java object * @param jObject - the "java/lang/Char" object to convert * @return - the pointer to the new CK_CHAR value */ @@ -1127,7 +1148,7 @@ CK_CHAR_PTR jCharObjectToCKCharPtr(JNIEnv *env, jobject jObject) * converts a Java object into a pointer to CK-type or a CK-structure with the length in Bytes. * The memory of the returned pointer MUST BE FREED BY CALLER! * - * @param env - used to call JNI funktions to get the Java classes and objects + * @param env - used to call JNI functions to get the Java classes and objects * @param jObject - the Java object to convert * @param ckpLength - pointer to the length (bytes) of the newly-allocated CK-value or CK-structure * @return ckpObject - pointer to the newly-allocated CK-value or CK-structure diff --git a/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/pkcs11wrapper.h b/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/pkcs11wrapper.h index 7159fc982a2..eb6d01b9e47 100644 --- a/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/pkcs11wrapper.h +++ b/src/jdk.crypto.cryptoki/share/native/libj2pkcs11/pkcs11wrapper.h @@ -307,6 +307,7 @@ CK_MECHANISM_PTR updateGCMParams(JNIEnv *env, CK_MECHANISM_PTR mechPtr); */ jlong ckAssertReturnValueOK(JNIEnv *env, CK_RV returnValue); +jlong ckAssertReturnValueOK2(JNIEnv *env, CK_RV returnValue, const char *msg); void throwOutOfMemoryError(JNIEnv *env, const char *message); void throwNullPointerException(JNIEnv *env, const char *message); void throwIOException(JNIEnv *env, const char *message);