Blame SOURCES/coolkey-pcsc-lite-fix.patch

d98f6e
diff -up ./src/coolkey/slot.cpp.reader-state-fix ./src/coolkey/slot.cpp
d98f6e
--- ./src/coolkey/slot.cpp.reader-state-fix	2010-09-08 13:25:14.479109000 -0700
d98f6e
+++ ./src/coolkey/slot.cpp	2010-09-08 13:25:14.506109000 -0700
d98f6e
@@ -2185,6 +2185,7 @@ Slot::readCACCertificateFirst(CKYBuffer 
d98f6e
 {
d98f6e
     CKYStatus status;
d98f6e
     CKYISOStatus apduRC;
d98f6e
+    *nextSize = 0;
d98f6e
 
d98f6e
     if (mOldCAC) {
d98f6e
 	/* get the first 100 bytes of the cert */
d98f6e
diff -up ./src/libckyapplet/cky_card.c.reader-state-fix ./src/libckyapplet/cky_card.c
d98f6e
--- ./src/libckyapplet/cky_card.c.reader-state-fix	2010-09-08 14:05:10.859321000 -0700
d98f6e
+++ ./src/libckyapplet/cky_card.c	2010-09-08 14:05:42.792257000 -0700
d98f6e
@@ -27,7 +27,6 @@
d98f6e
 
d98f6e
 #ifndef WINAPI
d98f6e
 #define WINAPI
d98f6e
-typedef SCARD_READERSTATE *LPSCARD_READERSTATE;
d98f6e
 #endif
d98f6e
 
d98f6e
 #ifndef SCARD_E_NO_READERS_AVAILABLE
d98f6e
diff -up ./src/libckyapplet/cky_card.h.reader-state-fix ./src/libckyapplet/cky_card.h
d98f6e
--- ./src/libckyapplet/cky_card.h.reader-state-fix	2006-06-09 11:44:17.000000000 -0700
d98f6e
+++ ./src/libckyapplet/cky_card.h	2010-09-08 13:25:14.518109000 -0700
d98f6e
@@ -41,23 +41,23 @@ CKYLIST_DECLARE(CKYReaderName, char *)
d98f6e
 CKYLIST_DECLARE(CKYCardConnection, CKYCardConnection *)
d98f6e
 
d98f6e
 CKY_BEGIN_PROTOS
d98f6e
-void CKYReader_Init(SCARD_READERSTATE_A *reader);
d98f6e
-void CKYReader_FreeData(SCARD_READERSTATE_A *reader);
d98f6e
+void CKYReader_Init(SCARD_READERSTATE *reader);
d98f6e
+void CKYReader_FreeData(SCARD_READERSTATE *reader);
d98f6e
 
d98f6e
 /*
d98f6e
- * "Accessors": for SCARD_READERSTATE_A structure as a class.
d98f6e
- * These functions take an SCARD_READERSTATE_A which can also be referenced
d98f6e
+ * "Accessors": for SCARD_READERSTATE structure as a class.
d98f6e
+ * These functions take an SCARD_READERSTATE which can also be referenced
d98f6e
  * directly.
d98f6e
  */
d98f6e
-CKYStatus CKYReader_SetReaderName(SCARD_READERSTATE_A *reader, const char *name);
d98f6e
-const char *CKYReader_GetReaderName(const SCARD_READERSTATE_A *reader);
d98f6e
-CKYStatus CKYReader_SetKnownState(SCARD_READERSTATE_A *reader, 
d98f6e
+CKYStatus CKYReader_SetReaderName(SCARD_READERSTATE *reader, const char *name);
d98f6e
+const char *CKYReader_GetReaderName(const SCARD_READERSTATE *reader);
d98f6e
+CKYStatus CKYReader_SetKnownState(SCARD_READERSTATE *reader, 
d98f6e
 						unsigned long state);
d98f6e
-unsigned long CKYReader_GetKnownState(const SCARD_READERSTATE_A *reader);
d98f6e
-unsigned long CKYReader_GetEventState(const SCARD_READERSTATE_A *reader);
d98f6e
-CKYStatus CKYReader_GetATR(const SCARD_READERSTATE_A *reader, CKYBuffer *buf);
d98f6e
+unsigned long CKYReader_GetKnownState(const SCARD_READERSTATE *reader);
d98f6e
+unsigned long CKYReader_GetEventState(const SCARD_READERSTATE *reader);
d98f6e
+CKYStatus CKYReader_GetATR(const SCARD_READERSTATE *reader, CKYBuffer *buf);
d98f6e
 /* create an array of READERSTATEs from a LIST of Readers */
d98f6e
-SCARD_READERSTATE_A *CKYReader_CreateArray(const CKYReaderNameList readerNames, 
d98f6e
+SCARD_READERSTATE *CKYReader_CreateArray(const CKYReaderNameList readerNames, 
d98f6e
 					  unsigned long *readerCount);
d98f6e
 /* frees the reader, then the full array */
d98f6e
 void CKYReader_DestroyArray(SCARD_READERSTATE *reader, unsigned long count);
d98f6e
@@ -88,7 +88,7 @@ CKYStatus CKYCardContext_FindReadersByAT
d98f6e
 				const CKYBuffer *targetATR);
d98f6e
 /* return if any of the readers in our array has changed in status */
d98f6e
 CKYStatus CKYCardContext_WaitForStatusChange(CKYCardContext *context,
d98f6e
-				SCARD_READERSTATE_A *readers,
d98f6e
+				SCARD_READERSTATE *readers,
d98f6e
 				unsigned long readerCount,
d98f6e
 				unsigned long timeout);
d98f6e
 /* cancel any current operation (such as wait for status change) on this