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

Contents of /trunk/Drivers/ccid/README

Parent Directory Parent Directory | Revision Log Revision Log


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

Properties

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

  ViewVC Help
Powered by ViewVC 1.1.5