/[pcsclite]/trunk/Drivers/ccid/README
ViewVC logotype

Diff of /trunk/Drivers/ccid/README

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 666 by rousseau, Mon Feb 2 10:33:26 2004 UTC revision 2921 by rousseau, Wed Apr 30 12:09:43 2008 UTC
# Line 6  USB CCID IFD Handler Line 6  USB CCID IFD Handler
6  specifications from the USB working group.  specifications from the USB working group.
7    
8    
9  Author:  Authors:
10  =======  ========
11    
12  - Ludovic Rousseau <ludovic.rousseau@free.fr>  - Ludovic Rousseau <ludovic.rousseau@free.fr>
13    - Carlos Prados for the PPS and ATR parsing code (taken from his
14      towitoto driver) in towitoko/ directory.
15    - Olaf Kirch for the T=1 TPDU code (from the OpenCT package) in openct/
16      directory. I (Ludovic Rousseau) greatly improved this code.
17    
18    
19  Supported CCID readers:  Supported CCID readers:
20  =======================  =======================
21    
22  (in alphabetical order)  (in alphabetical order)
23    - ActivCard USB reader 3.0
24    - Advanced Card Systems ACR 38U-CCID [16]
25      old versions of this reader have a bug: the reader do timeout when a
26      special USB frame is sent from the reader. If the frame size if a
27      multiple of wMaxPacketSize the communication is stopped.
28    - Alcor Micro AU9520 [46]
29      Firmware 1.01 is bogus. The time request sent by the card is not
30      forwarded by the reader to the host.
31    - Athena ASE IIIe USB V2 [29]
32    - Athena ASE IIIe KB USB [42]
33    - Blutronics Bludrive II CCID
34    - C3PO LTC31 (new model, USB product id 0x0006) [8]
35    - Cherry XX33 keyboard [?]
36    - Cherry XX44 keyboard (SmartBoard G83-6744) [18]
37    - Cherry SmartTerminal ST2000U [35]
38    - Cherry ST-1044U [27]
39    - Covadis Alya [63]
40    - Dell keyboard SK-3106 [?]
41    - Dell smart card reader keyboard [?]
42    - Eutron Digipass 860 [59]
43    - Eutron SIM Pocket Combo [25]
44    - Eutron CryptoIdentity [26]
45    - Eutron Smart Pocket [58]
46  - Gemplus GemPC 433 SL [2]  - Gemplus GemPC 433 SL [2]
47    - Gemplus GemPC Card [41]
48  - Gemplus GemPC Key [3]  - Gemplus GemPC Key [3]
49    - Gemplus GemPC PinPad
50  - Gemplus GemPC Twin [4]  - Gemplus GemPC Twin [4]
51  - LTC31 from C3PO [8]  - Gemplus GemCore POS Pro
52    - Gemplus GemCore SIM Pro
53    - Kobil KAAN Base [19]
54    - Kobil KAAN Advanced [20]
55    - Kobil KAAN SIM III [21]
56  - OmniKey CardMan 3121 [5]  - OmniKey CardMan 3121 [5]
57    - RSA SecureID SID800 [50]
58  - SCM Micro SCR 331 [6]  - SCM Micro SCR 331 [6]
59      You shall upgrade the firmware [17] using version 5.18 or later.
60    - SCM Micro SCR 331-DI [11]
61      You shall upgrade the firmware [17] using version 6.22 or later.
62  - SCM Micro SCR 335 [7]  - SCM Micro SCR 335 [7]
63      The firmware of this reader can't be upgraded so be sure to buy a
64      recent model with firmware 5.14 or later
65    - SCM Micro SCR 355
66    - SCM Micro SCR 3310 [30]
67    - SCM Micro SCR 3311 [31]
68    - SCM Micro SPR 532 [9]
69      You shall contact Torsten Maykranz <tmaykranz@scmmicro.de> to get a
70      firmware upgrade.
71    - SmartEpad (v 2.0) [32]
72      The firmware gives a very strange description of the reader (like a
73      dwDefaultClock: 1024.000 MHz). So do not expect a perfect behavior.
74    - Verisign Secure Storage Token [24]
75    - Verisign Secure Token [?]
76    - Xiring Teo [52]
77    
78    
79  Should work but untested by me:  Should work but untested by me:
# Line 32  I would like to get these readers to per Line 83  I would like to get these readers to per
83  move them in the supported list above. If you are one of the  move them in the supported list above. If you are one of the
84  manufacturers, please, contact me.  manufacturers, please, contact me.
85    
86  - SCM Micro SCR 331-DI [11]  - Advanced Card Systems ACR122 [62]
87  - SCM Micro SPR 532 [9]  - Axalto Reflex USB v3 [38]
88  - ActivCard USB reader 2.0 [10]  - C3PO LTC32 [13]
89  - Silitek SK-3105 keyboard  - C3PO TLTC2USB
90    - C3PO KBR36
91    - Charismathics token
92    - Cherry SmartBoard, G83-6610 [61]
93    - Covadis Véga [64]
94    - Gemplus GemPC Express
95    - Gemplus Gem e-Seal Pro
96    - Fujitsu Siemens Computers SmartCard USB 2A [53]
97    - Fujitsu Siemens Computers SmartCard Keyboard USB 2A [54]
98    - Giesecke & Devrient StarSign Card Token 350 (ICCD) [57]
99    - Giesecke & Devrient StarSign Card Token 550 (ICCD)
100    - HP USB Smart Card Keyboard [44]
101    - HP USB Smartcard Reader
102    - id3 Semiconductors CL1356D [45] (tested by me but I don't have the
103      reader anymore)
104    - id3 Semiconductors CL1356T [48] (it should be the same firmware as the
105      CL1356D)
106    - Kobil EMV CAP - SecOVID Reader III
107    - Lenovo Integrated Smart Card Reader
108    - Lexar/Gemalto Smart Enterprise Guardian [60]
109    - OmniKey CardMan 1021
110    - OmniKey CardMan 3021 [49]
111    - OmniKey CardMan 3621 [43]
112    - OmniKey CardMan 3821 [37]
113    - OmniKey CardMan 4321 [55]
114    - OmniKey CardMan 5121 [33]
115    - OmniKey CardMan 5125 [51]
116    - OmniKey CardMan 5321 [56]
117    - OmniKey CardMan 6121 [36]
118    - O2Micro Oz776 (0x7762 and 0x7772 versions)
119    - Philips JCOP41V221
120    - SafeNet IKey4000
121    - SCM Micro SCR 331-DI NTTCom [23]
122    - SCM Micro SCR 3310-NTTCOM [28]
123    - SCM Micro SCR 3320 [31b]
124    - SCM Micro SCR 333 [15]
125    - SCM Micro SDI 010 [39]
126    - SCM SCR 3340 ExpressCard54 [34]
127    - SchlumbergerSema Cyberflex Access e-gate ICCD
128    - Silitek SK-3105 keyboard [12] or C3PO TLTC2USB [14]
129    - Sitecom USB simcard reader MD-010
130    - Validy TokenA sl vt
131    - Vasco DP905
132    - Winbond Electronics (for OEM only) [40]
133    
134    
135  Unsupported CCID readers:  Unsupported or partly supported CCID readers:
136  =========================  =============================================
137    
138  None known.  - ActivCard USB reader 2.0 [10]
139        The reader do timeout when a special USB frame is sent from the
140        reader. If the frame size if a multiple of wMaxPacketSize the
141        communication is stopped.
142    - C3PO LTC31 (old model, USB product id 0x0003) [8]
143        The reader works fine with Linux kernel 2.4 but does not with Linux
144        kernel 2.6. The ioctl() syscall returns EINVAL (Invalid argument)
145    - iDream (THRC2002-2) [47]
146        PPS fails with a Cryptoflex card
147        powerup fails with a Setcos card
148        does work with the belgium eID (the reader is sold for this
149        application)
150    - Kobil mIDentity [22]
151        Time requests are not managed correctly and make the firmware fails.
152        This is not a problem unless you use a time-consuming APDU like RSA
153        key generation.
154        A new firmware will correct the bug.
155    - Reiner-SCT cyberJack pinpad(a)
156        Time requests are not managed and the driver may time out without
157        any response from the reader.  This is not a problem unless you use
158        a time-consuming APDU like RSA key generation.
159    
160    
161  Supported operating systems:  Supported operating systems:
# Line 52  Supported operating systems: Line 166  Supported operating systems:
166    to libusb)    to libusb)
167    
168    
169    Debug informations:
170    ===================
171    
172    The driver uses the debug function provided by pcscd. So if pcscd sends
173    its debug to stderr (pcscd --foreground) then the CCID will also send
174    its debug to stderr. If pcscd sends its debug to syslog (by default)
175    then the CCID will also send its debug to syslog.
176    
177    You can change the debug level using the Info.plist configuration file.
178    The Info.plist is installed, by default, in
179    /usr/local/pcsc/drivers/ifd-ccid.bundle/Contents/Info.plist
180    
181    The debug level is set in the ifdLogLevel field. It is a binary OR
182    combinaison of 4 different levels.
183    - 1: critical: important error messages
184    - 2: info:     informative messages like what reader was detected
185    - 4: comm:     a dump of all the bytes exchanged between the host and the
186                   reader
187    - 8: periodic: periodic info when pcscd test if a card is present (every
188                   1/10 of a second)
189    
190    By default the debug level is set to 3 (1 + 2) and correspond to the
191    critical and info levels.
192    
193    You have to restart the driver so it read the configuration file again
194    and use the new debug level value.  To restart the driver you just need
195    to unplug all your CCID readers so the the driver is unloaded and then
196    replug your readers. You can also restart pcscd.
197    
198    
199    Voltage selection
200    =================
201    
202    You can change the voltage level using the Info.plist configuration file.  The
203    Info.plist is installed, by default, in
204    /usr/local/pcsc/drivers/ifd-ccid.bundle/Contents/Info.plist
205    
206    The voltage level is set in the ifdDriverOptions field. It is a binary OR
207    combinaison of 4 different levels.
208    
209    -  0: power on the card at 5V (default value)
210    - 16: power on the card at 3V and then, if 3V fails then use 5V
211    - 32: power on the card at 1.8V, then 3V and then 5V
212    - 48: let the reader decide
213    
214    By default the voltage level is set to 0  and correspond to 5V.
215    
216    You have to restart the driver so it read the configuration file again
217    and use the new debug level value.  To restart the driver you just need
218    to unplug all your CCID readers so the the driver is unloaded and then
219    replug your readers.  You can also restart pcscd.
220    
221    
222  Known problems:  Known problems:
223  ===============  ===============
224    
225  All platforms  MacOSX libusb
226      T=1 and TPDU  """""""""""""
227      """"""""""""      There is a bug in libusb that crash the libusb library when you
228        I do not yet included support of T=1 cards when the reader is in      unplug a reader and replug it in another USB socket.  So if you
229        TPDU mode.      unplug a reader replug it in the same USB socket.
230        If you have a T=1 card I recommand you to use a reader working in  
231        APDU mode. T=1 and TPDU will be supported in a future version of      see http://sourceforge.net/tracker/index.php?func=detail&aid=886778&group_id=1674&atid=101674
       the driver.  
   
     readers enumeration  
     """""""""""""""""""  
       You may have wrong reader identification if you connect two or  
       more reader at the exact same time.  
   
       The daemon pcscd and the CCID driver do not list connected readers  
       in the same order. The driver has no way to know which reader has  
       been detected as a new reader by pcscd.  
   
       So if you plug two readers at the same time (for example if you  
       start pcscd with two readers connected or if you plug a USB hub  
       with two readers on the hub) you may have this (with two readers  
       foo and bar):  
       - pcscd scans the USB bus and finds a new CCID reader foo and  
         calls the driver  
       - the CCID driver scan the USB bus and finds a new different  
         reader bar  
       - pcscd continues scanning the USB bus and finds the second reader  
         bar and calls the driver  
       - the CCID driver scan the USB bus and finds an unused reader foo.  
   
         Now the reader foo will be called bar by pcscd and bar will be  
         called foo. This may not be a problem if the two readers have  
         the same name. But it is strange to insert a card in the  
         physical reader foo and see pcscd detect the card insertion in  
         the reader he calls bar.  
   
         The solution is to use IFDHCreateChannelByName() instead of  
         IFDHCreateChannel() and specify the USB device to use. But pcscd  
         does not implement IFDHCreateChannelByName() yet. Maybe in the  
         future.  
   
         Another solution is to plug readers one after the other and not  
         at the same time.  
   
 *BSD  
     libusb  
     """"""  
       The libusb does not yet support USB interrupt endpoints. You will  
       notice that the driver will stop working as soon as you insert a  
       card in the reader.  
       A new version of libusb should fix this bug.  
232    
233    
234  Licence:  Licence:
235  ========  ========
236    
237    This program is free software; you can redistribute it and/or modify    This library is free software; you can redistribute it and/or modify it
238  it under the terms of the GNU General Public License as published by the  under the terms of the GNU Lesser General Public License as published by
239  Free Software Foundation; either version 2 of the License, or (at your  the Free Software Foundation; either version 2.1 of the License, or (at
240  option) any later version.  your option) any later version.
241    
242    This program is distributed in the hope that it will be useful, but    This library is distributed in the hope that it will be useful, but
243  WITHOUT ANY WARRANTY; without even the implied warranty of  WITHOUT ANY WARRANTY; without even the implied warranty of
244  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser
245  General Public License for more details.  General Public License for more details.
246    
247    You should have received a copy of the GNU General Public License    You should have received a copy of the GNU Lesser General Public License
248  along with this program; if not, write to the Free Software Foundation,  along with this library; if not, write to the Free Software Foundation,
249  Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA  Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA
250    
251    
252  History:  History:
253  ========  ========
254    
255    1.3.5 - 22 February 2008, Ludovic Rousseau
256        - add support for Gemplus Gem e-Seal Pro, Cherry SmartBoard,
257          G83-6610
258        - use usb_interrupt_read() only if libusb > 0.1.12 or
259          --enable-usb-interrupt is used. libusb <= 0.1.12 is bogus and will
260          consume more CPU than needed.
261        - contrib/Kobil_mIDentity_switch/Kobil_mIDentity_switch was broken
262          on Linux since release 1.3.1
263        - some minor bugs removed
264    
265    
266    1.3.4 - 8 February 2008, Ludovic Rousseau
267        - the serial driver could not be loaded because of the missing
268          symbol InterruptRead
269        - remove WAIT_FOR_SYSFS="bInterfaceProtocol" to do not delay udev
270    
271    
272    1.3.3 - 6 February 2008, Ludovic Rousseau
273        - add support for Lexar Smart Enterprise Guardian and Blutronics
274          Bludrive II CCID
275        - add support of TAG_IFD_POLLING_THREAD using IFDHPolling() to
276          detect asynchronous card movements. With this feature pcscd will
277          not poll the reader every 0.4 second for a card movement but will
278          wait until the reader sends a USB interrupt signal
279        - correct a bug with an ICCD-B device and a receive buffer smaller
280          than 4 bytes
281        - remove the sleep in the udev rule. It slows down the detection of
282          any USB device
283        - some minor bugs removed
284    
285    
286    1.3.2 - 22 January 2008, Ludovic Rousseau
287        - add support of Apple Mac OS X Leopard (10.5.1)
288        - solve a hotplug problem on Ubuntu 7.10 (reader was not detected)
289        - create a symlink from libccidtwin.so to libccidtwin.so.VERSION so
290          that the /etc/reader.conf configuration file do not need to edited
291          for each new driver version
292        - make driver for the GemPC Serial compile again
293        - some minor bugs removed
294    
295    
296    1.3.1 - 16 November 2007, Ludovic Rousseau
297        - add support for "Philips Semiconductors JCOP41V221" ICCD card,
298          O2Micro oz776 (ProductID 0x7772), CardMan5321, Giesecke & Devrient
299          StarSign Card Token 350 and 550, SafeNet IKey4000, Eutron
300          CryptoIdentity, Eutron Smart Pocket, Eutron Digipass 860, Lenovo
301          Integrated Smart Card Reader, "Kobil EMV CAP - SecOVID Reader III,
302          Charismathics token, Reiner-SCT cyberJack pinpad(a)
303        - improve support of Mac OS X and *BSD
304        - some minor bugs removed
305    
306    
307    1.3.0 - 10 May 2007, Ludovic Rousseau
308        - add support of ICCD version A and B
309        - add support for (new) KOBIL mIDentity, SchlumbergerSema Cyberflex
310          Access e-gate ICCD, Fujitsu Siemens Computers SmartCard USB 2A and
311          SmartCard Keyboard USB 2A readers, OmniKey CardMan 4321
312        - contrib/RSA_SecurID/RSA_SecurID_getpasswd: tool to get the on time
313          password also displayed on the token screen
314        - contrib/Kobil_mIDentity_switch: tool to activate the CCID reader
315          of the Kobil mIDentity. The tool should be started automatically
316          by the udev rule on Linux
317        - GemPC pinpad: localisation of the string "PIN blocked", add
318          Portuguese(pt), Dutch(nl) and Turkish(tr) localisations
319        - some minor bugs removed
320    
321    1.2.1 - 27 January 2007, Ludovic Rousseau
322        - pcscd_ccid.rules: add non CCID generic (InterfaceClass: 0xFF)
323          readers
324        - INSTALL: document how to use --enable-udev on FreeBSD
325        - move the O2Micro Oz7762 from the unsupported to the supported list
326          since patches to support it are applied by default
327          (O2MICRO_OZ776_PATCH)
328    
329    
330    1.2.0 - 19 January 2007, Ludovic Rousseau
331        - add support for SCARD_ATTR_VENDOR_IFD_VERSION,
332          SCARD_ATTR_VENDOR_NAME and SCARD_ATTR_MAXINPUT tags used by
333          SCardGetAttrib(). Read SCARDGETATTRIB.txt for more documentation
334        - add support for OmniKey CardMan 5125, CardMan 1021, C3PO LTC32,
335          Teo by Xiring, HP USB Smartcard Reader
336        - use --enable-twinserial to build the serial reader driver
337        - use --enable-udev to configure for a use with Linux udev hotplug
338          mechanism. This will allow pcscd to avoid polling the USB bus
339          every 1 second
340        - some minor bugs removed
341    
342    
343    1.1.0 - 11 August 2006, Ludovic Rousseau
344        - support Extended APDU (up to 64KB) for readers in TPDU mode (many
345          readers) or Extended APDU mode (very rare). This only works for
346          T=1 cards.
347        - add support for C3PO LTC31 (new version), OmniKey CardMan 3021, HP
348          USB Smart Card Keyboard, Actividentity (ActiveCard) Activkey Sim,
349          id3 Semiconductors CL1356D and CL1356T, Alcor Micro AU9520
350        - support the contactless interface of the SCR331-DI-NTTCOM
351        - add support of FreeBSD
352        - increase the USB timeout used for PIN verify/modify to not timeout
353          before the reader
354        - the 4-bytes value returned by CM_IOCTL_GET_FEATURE_REQUEST shall
355          be encoded in big endian as documented in PCSC v2 part 10 ch 2.2
356          page 2. The applications using this feature shall be updated (to
357          respect the PCSC specification).
358        - use ./configure --enable-twinserial to compile and install the the
359          driver for the GemPC Twin serial
360        - some minor bugs removed
361    
362    
363    1.0.1 - 22 April 2006, Ludovic Rousseau
364        - add support for Axalto Reflex USB v3, SCM Micro SDI 010, Winbond
365          Electronics W81E381 chipset, Gemplus GemPC Card, Athena ASE IIIe
366          KB USB, OmniKey CardMan 3621
367        - support Solaris (Solaris uses a different libusb)
368        - better documentation for ./configure arguments
369        - improve support of Cherry XX44 keyboard for PIN verify and change
370          (circumvent firmware bugs)
371        - do not use LTPBundleFindValueWithKey() from pcscd since this
372          function has been removed from pcscd API
373        - use -fvisibility=hidden is available to limit the number of
374          exported symbols
375    
376    
377    1.0.0 - 3 March 2006, Ludovic Rousseau
378        - add support for ActivCard USB Reader 3.0, Athena ASE IIIe USB V2,
379          SCM Micro SCR 355, SCR 3311, SCR 3320, SCR 3340 ExpressCard54,
380          Gemplus GemCore SIM Pro, GemCore POS Pro (serial and USB), GemPC
381          Express (ExpressCard/54 interface), SmartEpad (v 2.0), OmniKey
382          CardMan 5121
383        - greatly improve support of PIN PAD readers. We now support TPDU
384          readers with T=1 cards
385        - use l10n strings for the Gemplus GemPC PIN PAD (it has a screen).
386          Supported languages are: de, en, es, fr, it
387        - rename ACS ACR 38 in ACR 38U-CCID since the ACR 38 is a different
388          reader and is not CCID compatible
389        - allow to select the Power On voltage using Info.plist instead of
390          recompiling the source code
391        - correct bugs in the support of multi-slots readers
392        - if the card is faster than the reader (TA1=97 for example) we try
393          to use a not-so-bad speed (corresponding to TA1=96, 95 or 94)
394          instead of the default speed of TA1=11
395        - the src/parse tool do not use the driver anymore. No need to
396          update the Info.plist file first.
397        - some minor bugs removed
398    
399    
400    0.9.4 - 27 November 2005, Ludovic Rousseau
401        - add support for Eutron SIM Pocket Combo, Eutron CryptoIdentity,
402          Verisign Secure Token and VeriSign Secure Storage Token, GemPC
403          Card (PCMCIA), SCM SCR331-DI NTTCom, SCM Micro SCR 3310-NTTCom,
404          Cherry ST-1044U, Cherry SmartTerminal ST-2XXX
405        - add support of PC/SC v2 part 10 CM_IOCTL_GET_FEATURE_REQUEST add
406          support of FEATURE_VERIFY_PIN_DIRECT and FEATURE_MODIFY_PIN_DIRECT
407          remove support of IOCTL_SMARTCARD_VENDOR_VERIFY_PIN (now
408          obsoleted). A sample code is available in examples/scardcontrol.c
409        - we need pcsc-lite 1.2.9-beta9 since some structures used for PIN
410          pad readers are defined by pcsc-lite
411        - some (bogus) cards require an extra EGT but the ATR does not say
412          so. We try to detect the bogus cards and set TC1=2
413        - IFDHSetProtocolParameters(): only use a data rate supported by the
414          reader in the PPS negociation, otherwise we stay at the default
415          speed.
416        - calculate and store the read timeout according to the card ATR
417          instead of using a fixed value of 60 seconds
418        - increase the read timeout if the card sends and WTX request
419        - improve support of GemPC Twin and GemPC Card (serial protocol)
420        - reset the device on close only if DRIVER_OPTION_RESET_ON_CLOSE is
421          set. The problem was that a device reset also disconnects the
422          keyboard on a keyboard + reader device.
423        - use color logs
424        - some minor bugs removed
425    
426    
427    0.9.3 - 14 March 2005, Ludovic Rousseau
428        - change the licence from GNU GPL to GNU Lesser GPL (LGPL)
429        - add support for ACS ACR 38, Kobil KAAN Base, Kobil KAAN Advanced,
430          Kobil KAAN SIM III, Kobil KAAN mIDentity, SCM Micro SCR 331,
431          SCM Micro SCR 331-DI, SCM Micro SCR 335, SCM Micro SCR 3310,
432          SCM Micro SCR 532, Cherry XX44 readers
433        - improve communication speed with readers featuring "Automatic PPS
434          made by the CCID"
435        - switch the Cherry xx33 reader in ISO mode if power up in EMV mode
436          fails.
437        - add support of character level readers. Thanks to O2Micro for the
438          patch
439        - add support for the O2Micro OZ776S reader but the reader firmware
440          is still bogus
441        - check firmware version to avoid firmwares with bugs. You can still
442          use a bogus firmware by setting DRIVER_OPTION_USE_BOGUS_FIRMWARE
443          in Info.plist
444        - some minor bugs removed
445    
446    0.9.2 - 15 August 2004, Ludovic Rousseau
447        - T=1 TPDU code:
448          . the work on T=1 TPDU code was possible thanks to Gemplus
449            validation team who helped me test, debug and bring the code to
450            an EMV validation level. Thanks to Jérôme, Jean-Yves, Xavier and
451            the Gemplus readers department
452          . error code was not checked correctly
453          . avoid a (nearly) infinite loop when resynch are needed.
454          . correctly initialise an internal value to allow more than one
455            reader to work
456        - multi-slots readers
457          . add support for multi-slots readers. The only one I have is a
458            SCM Micro SCR 331-DI with a contact and a contactless interface.
459            The contactless interface may or may not work for you since the
460            reader uses proprietary (undocumented) commands.
461        - GemPC Twin serial reader
462          . perform a command (get the reader firmware) to be sure a GemPC
463            Twin (serial or pcmcia) reader is connected
464          . use a dynamic timeout when reading the serial port.
465            The first timeout used when detecting the reader is 2 seconds to
466            not wait too long if no reader is connected. Later timeouts are
467            set to 1 minute to allow long time APDU.
468        - use `pkg-config libpcsclite --cflags` to locate the pcsc-lite
469          header files
470        - use `pkg-config --print-errors --atleast-version=1.2.9-beta5 libpcsclite`
471          to test the pcsc-lite version
472        - code improvements thanks to the splint tool (http://www.splint.org/)
473    
474    0.9.1 - 1 July 2004, Ludovic Rousseau
475        - I forgot to define IFD_PARITY_ERROR in a .h file
476    
477    0.9.0 - 1 July 2004, Ludovic Rousseau
478        - The T=1 TPDU automata from Carlos Prados' Towitoko driver is very
479          limited and do not support error management mechanisms.
480          I then used the T=1 TPDU automata from OpenCT (OpenSC project).
481          This automata is much more powerful but still lacks a lot of error
482          management code.
483          I then added all the needed code to reach the quality level
484          requested by the EMV standard.
485        - add support for new readers:
486          . Advanced Card Systems ACR 38
487          . Cherry XX33
488          . Dell keyboard SK-3106
489          . Dell smart card reader keyboard
490          . SCR 333
491        - add support of multi procotol cards (T=0 and T=1)
492        - the debug level is now dynamic and set in the Info.plist file (no
493          need to recompile the driver any more)
494        - add support for the libusb naming scheme: usb:%04x/%04x:libusb:%s
495        - INSTALL: add a "configuring the driver for the serial reader
496          (GemPC Twin)" part
497        - use `pkg-config libpcsclite --variable=usbdropdir` so you do not
498          have to use --enable-usbdropdir=DIR or --enable-ccidtwindir=DIR
499          even if pcscd does not use the default /usr/local/pcsc/drivers
500        - add support of IOCTL_SMARTCARD_VENDOR_IFD_EXCHANGE and
501          IOCTL_SMARTCARD_VENDOR_VERIFY_PIN in IFDHControl()
502        - read ifdDriverOptions from Info.plist to limit the use of
503          IOCTL_SMARTCARD_VENDOR_IFD_EXCHANGE (idea from Peter Williams)
504        - provide an example of use of SCardControl()
505          IOCTL_SMARTCARD_VENDOR_IFD_EXCHANGE and
506          IOCTL_SMARTCARD_VENDOR_VERIFY_PIN in example/
507        - add a --enable-pcsclite option (default to yes) so that the driver
508          can be compiled for a different framework (one needing
509          tokenparser.l like Solaris)
510        - Reset action is power off and power on, not just power on
511        - use the include files from pcsc-lite
512        - add a mechanism to allow power on at 1.8V, 3V and then 5V as
513          specified by ISO 7816. We still use 5V for now to avoid problems
514          with non ISO compliant cards
515    
516    0.4.1 - 14 February 2004, Ludovic Rousseau
517        - distribute missing files readers/supported_readers.txt and
518          src/create_Info_plist.pl
519          'make install' failed because of this.
520    
521    0.4.0 - 13 February 2004, Ludovic Rousseau
522        - support of T=1 with TPDU readers. A lot of the T=1 code comes from
523          Carlos Prados towitoko driver.
524          My code is GNU GPL, his code is GNU LGPL so the global driver is
525          GNU GPL
526        - PPS negotiation if the reader does not do it automatically
527        - add support for the Silitek SK-3105 keyboard. It's a USB device
528          with multiple interfaces
529        - use the create_Info_plist.pl script to generate the installed
530          Info.plist from an Info.plist template and a list of supported
531          readers. The Info.plist was too "complex" to maintain by hand
532          since it now contains 11 entries
533        - add support of IFDHCreateChannelByName to avoid wrong reader
534          enumeration. This is not complete if you have multiple _identical_
535          readers. You need to use a > 1.2.0 pcsc-lite version (not yet
536          released at that time)
537        - build but do not install the serial ccidtwin driver by default
538          since it is useless on computers without a serial port or without
539          this reader for example.
540        - read and write timeouts are not symmetric. write timout can be
541          shorter since the reader and card is not supposed to do anything
542          before receiving (write) a command
543        - do not try to find usb.h and other libusb files if
544          --disable-libusb is used. Needed if you only want to build the
545          serial driver.  Thanks to Niki Waibel for the patch
546        - add a --enable-ccidtwindir argument to ./configure to specify the
547          serial GemPC Twin installation directory
548        - debug and code improvements and simplifications
549    
550  0.3.2 - 4 November 2003, Ludovic Rousseau  0.3.2 - 4 November 2003, Ludovic Rousseau
551      - src/commands.c: correct a stupid bug that occurs with an APDU with      - src/commands.c: correct a stupid bug that occurs with an APDU with
552        2 bytes response.        2 bytes response.
# Line 139  History: Line 557  History:
557      - move LTC31 reader from unsupported to supported reader list. It      - move LTC31 reader from unsupported to supported reader list. It
558        was my f ault since in used odd INS byte in my test applet and odd        was my f ault since in used odd INS byte in my test applet and odd
559        INS bytes are forbidden by ISO 7816-4 ch. 5.4.2 Instruction byte.        INS bytes are forbidden by ISO 7816-4 ch. 5.4.2 Instruction byte.
560        Thanks to Josep Moné s Teixidor for pointing the problem.        Thanks to Josep Moné s Teixidor for pointing the problem.
561      - src/commands.c: comment out the automatic GET RESPONSE part. I      - src/commands.c: comment out the automatic GET RESPONSE part. I
562        don't think it should be in the driver. Maybe in pcscd instead?        don't think it should be in the driver. Maybe in pcscd instead?
563    
# Line 150  History: Line 568  History:
568      - add --enable-libusb=PATH option is your libusb is not installed in      - add --enable-libusb=PATH option is your libusb is not installed in
569        /usr or /usr/local        /usr or /usr/local
570      - honor DESTDIR in install rules (closes [ #300110 ]). Thanks to      - honor DESTDIR in install rules (closes [ #300110 ]). Thanks to
571        Ville Skyttä for the patch.        Ville Skyttä for the patch.
572      - src/ccid.c: do not switch the GemPC Key and GemPC Twin in APDU      - src/ccid.c: do not switch the GemPC Key and GemPC Twin in APDU
573        mode since it also swicth in EMV mode and may not work with non        mode since it also swicth in EMV mode and may not work with non
574        EMV cards        EMV cards
# Line 180  History: Line 598  History:
598      - First public release      - First public release
599    
600    
601  Bibliography:  References:
602  =============  ===========
603    
604  [1] http://www.usb.org/developers/devclass_docs/ccid_classspec_1_00a.pdf  [1] http://www.usb.org/developers/devclass_docs/ccid_classspec_1_00a.pdf
605  [2] http://www.gemplus.com/products/gempc433/  [2] http://www.gemplus.com/products/gempc433/
606  [3] http://www.gemplus.com/products/gempckey/  [3] http://www.gemplus.com/products/gempckey/
607  [4] http://www.gemplus.com/products/gempctwin/  [4] http://www.gemplus.com/products/gempctwin/
608  [5] http://www.omnikey.com/en/produkt_details.php3?produkt=1&variante=47  [5] http://www.omnikey.com/?id=products&tx_okprod_pi1[product]=21
609  [6] http://www.scmmicro.com/security/SCR331.html  [6] http://scmmicro.com/security/view_product_en.php?PID=3
610  [7] http://www.scmmicro.com/security/SCR335.html  [7] http://scmmicro.com/security/view_product_en.php?PID=11
611  [8] http://www.c3po.es/pcsc.htm  [8] http://www.c3po.es/ltc31.html
612  [9] http://www.scmmicro.com/security/SPR532.html  [9] http://scmmicro.com/security/view_product_en.php?PID=13
613  [10] http://www.activcard.com/products/usb_reader.html  [10] http://www.activcard.com/products/usb_reader.html
614  [11] http://www.scmmicro.com/security/SCR331-DI.html  [11] http://www.scmmicro.com/security/SCR331-DI.html
615    [12] http://www.silitek.com/prod/getProduct.do?xml_id=4_2&menu_id=4_2_8&cid=1_8_5
616    [13] http://www.c3po.es/ltc32.html
617    [14] http://www.c3po.es/tltc2usb.html
618    [15] http://scmmicro.com/security/view_product_en.php?PID=10
619    [16] http://www.acs.com.hk/Product_Readers.asp?productID=107&PCate=Products_PC_Linked_SmartCard_Readers
620    [17] http://www.scmmicro.com/support/pcs_downloads.php
621    [18] http://www.cherrycorp.com/english/advanced-line/advanced-line_smartboard_g83-6744.htm
622    [19] http://www.kobil.com/e/products/smartcard/kaan-base.php
623    [20] http://www.kobil.com/e/products/smartcard/kaan-advanced.php
624    [21] http://www.kobil.com/d/products/smartcard/kaansim3.php
625    [22] http://www.kobil.com/e/products/index.php?s=midentity
626    [23] http://www.ntt.com/jpki/SCR331DI.html
627    [24] http://www.verisign.co.uk/products-services/security-services/unified-authentication/usb-tokens/
628    [25] http://www.eutron.com/simpocket.asp
629    [26] http://www.cryptoidentity.eutron.com/eng/home.asp
630    [27] http://www.cherry.de/english/advanced-line/advanced_smartterminal_st-1044u.htm
631    [28] http://www.ntt.com/jpki/scr3310.html
632    [29] http://www.asedrive.com/product.asp?pid=1
633    [30] http://scmmicro.com/security/view_product_en.php?PID=4
634    [31] http://scmmicro.com/security/view_product_en.php?PID=5
635    [31b] http://scmmicro.com/security/view_product_en.php?PID=6
636    [32] http://www.smartepad.com.br/
637    [33] http://www.omnikey.com/?id=products&tx_okprod_pi1[product]=37
638    [34] http://scmmicro.com/security/view_product_en.php?PID=7
639    [35] http://www.cherry.de/deutsch/advanced-line/advanced_smart_terminal_st-2000u.htm
640    [36] http://www.omnikey.com/index.php?id=products&tx_okprod_pi1[product]=29
641    [37] http://www.omnikey.com/index.php?id=products&tx_okprod_pi1[product]=33
642    [38] http://www.reflexreaders.com/Products/reflex_usbnew.html
643    [39] http://scmmicro.com/security/view_product_en.php?PID=19
644    [40] http://www.winbond.com.tw/E-WINBONDHTM/partner/b_2_e_4.htm
645    [41] http://www.gemplus.com/products/gempc_card/
646    [42] http://www.asedrive.com/product.asp?pid=2
647    [43] http://www.omnikey.com/?id=products&tx_okprod_pi1[product]=31
648    [44] http://h18000.www1.hp.com/products/quickspecs/12346_na/12346_na.HTML
649    [45] http://www.id3semiconductors.com/produits/cl1356D.htm
650    [46] http://www.alcormicro.com/products_detail.php?main_id=8&p_id=21
651    [47] http://www.tai-hao.com/english/products_detail.php?main_id=4&second_id=13&p_id=53&now_rows=1
652    [48] http://www.id3semiconductors.com/produits/cl1356T.htm
653    [49] http://www.omnikey.com/index.php?id=products&tx_okprod_pi1[product]=48
654    [50] http://www.rsasecurity.com/products/securid/datasheets/SID800_DS_0205.pdf
655    [51] http://www.omnikey.com/?id=products&tx_okprod_pi1[product]=39
656    [52] http://www.teobyxiring.com/
657    [53] http://www.fujitsu-siemens.com/solutions/business_solutions/security/security_products/smartcase_scr_usbex.html
658    [54] http://www.fujitsu-siemens.com/solutions/business_solutions/security/security_products/smartcase_kbpc_cx.html
659    [55] http://omnikey.aaitg.com/?id=products&tx_okprod_pi1[product]=50
660    [56] http://omnikey.aaitg.com/?id=products&tx_okprod_pi1[product]=41
661    [57] http://www.gi-de.com/portal/page?_pageid=42,126834&_dad=portal&_schema=PORTAL
662    [58] http://www.eutronsec.com/infosecurity/Contents/ProductLine/Details.aspx?IDProd=26&IDFamiglia=3
663    [59] http://www.eutronsec.com/infosecurity/Contents/ProductLine/Details.aspx?IDProd=62&IDFamiglia=39
664    [60] http://www.lexar.com/enterprise/ent_ppsd.html
665    [61] http://www.cherry.de/deutsch/produkte/chipkartentastaturen_g-6610.htm
666    [62] http://acs.com.hk/acr122.php
667    [63] http://covadis.ch/Alya.239.0.html
668    [64] http://covadis.ch/Vega.104.0.html
669    
670  $Id$  $Id$
671    

Legend:
Removed from v.666  
changed lines
  Added in v.2921

  ViewVC Help
Powered by ViewVC 1.1.5