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