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

Contents of /trunk/Drivers/ccid/README

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3316 - (hide annotations) (download)
Sat Feb 14 08:56:26 2009 UTC (4 years, 3 months ago) by rousseau
File size: 34134 byte(s)
use product name Philips SmartMX instead of commercial name
SafeNet IKey4000.

SafeNet IKey4000 is also used with different device like:
 idVendor:  0x04B9  iManufacturer: SafeNet, Inc.
 idProduct: 0x1206  iProduct: iKey 4000
  Found a CCID/ICCD device
 idVendor: 0x04B9
  iManufacturer: SafeNet, Inc.
 idProduct: 0x1206
  iProduct: iKey 4000
 bcdDevice: 1.10 (firmware release?)
 bLength: 9
 bDescriptorType: 4
 bInterfaceNumber: 0
 bAlternateSetting: 0
 bNumEndpoints: 0
  Control only
 bInterfaceClass: 0xFF
  NOT A CCID DEVICE
  Class is 0xFF (proprietary)
 bInterfaceSubClass: 0
 bInterfaceProtocol: 0
  bulk transfer, optional interrupt-IN (CCID)
 iInterface: 0
USB extra length is too short: 2

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

Properties

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

  ViewVC Help
Powered by ViewVC 1.1.5