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

Contents of /trunk/Drivers/ccid/README

Parent Directory Parent Directory | Revision Log Revision Log


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

Properties

Name Value
svn:eol-style native
svn:keywords Author Date Id Revision

  ViewVC Help
Powered by ViewVC 1.1.5