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

Contents of /trunk/Drivers/ccid/README

Parent Directory Parent Directory | Revision Log Revision Log


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

Properties

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

  ViewVC Help
Powered by ViewVC 1.1.5