/[pcsclite]/tags/ccid/ccid-1.3.8/README
ViewVC logotype

Contents of /tags/ccid/ccid-1.3.8/README

Parent Directory Parent Directory | Revision Log Revision Log


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

Properties

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

  ViewVC Help
Powered by ViewVC 1.1.5