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

Contents of /trunk/Drivers/ccid/README

Parent Directory Parent Directory | Revision Log Revision Log


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

Properties

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

  ViewVC Help
Powered by ViewVC 1.1.5