/[pcsclite]/trunk/Drivers/ccid/src/ccid.h
ViewVC logotype

Contents of /trunk/Drivers/ccid/src/ccid.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1106 - (show annotations) (download)
Wed Jul 28 08:33:18 2004 UTC (8 years, 9 months ago) by rousseau
File MIME type: text/plain
File size: 2906 byte(s)
use reader_index instead of lun as reader identification
1 /*
2 ccid.h: CCID structures
3 Copyright (C) 2003 Ludovic Rousseau
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 */
19
20 /*
21 * $Id$
22 */
23
24 typedef struct
25 {
26 /*
27 * CCID Sequence number
28 */
29 unsigned char bSeq;
30
31 /*
32 * VendorID << 16 + ProductID
33 */
34 int readerID;
35
36 /*
37 * Maximum message length
38 */
39 int dwMaxCCIDMessageLength;
40
41 /*
42 * Maximum IFSD
43 */
44 int dwMaxIFSD;
45
46 /*
47 * Features supported by the reader (directly from Class Descriptor)
48 */
49 int dwFeatures;
50
51 /*
52 * default value of dwFeatures
53 * we need this for the SCR331-DI that has two slots with different Features
54 */
55 int defaultFeatures;
56
57 /*
58 * PIN support of the reader (directly from Class Descriptor)
59 */
60 char bPINSupport;
61
62 /*
63 * Default Clock
64 */
65 int dwDefaultClock;
66
67 /*
68 * Max Data Rate
69 */
70 int dwMaxDataRate;
71
72 /*
73 * Number of available slots
74 */
75 char bMaxSlotIndex;
76
77 /*
78 * Slot in use
79 */
80 char bCurrentSlotIndex;
81
82 } _ccid_descriptor;
83
84 /* Features from dwFeatures */
85 #define CCID_CLASS_AUTO_CONF_ATR 0x00000002
86 #define CCID_CLASS_AUTO_VOLTAGE 0x00000008
87 #define CCID_CLASS_AUTO_BAUD 0x00000020
88 #define CCID_CLASS_AUTO_PPS_CUR 0x00000080
89 #define CCID_CLASS_AUTO_IFSD 0x00000400
90 #define CCID_CLASS_TPDU 0x00010000
91 #define CCID_CLASS_SHORT_APDU 0x00020000
92 #define CCID_CLASS_EXTENDED_APDU 0x00040000
93 #define CCID_CLASS_EXCHANGE_MASK 0x00070000
94
95 /* Features from bPINSupport */
96 #define CCID_CLASS_PIN_VERIFY 0x01
97 #define CCID_CLASS_PIN_MODIFY 0x02
98
99 /* See CCID specs ch. 4.2.1 */
100 #define CCID_COMMAND_FAILED 0x40 /* 01 0000 00 */
101 #define CCID_TIME_EXTENSION 0x80 /* 10 0000 00 */
102
103 /* Product identification for special treatments */
104 #define GEMPC433 0x08E64433
105 #define GEMPCKEY 0x08E63438
106 #define GEMPCTWIN 0x08E63437
107 #define CARDMAN3121 0x076B3021
108 #define LTC31 0x07830003
109 #define SCR331DI 0x04E65111
110
111 /* Escape sequence codes */
112 #define ESC_GEMPC_SET_ISO_MODE 1
113 #define ESC_GEMPC_SET_APDU_MODE 2
114
115
116 int ccid_open_hack(unsigned int reader_index);
117 void ccid_error(int error, char *file, int line, char *function);
118 _ccid_descriptor *get_ccid_descriptor(unsigned int reader_index);
119
120 /* convert a 4 byte integer in USB format into an int */
121 #define dw2i(a, x) ((((((a[x+3] << 8) + a[x+2]) << 8) + a[x+1]) << 8) + a[x])
122

Properties

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

  ViewVC Help
Powered by ViewVC 1.1.5