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 8a560a2c48d..661cb816f95 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 @@ -180,14 +180,37 @@ public class PKCS11Exception extends Exception { } }; + public static enum RV_VENDOR { + // NSS + CKR_NSS_CERTDB_FAILED(0xCE534351L), + CKR_NSS_KEYDB_FAILED(0xCE534352L); + + private final long value; + + RV_VENDOR(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); + // for unknown PKCS11 return values, use hex as its string + String res = "0x" + Functions.toFullHexString((int)errorCode); + // for vendor-defined values, check the enum for vendors and include + // potential matches + if ((errorCode & 0x80000000L) != 0) { + for (RV_VENDOR r : RV_VENDOR.values()) { + if (r.value == errorCode) { + res += "(" + r.name() + ")"; + break; + } + } + } + return res; } /**