skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 1 | // Copyright © 2015, skdltmxn |
| 2 | // Licensed under the MIT License <LICENSE.md> |
| 3 | // Smart Card class/port IOCTL codes. |
| 4 | pub type UWORD = ::WORD; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 5 | DEFINE_GUID!(GUID_DEVINTERFACE_SMARTCARD_READER, 0x50DD5230, 0xBA8A, 0x11D1, |
| 6 | 0xBF, 0x5D, 0x00, 0x00, 0xF8, 0x05, 0xF5, 0x30); |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 7 | pub const SCARD_ATR_LENGTHL: ::DWORD = 33; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 15 | pub const SCARD_POWER_DOWN: ::DWORD = 0; |
| 16 | pub const SCARD_COLD_RESET: ::DWORD = 1; |
| 17 | pub const SCARD_WARM_RESET: ::DWORD = 2; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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); |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 44 | pub const MAXIMUM_ATTR_STRING_LENGTH: ::DWORD = 32; |
| 45 | pub const MAXIMUM_SMARTCARD_READERS: ::DWORD = 10; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 103 | pub const SCARD_T0_HEADER_LENGTH: ::DWORD = 7; |
| 104 | pub const SCARD_T0_CMD_LENGTH: ::DWORD = 5; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |
Eh2406 | df60d5f | 2015-10-25 14:22:53 | [diff] [blame] | 115 | STRUCT!{struct SCARD_IO_REQUEST { |
| 116 | dwProtocol: ::DWORD, |
| 117 | cbPciLength: ::DWORD, |
| 118 | }} |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |
Eh2406 | df60d5f | 2015-10-25 14:22:53 | [diff] [blame] | 122 | STRUCT!{struct SCARD_T0_COMMAND { |
| 123 | bCla: ::BYTE, |
| 124 | bIns: ::BYTE, |
| 125 | bP1: ::BYTE, |
| 126 | bP2: ::BYTE, |
| 127 | bP3: ::BYTE, |
| 128 | }} |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 129 | pub type LPSCARD_T0_COMMAND = *mut SCARD_T0_COMMAND; |
Eh2406 | df60d5f | 2015-10-25 14:22:53 | [diff] [blame] | 130 | STRUCT!{struct SCARD_T0_REQUEST { |
| 131 | ioRequest: SCARD_IO_REQUEST, |
| 132 | bSw1: ::BYTE, |
| 133 | bSw2: ::BYTE, |
| 134 | CmdBytes: SCARD_T0_COMMAND, |
| 135 | }} |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |
Eh2406 | df60d5f | 2015-10-25 14:22:53 | [diff] [blame] | 139 | STRUCT!{struct SCARD_T1_REQUEST { |
| 140 | ioRequest: SCARD_IO_REQUEST, |
| 141 | }} |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 142 | pub type PSCARD_T1_REQUEST = *mut SCARD_T1_REQUEST; |
| 143 | pub type LPSCARD_T1_REQUEST = *mut SCARD_T1_REQUEST; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 144 | pub const SCARD_READER_SWALLOWS: ::ULONG = 0x00000001; |
| 145 | pub const SCARD_READER_EJECTS: ::ULONG = 0x00000002; |
| 146 | pub const SCARD_READER_CONFISCATES: ::ULONG = 0x00000004; |
skdltmxn | 82584b4 | 2015-09-11 07:27:55 | [diff] [blame] | 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; |