/[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 467 by rousseau, Tue Sep 23 07:54:56 2003 UTC revision 2924 by rousseau, Wed Apr 30 12:45:12 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    - 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  Unsupported CCID readers:  - SCM Micro SCR 355
66  =========================  - SCM Micro SCR 3310 [30]
67    - SCM Micro SCR 3311 [31]
68  - LTC31 from C3PO [8]  - SCM Micro SPR 532 [9]
69    Communication errors between the card and the reader. Some cards can't    You shall contact Torsten Maykranz <tmaykranz@scmmicro.de> to get a
70    send an ATR.  I have the exact same symptoms with the Windows driver    firmware upgrade.
71    provided by C3PO.  - 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:
80    ===============================
81    
82    I would like to get these readers to perform test and validation and
83    move them in the supported list above. If you are one of the
84    manufacturers, please, contact me.
85    
86    - Advanced Card Systems ACR122 [62]
87    - Axalto Reflex USB v3 [38]
88    - C3PO LTC32 [13]
89    - 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 USB Token [65]
131    - Vasco DP905
132    - Winbond Electronics (for OEM only) [40]
133    
134    
135    Unsupported or partly supported CCID readers:
136    =============================================
137    
138    - 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 41  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.  
   
 MacOS X/Darwin  
     hotplug  
     """""""  
       Due to libusb work in progress the driver may crash on a reader  
       insertion after a few insert/remove actions.  
       So if your reader is always connected you should not have  
       problems.  
       A new version of libusb should fix this bug  
   
 *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.6 - 30 April 2008, Ludovic Rousseau
256        - add support for Covadis Alya, Covadis Véga, Precise Biometrics 250
257          MC, Vasco DP905, Validy TokenA sl vt
258        - better support for the O2Micro OZ776, GemCore SIM Pro
259        - the environment variable LIBCCID_ifdLogLevel overwrite the value
260          of ifdLogLevel read from the Info.plist file
261        - add support for DragonFly BSD
262        - some minor bugs removed
263    
264    
265    1.3.5 - 22 February 2008, Ludovic Rousseau
266        - add support for Gemplus Gem e-Seal Pro, Cherry SmartBoard,
267          G83-6610
268        - use usb_interrupt_read() only if libusb > 0.1.12 or
269          --enable-usb-interrupt is used. libusb <= 0.1.12 is bogus and will
270          consume more CPU than needed.
271        - contrib/Kobil_mIDentity_switch/Kobil_mIDentity_switch was broken
272          on Linux since release 1.3.1
273        - some minor bugs removed
274    
275    
276    1.3.4 - 8 February 2008, Ludovic Rousseau
277        - the serial driver could not be loaded because of the missing
278          symbol InterruptRead
279        - remove WAIT_FOR_SYSFS="bInterfaceProtocol" to do not delay udev
280    
281    
282    1.3.3 - 6 February 2008, Ludovic Rousseau
283        - add support for Lexar Smart Enterprise Guardian and Blutronics
284          Bludrive II CCID
285        - add support of TAG_IFD_POLLING_THREAD using IFDHPolling() to
286          detect asynchronous card movements. With this feature pcscd will
287          not poll the reader every 0.4 second for a card movement but will
288          wait until the reader sends a USB interrupt signal
289        - correct a bug with an ICCD-B device and a receive buffer smaller
290          than 4 bytes
291        - remove the sleep in the udev rule. It slows down the detection of
292          any USB device
293        - some minor bugs removed
294    
295    
296    1.3.2 - 22 January 2008, Ludovic Rousseau
297        - add support of Apple Mac OS X Leopard (10.5.1)
298        - solve a hotplug problem on Ubuntu 7.10 (reader was not detected)
299        - create a symlink from libccidtwin.so to libccidtwin.so.VERSION so
300          that the /etc/reader.conf configuration file do not need to edited
301          for each new driver version
302        - make driver for the GemPC Serial compile again
303        - some minor bugs removed
304    
305    
306    1.3.1 - 16 November 2007, Ludovic Rousseau
307        - add support for "Philips Semiconductors JCOP41V221" ICCD card,
308          O2Micro oz776 (ProductID 0x7772), CardMan5321, Giesecke & Devrient
309          StarSign Card Token 350 and 550, SafeNet IKey4000, Eutron
310          CryptoIdentity, Eutron Smart Pocket, Eutron Digipass 860, Lenovo
311          Integrated Smart Card Reader, "Kobil EMV CAP - SecOVID Reader III,
312          Charismathics token, Reiner-SCT cyberJack pinpad(a)
313        - improve support of Mac OS X and *BSD
314        - some minor bugs removed
315    
316    
317    1.3.0 - 10 May 2007, Ludovic Rousseau
318        - add support of ICCD version A and B
319        - add support for (new) KOBIL mIDentity, SchlumbergerSema Cyberflex
320          Access e-gate ICCD, Fujitsu Siemens Computers SmartCard USB 2A and
321          SmartCard Keyboard USB 2A readers, OmniKey CardMan 4321
322        - contrib/RSA_SecurID/RSA_SecurID_getpasswd: tool to get the on time
323          password also displayed on the token screen
324        - contrib/Kobil_mIDentity_switch: tool to activate the CCID reader
325          of the Kobil mIDentity. The tool should be started automatically
326          by the udev rule on Linux
327        - GemPC pinpad: localisation of the string "PIN blocked", add
328          Portuguese(pt), Dutch(nl) and Turkish(tr) localisations
329        - some minor bugs removed
330    
331    1.2.1 - 27 January 2007, Ludovic Rousseau
332        - pcscd_ccid.rules: add non CCID generic (InterfaceClass: 0xFF)
333          readers
334        - INSTALL: document how to use --enable-udev on FreeBSD
335        - move the O2Micro Oz7762 from the unsupported to the supported list
336          since patches to support it are applied by default
337          (O2MICRO_OZ776_PATCH)
338    
339    
340    1.2.0 - 19 January 2007, Ludovic Rousseau
341        - add support for SCARD_ATTR_VENDOR_IFD_VERSION,
342          SCARD_ATTR_VENDOR_NAME and SCARD_ATTR_MAXINPUT tags used by
343          SCardGetAttrib(). Read SCARDGETATTRIB.txt for more documentation
344        - add support for OmniKey CardMan 5125, CardMan 1021, C3PO LTC32,
345          Teo by Xiring, HP USB Smartcard Reader
346        - use --enable-twinserial to build the serial reader driver
347        - use --enable-udev to configure for a use with Linux udev hotplug
348          mechanism. This will allow pcscd to avoid polling the USB bus
349          every 1 second
350        - some minor bugs removed
351    
352    
353    1.1.0 - 11 August 2006, Ludovic Rousseau
354        - support Extended APDU (up to 64KB) for readers in TPDU mode (many
355          readers) or Extended APDU mode (very rare). This only works for
356          T=1 cards.
357        - add support for C3PO LTC31 (new version), OmniKey CardMan 3021, HP
358          USB Smart Card Keyboard, Actividentity (ActiveCard) Activkey Sim,
359          id3 Semiconductors CL1356D and CL1356T, Alcor Micro AU9520
360        - support the contactless interface of the SCR331-DI-NTTCOM
361        - add support of FreeBSD
362        - increase the USB timeout used for PIN verify/modify to not timeout
363          before the reader
364        - the 4-bytes value returned by CM_IOCTL_GET_FEATURE_REQUEST shall
365          be encoded in big endian as documented in PCSC v2 part 10 ch 2.2
366          page 2. The applications using this feature shall be updated (to
367          respect the PCSC specification).
368        - use ./configure --enable-twinserial to compile and install the the
369          driver for the GemPC Twin serial
370        - some minor bugs removed
371    
372    
373    1.0.1 - 22 April 2006, Ludovic Rousseau
374        - add support for Axalto Reflex USB v3, SCM Micro SDI 010, Winbond
375          Electronics W81E381 chipset, Gemplus GemPC Card, Athena ASE IIIe
376          KB USB, OmniKey CardMan 3621
377        - support Solaris (Solaris uses a different libusb)
378        - better documentation for ./configure arguments
379        - improve support of Cherry XX44 keyboard for PIN verify and change
380          (circumvent firmware bugs)
381        - do not use LTPBundleFindValueWithKey() from pcscd since this
382          function has been removed from pcscd API
383        - use -fvisibility=hidden is available to limit the number of
384          exported symbols
385    
386    
387    1.0.0 - 3 March 2006, Ludovic Rousseau
388        - add support for ActivCard USB Reader 3.0, Athena ASE IIIe USB V2,
389          SCM Micro SCR 355, SCR 3311, SCR 3320, SCR 3340 ExpressCard54,
390          Gemplus GemCore SIM Pro, GemCore POS Pro (serial and USB), GemPC
391          Express (ExpressCard/54 interface), SmartEpad (v 2.0), OmniKey
392          CardMan 5121
393        - greatly improve support of PIN PAD readers. We now support TPDU
394          readers with T=1 cards
395        - use l10n strings for the Gemplus GemPC PIN PAD (it has a screen).
396          Supported languages are: de, en, es, fr, it
397        - rename ACS ACR 38 in ACR 38U-CCID since the ACR 38 is a different
398          reader and is not CCID compatible
399        - allow to select the Power On voltage using Info.plist instead of
400          recompiling the source code
401        - correct bugs in the support of multi-slots readers
402        - if the card is faster than the reader (TA1=97 for example) we try
403          to use a not-so-bad speed (corresponding to TA1=96, 95 or 94)
404          instead of the default speed of TA1=11
405        - the src/parse tool do not use the driver anymore. No need to
406          update the Info.plist file first.
407        - some minor bugs removed
408    
409    
410    0.9.4 - 27 November 2005, Ludovic Rousseau
411        - add support for Eutron SIM Pocket Combo, Eutron CryptoIdentity,
412          Verisign Secure Token and VeriSign Secure Storage Token, GemPC
413          Card (PCMCIA), SCM SCR331-DI NTTCom, SCM Micro SCR 3310-NTTCom,
414          Cherry ST-1044U, Cherry SmartTerminal ST-2XXX
415        - add support of PC/SC v2 part 10 CM_IOCTL_GET_FEATURE_REQUEST add
416          support of FEATURE_VERIFY_PIN_DIRECT and FEATURE_MODIFY_PIN_DIRECT
417          remove support of IOCTL_SMARTCARD_VENDOR_VERIFY_PIN (now
418          obsoleted). A sample code is available in examples/scardcontrol.c
419        - we need pcsc-lite 1.2.9-beta9 since some structures used for PIN
420          pad readers are defined by pcsc-lite
421        - some (bogus) cards require an extra EGT but the ATR does not say
422          so. We try to detect the bogus cards and set TC1=2
423        - IFDHSetProtocolParameters(): only use a data rate supported by the
424          reader in the PPS negociation, otherwise we stay at the default
425          speed.
426        - calculate and store the read timeout according to the card ATR
427          instead of using a fixed value of 60 seconds
428        - increase the read timeout if the card sends and WTX request
429        - improve support of GemPC Twin and GemPC Card (serial protocol)
430        - reset the device on close only if DRIVER_OPTION_RESET_ON_CLOSE is
431          set. The problem was that a device reset also disconnects the
432          keyboard on a keyboard + reader device.
433        - use color logs
434        - some minor bugs removed
435    
436    
437    0.9.3 - 14 March 2005, Ludovic Rousseau
438        - change the licence from GNU GPL to GNU Lesser GPL (LGPL)
439        - add support for ACS ACR 38, Kobil KAAN Base, Kobil KAAN Advanced,
440          Kobil KAAN SIM III, Kobil KAAN mIDentity, SCM Micro SCR 331,
441          SCM Micro SCR 331-DI, SCM Micro SCR 335, SCM Micro SCR 3310,
442          SCM Micro SCR 532, Cherry XX44 readers
443        - improve communication speed with readers featuring "Automatic PPS
444          made by the CCID"
445        - switch the Cherry xx33 reader in ISO mode if power up in EMV mode
446          fails.
447        - add support of character level readers. Thanks to O2Micro for the
448          patch
449        - add support for the O2Micro OZ776S reader but the reader firmware
450          is still bogus
451        - check firmware version to avoid firmwares with bugs. You can still
452          use a bogus firmware by setting DRIVER_OPTION_USE_BOGUS_FIRMWARE
453          in Info.plist
454        - some minor bugs removed
455    
456    0.9.2 - 15 August 2004, Ludovic Rousseau
457        - T=1 TPDU code:
458          . the work on T=1 TPDU code was possible thanks to Gemplus
459            validation team who helped me test, debug and bring the code to
460            an EMV validation level. Thanks to Jérôme, Jean-Yves, Xavier and
461            the Gemplus readers department
462          . error code was not checked correctly
463          . avoid a (nearly) infinite loop when resynch are needed.
464          . correctly initialise an internal value to allow more than one
465            reader to work
466        - multi-slots readers
467          . add support for multi-slots readers. The only one I have is a
468            SCM Micro SCR 331-DI with a contact and a contactless interface.
469            The contactless interface may or may not work for you since the
470            reader uses proprietary (undocumented) commands.
471        - GemPC Twin serial reader
472          . perform a command (get the reader firmware) to be sure a GemPC
473            Twin (serial or pcmcia) reader is connected
474          . use a dynamic timeout when reading the serial port.
475            The first timeout used when detecting the reader is 2 seconds to
476            not wait too long if no reader is connected. Later timeouts are
477            set to 1 minute to allow long time APDU.
478        - use `pkg-config libpcsclite --cflags` to locate the pcsc-lite
479          header files
480        - use `pkg-config --print-errors --atleast-version=1.2.9-beta5 libpcsclite`
481          to test the pcsc-lite version
482        - code improvements thanks to the splint tool (http://www.splint.org/)
483    
484    0.9.1 - 1 July 2004, Ludovic Rousseau
485        - I forgot to define IFD_PARITY_ERROR in a .h file
486    
487    0.9.0 - 1 July 2004, Ludovic Rousseau
488        - The T=1 TPDU automata from Carlos Prados' Towitoko driver is very
489          limited and do not support error management mechanisms.
490          I then used the T=1 TPDU automata from OpenCT (OpenSC project).
491          This automata is much more powerful but still lacks a lot of error
492          management code.
493          I then added all the needed code to reach the quality level
494          requested by the EMV standard.
495        - add support for new readers:
496          . Advanced Card Systems ACR 38
497          . Cherry XX33
498          . Dell keyboard SK-3106
499          . Dell smart card reader keyboard
500          . SCR 333
501        - add support of multi procotol cards (T=0 and T=1)
502        - the debug level is now dynamic and set in the Info.plist file (no
503          need to recompile the driver any more)
504        - add support for the libusb naming scheme: usb:%04x/%04x:libusb:%s
505        - INSTALL: add a "configuring the driver for the serial reader
506          (GemPC Twin)" part
507        - use `pkg-config libpcsclite --variable=usbdropdir` so you do not
508          have to use --enable-usbdropdir=DIR or --enable-ccidtwindir=DIR
509          even if pcscd does not use the default /usr/local/pcsc/drivers
510        - add support of IOCTL_SMARTCARD_VENDOR_IFD_EXCHANGE and
511          IOCTL_SMARTCARD_VENDOR_VERIFY_PIN in IFDHControl()
512        - read ifdDriverOptions from Info.plist to limit the use of
513          IOCTL_SMARTCARD_VENDOR_IFD_EXCHANGE (idea from Peter Williams)
514        - provide an example of use of SCardControl()
515          IOCTL_SMARTCARD_VENDOR_IFD_EXCHANGE and
516          IOCTL_SMARTCARD_VENDOR_VERIFY_PIN in example/
517        - add a --enable-pcsclite option (default to yes) so that the driver
518          can be compiled for a different framework (one needing
519          tokenparser.l like Solaris)
520        - Reset action is power off and power on, not just power on
521        - use the include files from pcsc-lite
522        - add a mechanism to allow power on at 1.8V, 3V and then 5V as
523          specified by ISO 7816. We still use 5V for now to avoid problems
524          with non ISO compliant cards
525    
526    0.4.1 - 14 February 2004, Ludovic Rousseau
527        - distribute missing files readers/supported_readers.txt and
528          src/create_Info_plist.pl
529          'make install' failed because of this.
530    
531    0.4.0 - 13 February 2004, Ludovic Rousseau
532        - support of T=1 with TPDU readers. A lot of the T=1 code comes from
533          Carlos Prados towitoko driver.
534          My code is GNU GPL, his code is GNU LGPL so the global driver is
535          GNU GPL
536        - PPS negotiation if the reader does not do it automatically
537        - add support for the Silitek SK-3105 keyboard. It's a USB device
538          with multiple interfaces
539        - use the create_Info_plist.pl script to generate the installed
540          Info.plist from an Info.plist template and a list of supported
541          readers. The Info.plist was too "complex" to maintain by hand
542          since it now contains 11 entries
543        - add support of IFDHCreateChannelByName to avoid wrong reader
544          enumeration. This is not complete if you have multiple _identical_
545          readers. You need to use a > 1.2.0 pcsc-lite version (not yet
546          released at that time)
547        - build but do not install the serial ccidtwin driver by default
548          since it is useless on computers without a serial port or without
549          this reader for example.
550        - read and write timeouts are not symmetric. write timout can be
551          shorter since the reader and card is not supposed to do anything
552          before receiving (write) a command
553        - do not try to find usb.h and other libusb files if
554          --disable-libusb is used. Needed if you only want to build the
555          serial driver.  Thanks to Niki Waibel for the patch
556        - add a --enable-ccidtwindir argument to ./configure to specify the
557          serial GemPC Twin installation directory
558        - debug and code improvements and simplifications
559    
560    0.3.2 - 4 November 2003, Ludovic Rousseau
561        - src/commands.c: correct a stupid bug that occurs with an APDU with
562          2 bytes response.
563        - Info.plist: add SPR 532 in list of supported readers
564        - parse.c: do not exit if the InterfaceClass is 0xFF (proprietary).
565          It is the case with old readers manufactured before the final
566          release of the CCID specs.
567        - move LTC31 reader from unsupported to supported reader list. It
568          was my f ault since in used odd INS byte in my test applet and odd
569          INS bytes are forbidden by ISO 7816-4 ch. 5.4.2 Instruction byte.
570          Thanks to Josep Moné s Teixidor for pointing the problem.
571        - src/commands.c: comment out the automatic GET RESPONSE part. I
572          don't think it should be in the driver. Maybe in pcscd instead?
573    
574  0.3.1 - 23 September 2003, Ludovic Rouseau  0.3.1 - 23 September 2003, Ludovic Rouseau
575      - add --enable-multi-thread (enabled by default) for thread safe      - add --enable-multi-thread (enabled by default) for thread safe
576        support an APDU multiplexing. You will need pcsc-lite-1.2.0-rc3 or        support an APDU multiplexing. You will need pcsc-lite-1.2.0-rc3 or
# Line 134  History: Line 578  History:
578      - add --enable-libusb=PATH option is your libusb is not installed in      - add --enable-libusb=PATH option is your libusb is not installed in
579        /usr or /usr/local        /usr or /usr/local
580      - honor DESTDIR in install rules (closes [ #300110 ]). Thanks to      - honor DESTDIR in install rules (closes [ #300110 ]). Thanks to
581        Ville Skyttä for the patch.        Ville Skyttä for the patch.
582      - 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
583        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
584        EMV cards        EMV cards
# Line 164  History: Line 608  History:
608      - First public release      - First public release
609    
610    
611  Bibliography:  References:
612  =============  ===========
613    
614  [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
615  [2] http://www.gemplus.com/products/gempc433/  [2] http://www.gemplus.com/products/gempc433/
616  [3] http://www.gemplus.com/products/gempckey/  [3] http://www.gemplus.com/products/gempckey/
617  [4] http://www.gemplus.com/products/gempctwin/  [4] http://www.gemplus.com/products/gempctwin/
618  [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
619  [6] http://www.scmmicro.com/security/SCR331.html  [6] http://scmmicro.com/security/view_product_en.php?PID=3
620  [7] http://www.scmmicro.com/security/SCR335.html  [7] http://scmmicro.com/security/view_product_en.php?PID=11
621  [8] http://www.c3po.es/pcsc.htm  [8] http://www.c3po.es/ltc31.html
622    [9] http://scmmicro.com/security/view_product_en.php?PID=13
623    [10] http://www.activcard.com/products/usb_reader.html
624    [11] http://www.scmmicro.com/security/SCR331-DI.html
625    [12] http://www.silitek.com/prod/getProduct.do?xml_id=4_2&menu_id=4_2_8&cid=1_8_5
626    [13] http://www.c3po.es/ltc32.html
627    [14] http://www.c3po.es/tltc2usb.html
628    [15] http://scmmicro.com/security/view_product_en.php?PID=10
629    [16] http://www.acs.com.hk/Product_Readers.asp?productID=107&PCate=Products_PC_Linked_SmartCard_Readers
630    [17] http://www.scmmicro.com/support/pcs_downloads.php
631    [18] http://www.cherrycorp.com/english/advanced-line/advanced-line_smartboard_g83-6744.htm
632    [19] http://www.kobil.com/e/products/smartcard/kaan-base.php
633    [20] http://www.kobil.com/e/products/smartcard/kaan-advanced.php
634    [21] http://www.kobil.com/d/products/smartcard/kaansim3.php
635    [22] http://www.kobil.com/e/products/index.php?s=midentity
636    [23] http://www.ntt.com/jpki/SCR331DI.html
637    [24] http://www.verisign.co.uk/products-services/security-services/unified-authentication/usb-tokens/
638    [25] http://www.eutron.com/simpocket.asp
639    [26] http://www.cryptoidentity.eutron.com/eng/home.asp
640    [27] http://www.cherry.de/english/advanced-line/advanced_smartterminal_st-1044u.htm
641    [28] http://www.ntt.com/jpki/scr3310.html
642    [29] http://www.asedrive.com/product.asp?pid=1
643    [30] http://scmmicro.com/security/view_product_en.php?PID=4
644    [31] http://scmmicro.com/security/view_product_en.php?PID=5
645    [31b] http://scmmicro.com/security/view_product_en.php?PID=6
646    [32] http://www.smartepad.com.br/
647    [33] http://www.omnikey.com/?id=products&tx_okprod_pi1[product]=37
648    [34] http://scmmicro.com/security/view_product_en.php?PID=7
649    [35] http://www.cherry.de/deutsch/advanced-line/advanced_smart_terminal_st-2000u.htm
650    [36] http://www.omnikey.com/index.php?id=products&tx_okprod_pi1[product]=29
651    [37] http://www.omnikey.com/index.php?id=products&tx_okprod_pi1[product]=33
652    [38] http://www.reflexreaders.com/Products/reflex_usbnew.html
653    [39] http://scmmicro.com/security/view_product_en.php?PID=19
654    [40] http://www.winbond.com.tw/E-WINBONDHTM/partner/b_2_e_4.htm
655    [41] http://www.gemplus.com/products/gempc_card/
656    [42] http://www.asedrive.com/product.asp?pid=2
657    [43] http://www.omnikey.com/?id=products&tx_okprod_pi1[product]=31
658    [44] http://h18000.www1.hp.com/products/quickspecs/12346_na/12346_na.HTML
659    [45] http://www.id3semiconductors.com/produits/cl1356D.htm
660    [46] http://www.alcormicro.com/products_detail.php?main_id=8&p_id=21
661    [47] http://www.tai-hao.com/english/products_detail.php?main_id=4&second_id=13&p_id=53&now_rows=1
662    [48] http://www.id3semiconductors.com/produits/cl1356T.htm
663    [49] http://www.omnikey.com/index.php?id=products&tx_okprod_pi1[product]=48
664    [50] http://www.rsasecurity.com/products/securid/datasheets/SID800_DS_0205.pdf
665    [51] http://www.omnikey.com/?id=products&tx_okprod_pi1[product]=39
666    [52] http://www.teobyxiring.com/
667    [53] http://www.fujitsu-siemens.com/solutions/business_solutions/security/security_products/smartcase_scr_usbex.html
668    [54] http://www.fujitsu-siemens.com/solutions/business_solutions/security/security_products/smartcase_kbpc_cx.html
669    [55] http://omnikey.aaitg.com/?id=products&tx_okprod_pi1[product]=50
670    [56] http://omnikey.aaitg.com/?id=products&tx_okprod_pi1[product]=41
671    [57] http://www.gi-de.com/portal/page?_pageid=42,126834&_dad=portal&_schema=PORTAL
672    [58] http://www.eutronsec.com/infosecurity/Contents/ProductLine/Details.aspx?IDProd=26&IDFamiglia=3
673    [59] http://www.eutronsec.com/infosecurity/Contents/ProductLine/Details.aspx?IDProd=62&IDFamiglia=39
674    [60] http://www.lexar.com/enterprise/ent_ppsd.html
675    [61] http://www.cherry.de/deutsch/produkte/chipkartentastaturen_g-6610.htm
676    [62] http://acs.com.hk/acr122.php
677    [63] http://covadis.ch/Alya.239.0.html
678    [64] http://covadis.ch/Vega.104.0.html
679    [65] http://www.validy.com/en/products/token/
680    
681  $Id$  $Id$
682    

Legend:
Removed from v.467  
changed lines
  Added in v.2924

  ViewVC Help
Powered by ViewVC 1.1.5