1 // Copyright © 2015, skdltmxn
2 // Licensed under the MIT License <LICENSE.md>
3 // Smart Card class/port IOCTL codes.
4 pub type UWORD = ::WORD;
5 DEFINE_GUID!(GUID_DEVINTERFACE_SMARTCARD_READER, 0x50DD5230, 0xBA8A, 0x11D1,
6     0xBF, 0x5D, 0x00, 0x00, 0xF8, 0x05, 0xF5, 0x30);
7 pub const SCARD_ATR_LENGTHL: ::DWORD = 33;
8 pub const SCARD_PROTOCOL_UNDEFINED: ::DWORD = 0x00000000;
9 pub const SCARD_PROTOCOL_T0: ::DWORD = 0x00000001;
10 pub const SCARD_PROTOCOL_T1: ::DWORD = 0x00000002;
11 pub const SCARD_PROTOCOL_RAW: ::DWORD = 0x00010000;
12 pub const SCARD_PROTOCOL_Tx: ::DWORD = SCARD_PROTOCOL_T0 | SCARD_PROTOCOL_T1;
13 pub const SCARD_PROTOCOL_DEFAULT: ::DWORD = 0x80000000;
14 pub const SCARD_PROTOCOL_OPTIMAL: ::DWORD = 0x00000000;
15 pub const SCARD_POWER_DOWN: ::DWORD = 0;
16 pub const SCARD_COLD_RESET: ::DWORD = 1;
17 pub const SCARD_WARM_RESET: ::DWORD = 2;
18 pub const IOCTL_SMARTCARD_POWER: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 1, ::METHOD_BUFFERED,
19     ::FILE_ANY_ACCESS);
20 pub const IOCTL_SMARTCARD_GET_ATTRIBUTE: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 2,
21     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
22 pub const IOCTL_SMARTCARD_SET_ATTRIBUTE: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 3,
23     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
24 pub const IOCTL_SMARTCARD_CONFISCATE: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 4,
25     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
26 pub const IOCTL_SMARTCARD_TRANSMIT: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 5,
27     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
28 pub const IOCTL_SMARTCARD_EJECT: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 6, ::METHOD_BUFFERED,
29     ::FILE_ANY_ACCESS);
30 pub const IOCTL_SMARTCARD_SWALLOW: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 7,
31     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
32 pub const IOCTL_SMARTCARD_IS_PRESENT: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 10,
33     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
34 pub const IOCTL_SMARTCARD_IS_ABSENT: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 11,
35     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
36 pub const IOCTL_SMARTCARD_SET_PROTOCOL: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 12,
37     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
38 pub const IOCTL_SMARTCARD_GET_STATE: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 14,
39     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
40 pub const IOCTL_SMARTCARD_GET_LAST_ERROR: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 15,
41     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
42 pub const IOCTL_SMARTCARD_GET_PERF_CNTR: ::DWORD = CTL_CODE!(::FILE_DEVICE_SMARTCARD, 16,
43     ::METHOD_BUFFERED, ::FILE_ANY_ACCESS);
44 pub const MAXIMUM_ATTR_STRING_LENGTH: ::DWORD = 32;
45 pub const MAXIMUM_SMARTCARD_READERS: ::DWORD = 10;
46 pub const SCARD_CLASS_VENDOR_INFO: ::ULONG = 1;
47 pub const SCARD_CLASS_COMMUNICATIONS: ::ULONG = 2;
48 pub const SCARD_CLASS_PROTOCOL: ::ULONG = 3;
49 pub const SCARD_CLASS_POWER_MGMT: ::ULONG = 4;
50 pub const SCARD_CLASS_SECURITY: ::ULONG = 5;
51 pub const SCARD_CLASS_MECHANICAL: ::ULONG = 6;
52 pub const SCARD_CLASS_VENDOR_DEFINED: ::ULONG = 7;
53 pub const SCARD_CLASS_IFD_PROTOCOL: ::ULONG = 8;
54 pub const SCARD_CLASS_ICC_STATE: ::ULONG = 9;
55 pub const SCARD_CLASS_PERF: ::ULONG = 0x7ffe;
56 pub const SCARD_CLASS_SYSTEM: ::ULONG = 0x7fff;
57 pub const SCARD_ATTR_VENDOR_NAME: ::ULONG = SCARD_CLASS_VENDOR_INFO << 16 | 0x0100;
58 pub const SCARD_ATTR_VENDOR_IFD_TYPE: ::ULONG = SCARD_CLASS_VENDOR_INFO << 16 | 0x0101;
59 pub const SCARD_ATTR_VENDOR_IFD_VERSION: ::ULONG = SCARD_CLASS_VENDOR_INFO << 16 | 0x0102;
60 pub const SCARD_ATTR_VENDOR_IFD_SERIAL_NO: ::ULONG = SCARD_CLASS_VENDOR_INFO << 16 | 0x0103;
61 pub const SCARD_ATTR_CHANNEL_ID: ::ULONG = SCARD_CLASS_COMMUNICATIONS << 16 | 0x0110;
62 pub const SCARD_ATTR_PROTOCOL_TYPES: ::ULONG = SCARD_CLASS_PROTOCOL << 16 | 0x0120;
63 pub const SCARD_ATTR_DEFAULT_CLK: ::ULONG = SCARD_CLASS_PROTOCOL << 16 | 0x0121;
64 pub const SCARD_ATTR_MAX_CLK: ::ULONG = SCARD_CLASS_PROTOCOL << 16 | 0x0122;
65 pub const SCARD_ATTR_DEFAULT_DATA_RATE: ::ULONG = SCARD_CLASS_PROTOCOL << 16 | 0x0123;
66 pub const SCARD_ATTR_MAX_DATA_RATE: ::ULONG = SCARD_CLASS_PROTOCOL << 16 | 0x0124;
67 pub const SCARD_ATTR_MAX_IFSD: ::ULONG = SCARD_CLASS_PROTOCOL << 16 | 0x0125;
68 pub const SCARD_ATTR_POWER_MGMT_SUPPORT: ::ULONG = SCARD_CLASS_POWER_MGMT << 16 | 0x0131;
69 pub const SCARD_ATTR_USER_TO_CARD_AUTH_DEVICE: ::ULONG = SCARD_CLASS_SECURITY << 16 | 0x0140;
70 pub const SCARD_ATTR_USER_AUTH_INPUT_DEVICE: ::ULONG = SCARD_CLASS_SECURITY << 16 | 0x0142;
71 pub const SCARD_ATTR_CHARACTERISTICS: ::ULONG = SCARD_CLASS_MECHANICAL << 16 | 0x0150;
72 pub const SCARD_ATTR_CURRENT_PROTOCOL_TYPE: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0201;
73 pub const SCARD_ATTR_CURRENT_CLK: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0202;
74 pub const SCARD_ATTR_CURRENT_F: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0203;
75 pub const SCARD_ATTR_CURRENT_D: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0204;
76 pub const SCARD_ATTR_CURRENT_N: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0205;
77 pub const SCARD_ATTR_CURRENT_W: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0206;
78 pub const SCARD_ATTR_CURRENT_IFSC: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0207;
79 pub const SCARD_ATTR_CURRENT_IFSD: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0208;
80 pub const SCARD_ATTR_CURRENT_BWT: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x0209;
81 pub const SCARD_ATTR_CURRENT_CWT: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x020a;
82 pub const SCARD_ATTR_CURRENT_EBC_ENCODING: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x020b;
83 pub const SCARD_ATTR_EXTENDED_BWT: ::ULONG = SCARD_CLASS_IFD_PROTOCOL << 16 | 0x020c;
84 pub const SCARD_ATTR_ICC_PRESENCE: ::ULONG = SCARD_CLASS_ICC_STATE << 16 | 0x0300;
85 pub const SCARD_ATTR_ICC_INTERFACE_STATUS: ::ULONG = SCARD_CLASS_ICC_STATE << 16 | 0x0301;
86 pub const SCARD_ATTR_CURRENT_IO_STATE: ::ULONG = SCARD_CLASS_ICC_STATE << 16 | 0x0302;
87 pub const SCARD_ATTR_ATR_STRING: ::ULONG = SCARD_CLASS_ICC_STATE << 16 | 0x0303;
88 pub const SCARD_ATTR_ICC_TYPE_PER_ATR: ::ULONG = SCARD_CLASS_ICC_STATE << 16 | 0x0304;
89 pub const SCARD_ATTR_ESC_RESET: ::ULONG = SCARD_CLASS_VENDOR_DEFINED << 16 | 0xA000;
90 pub const SCARD_ATTR_ESC_CANCEL: ::ULONG = SCARD_CLASS_VENDOR_DEFINED << 16 | 0xA003;
91 pub const SCARD_ATTR_ESC_AUTHREQUEST: ::ULONG = SCARD_CLASS_VENDOR_DEFINED << 16 | 0xA005;
92 pub const SCARD_ATTR_MAXINPUT: ::ULONG = SCARD_CLASS_VENDOR_DEFINED << 16 | 0xA007;
93 pub const SCARD_ATTR_DEVICE_UNIT: ::ULONG = SCARD_CLASS_SYSTEM << 16 | 0x0001;
94 pub const SCARD_ATTR_DEVICE_IN_USE: ::ULONG = SCARD_CLASS_SYSTEM << 16 | 0x0002;
95 pub const SCARD_ATTR_DEVICE_FRIENDLY_NAME_A: ::ULONG = SCARD_CLASS_SYSTEM << 16 | 0x0003;
96 pub const SCARD_ATTR_DEVICE_SYSTEM_NAME_A: ::ULONG = SCARD_CLASS_SYSTEM << 16 | 0x0004;
97 pub const SCARD_ATTR_DEVICE_FRIENDLY_NAME_W: ::ULONG = SCARD_CLASS_SYSTEM << 16 | 0x0005;
98 pub const SCARD_ATTR_DEVICE_SYSTEM_NAME_W: ::ULONG = SCARD_CLASS_SYSTEM << 16 | 0x0006;
99 pub const SCARD_ATTR_SUPRESS_T1_IFS_REQUEST: ::ULONG = SCARD_CLASS_SYSTEM << 16 | 0x0007;
100 pub const SCARD_PERF_NUM_TRANSMISSIONS: ::ULONG = SCARD_CLASS_PERF << 16 | 0x0001;
101 pub const SCARD_PERF_BYTES_TRANSMITTED: ::ULONG = SCARD_CLASS_PERF << 16 | 0x0002;
102 pub const SCARD_PERF_TRANSMISSION_TIME: ::ULONG = SCARD_CLASS_PERF << 16 | 0x0003;
103 pub const SCARD_T0_HEADER_LENGTH: ::DWORD = 7;
104 pub const SCARD_T0_CMD_LENGTH: ::DWORD = 5;
105 pub const SCARD_T1_PROLOGUE_LENGTH: ::DWORD = 3;
106 pub const SCARD_T1_EPILOGUE_LENGTH: ::DWORD = 2;
107 pub const SCARD_T1_MAX_IFS: ::DWORD = 254;
108 pub const SCARD_UNKNOWN: ::ULONG = 0;
109 pub const SCARD_ABSENT: ::ULONG = 1;
110 pub const SCARD_PRESENT: ::ULONG = 2;
111 pub const SCARD_SWALLOWED: ::ULONG = 3;
112 pub const SCARD_POWERED: ::ULONG = 4;
113 pub const SCARD_NEGOTIABLE: ::ULONG = 5;
114 pub const SCARD_SPECIFIC: ::ULONG = 6;
115 STRUCT!{struct SCARD_IO_REQUEST {
116     dwProtocol: ::DWORD,
117     cbPciLength: ::DWORD,
118 }}
119 pub type PSCARD_IO_REQUEST = *mut SCARD_IO_REQUEST;
120 pub type LPSCARD_IO_REQUEST = *mut SCARD_IO_REQUEST;
121 pub type LPCSCARD_IO_REQUEST = *const SCARD_IO_REQUEST;
122 STRUCT!{struct SCARD_T0_COMMAND {
123     bCla: ::BYTE,
124     bIns: ::BYTE,
125     bP1: ::BYTE,
126     bP2: ::BYTE,
127     bP3: ::BYTE,
128 }}
129 pub type LPSCARD_T0_COMMAND = *mut SCARD_T0_COMMAND;
130 STRUCT!{struct SCARD_T0_REQUEST {
131     ioRequest: SCARD_IO_REQUEST,
132     bSw1: ::BYTE,
133     bSw2: ::BYTE,
134     CmdBytes: SCARD_T0_COMMAND,
135 }}
136 UNION!(SCARD_T0_REQUEST, CmdBytes, rgbHeader, rgbHeader_mut, [::BYTE; 5]);
137 pub type PSCARD_T0_REQUEST = *mut SCARD_T0_REQUEST;
138 pub type LPSCARD_T0_REQUEST = *mut SCARD_T0_REQUEST;
139 STRUCT!{struct SCARD_T1_REQUEST {
140     ioRequest: SCARD_IO_REQUEST,
141 }}
142 pub type PSCARD_T1_REQUEST = *mut SCARD_T1_REQUEST;
143 pub type LPSCARD_T1_REQUEST = *mut SCARD_T1_REQUEST;
144 pub const SCARD_READER_SWALLOWS: ::ULONG = 0x00000001;
145 pub const SCARD_READER_EJECTS: ::ULONG = 0x00000002;
146 pub const SCARD_READER_CONFISCATES: ::ULONG = 0x00000004;
147 pub const SCARD_READER_TYPE_SERIAL: ::ULONG = 0x01;
148 pub const SCARD_READER_TYPE_PARALELL: ::ULONG = 0x02;
149 pub const SCARD_READER_TYPE_KEYBOARD: ::ULONG = 0x04;
150 pub const SCARD_READER_TYPE_SCSI: ::ULONG = 0x08;
151 pub const SCARD_READER_TYPE_IDE: ::ULONG = 0x10;
152 pub const SCARD_READER_TYPE_USB: ::ULONG = 0x20;
153 pub const SCARD_READER_TYPE_PCMCIA: ::ULONG = 0x40;
154 pub const SCARD_READER_TYPE_TPM: ::ULONG = 0x80;
155 pub const SCARD_READER_TYPE_NFC: ::ULONG = 0x100;
156 pub const SCARD_READER_TYPE_UICC: ::ULONG = 0x200;
157 pub const SCARD_READER_TYPE_VENDOR: ::ULONG = 0xF0;
158