# HG changeset patch # User valeriep # Date 1209161995 25200 # Node ID df198b4170f79184243811f07339b67ee83c99e0 # Parent e13b7add5742fce4323503a20eb68df822a59347 6524501: inconsistency with PKCS#11 spec - 0-value flags in CK_SLOT_INFO struct returned by C_GetSlotInfo() Reviewed-by: mullan diff -r e13b7add5742 -r df198b4170f7 jdk/src/share/classes/sun/security/pkcs11/SunPKCS11.java --- a/jdk/src/share/classes/sun/security/pkcs11/SunPKCS11.java Wed Apr 23 10:20:34 2008 -0700 +++ b/jdk/src/share/classes/sun/security/pkcs11/SunPKCS11.java Fri Apr 25 15:19:55 2008 -0700 @@ -720,9 +720,13 @@ } private boolean hasValidToken() { + /* Commented out to work with Solaris softtoken impl which + returns 0-value flags, e.g. both REMOVABLE_DEVICE and + TOKEN_PRESENT are false, when it can't access the token. if (removable == false) { return true; } + */ Token token = this.token; return (token != null) && token.isValid(); } @@ -752,7 +756,7 @@ if (slotInfo == null) { slotInfo = p11.C_GetSlotInfo(slotID); } - if ((slotInfo.flags & CKF_TOKEN_PRESENT) == 0) { + if (removable && (slotInfo.flags & CKF_TOKEN_PRESENT) == 0) { createPoller(); return; }