xref: /illumos-gate/usr/src/lib/libpcsc/common/winscard.h (revision 5fbc1fe0da7f34cf8155bf7624c94583cc98e47c)
1 /*
2  * This file and its contents are supplied under the terms of the
3  * Common Development and Distribution License ("CDDL"), version 1.0.
4  * You may only use this file in accordance with the terms of version
5  * 1.0 of the CDDL.
6  *
7  * A full copy of the text of the CDDL should have accompanied this
8  * source.  A copy of the CDDL is also available via the Internet at
9  * http://www.illumos.org/license/CDDL.
10  */
11 
12 /*
13  * Copyright 2019 Joyent, Inc.
14  */
15 
16 #ifndef _WINSCARD_H
17 #define	_WINSCARD_H
18 
19 /*
20  * This library provides a compatibility interface with programs designed
21  * against the PC SmartCard Library. This originates from Microsoft and has been
22  * used on a few different forms over the years by folks. The purpose of this
23  * library is for compatibility.
24  *
25  * At the time of this writing, Microsofts API documentation can be found here:
26  * https://docs.microsoft.com/en-us/windows/win32/api/winscard/
27  *
28  * New consumers should not use this library and instead should leverage
29  * ccid(7D) instead.
30  */
31 
32 #include <stdint.h>
33 #include <wintypes.h>
34 
35 #ifdef __cplusplus
36 extern "C" {
37 #endif
38 
39 /*
40  * This is a departure from the PCSC system which defines this as a LONG,
41  * which is the same size on 32bit and 64bit Windows (ILP32 and LLP64).
42  * We need to use the real native pointer size for the context handle as
43  * it wouldn't fit into a LONG on our LP64 platform.
44  */
45 typedef void *SCARDCONTEXT;
46 typedef void **PSCARDCONTEXT;
47 typedef void **LPSCARDCONTEXT;
48 typedef void *SCARDHANDLE;
49 typedef void **PSCARDHANDLE;
50 typedef void **LPSCARDHANDLE;
51 
52 /*
53  * Conventionally this is supposed to be packed.
54  */
55 #pragma pack(1)
56 typedef struct {
57 	unsigned long dwProtocol;
58 	unsigned long cbPciLength;
59 } SCARD_IO_REQUEST, *PSCARD_IO_REQUEST, *LPSCARD_IO_REQUEST;
60 #pragma pack()
61 
62 extern SCARD_IO_REQUEST g_rgSCardT0Pci, g_rgSCardT1Pci, g_rgSCardRawPci;
63 #define	SCARD_PCI_T0	(&g_rgSCardT0Pci)
64 #define	SCARD_PCI_T1	(&g_rgSCardT1Pci)
65 #define	SCARD_PCI_RAW	(&g_rgSCardRawPci)
66 
67 /*
68  * Return values and error codes. We strive to use the same error codes as
69  * Microsoft.
70  */
71 #define	SCARD_S_SUCCESS			((LONG)0x00000000)
72 #define	SCARD_F_INTERNAL_ERROR		((LONG)0x80100001)
73 #define	SCARD_E_CANCELLED		((LONG)0x80100002)
74 #define	SCARD_E_INVALID_HANDLE		((LONG)0x80100003)
75 #define	SCARD_E_INVALID_PARAMETER	((LONG)0x80100004)
76 #define	SCARD_E_NO_MEMORY		((LONG)0x80100006)
77 #define	SCARD_E_INSUFFICIENT_BUFFER	((LONG)0x80100008)
78 #define	SCARD_E_UNKNOWN_READER		((LONG)0x80100009)
79 #define	SCARD_E_TIMEOUT			((LONG)0x8010000a)
80 #define	SCARD_E_SHARING_VIOLATION	((LONG)0x8010000b)
81 #define	SCARD_E_NO_SMARTCARD		((LONG)0x8010000c)
82 #define	SCARD_E_UNKNOWN_CARD		((LONG)0x8010000d)
83 #define	SCARD_E_PROTO_MISMATCH		((LONG)0x8010000f)
84 #define	SCARD_E_INVALID_VALUE		((LONG)0x80100011)
85 #define	SCARD_F_COMM_ERROR		((LONG)0x80100013)
86 #define	SCARD_F_UNKNOWN_ERROR		((LONG)0x80100014)
87 #define	SCARD_E_READER_UNAVAILABLE	((LONG)0x80100017)
88 #define	SCARD_E_NO_SERVICE		((LONG)0x8010001D)
89 #define	SCARD_E_UNSUPPORTED_FEATURE	((LONG)0x80100022)
90 #define	SCARD_E_NO_READERS_AVAILABLE	((LONG)0x8010002E)
91 #define	SCARD_W_UNSUPPORTED_CARD	((LONG)0x80100065)
92 #define	SCARD_W_UNPOWERED_CARD		((LONG)0x80100067)
93 #define	SCARD_W_RESET_CARD		((LONG)0x80100068)
94 #define	SCARD_W_REMOVED_CARD		((LONG)0x80100069)
95 
96 #define	SCARD_SCOPE_USER		0x0000
97 #define	SCARD_SCOPE_TERMINAL		0x0001
98 #define	SCARD_SCOPE_SYSTEM		0x0002
99 #define	SCARD_SCOPE_GLOBAL		0x0003
100 
101 #define	SCARD_SHARE_EXCLUSIVE	0x0001
102 #define	SCARD_SHARE_SHARED	0x0002
103 #define	SCARD_SHARE_DIRECT	0x0003
104 
105 #define	SCARD_PROTOCOL_T0	0x0001
106 #define	SCARD_PROTOCOL_T1	0x0002
107 #define	SCARD_PROTOCOL_RAW	0x0004
108 #define	SCARD_PROTOCOL_T15	0x0008
109 
110 #define	SCARD_LEAVE_CARD	0x0000
111 #define	SCARD_RESET_CARD	0x0001
112 #define	SCARD_UNPOWER_CARD	0x0002
113 #define	SCARD_EJECT_CARD	0x0003
114 
115 /*
116  * This is used to indicate that the framework should allocate memory.
117  */
118 #define	SCARD_AUTOALLOCATE		UINT32_MAX
119 
120 extern LONG SCardEstablishContext(DWORD, LPCVOID, LPCVOID, LPSCARDCONTEXT);
121 extern LONG SCardReleaseContext(SCARDCONTEXT);
122 
123 extern LONG SCardListReaders(SCARDCONTEXT, LPCSTR, LPSTR, LPDWORD);
124 
125 extern LONG SCardFreeMemory(SCARDCONTEXT, LPCVOID);
126 
127 extern LONG SCardConnect(SCARDCONTEXT, LPCSTR, DWORD, DWORD, LPSCARDHANDLE,
128     LPDWORD);
129 extern LONG SCardDisconnect(SCARDHANDLE, DWORD);
130 
131 extern LONG SCardBeginTransaction(SCARDHANDLE);
132 extern LONG SCardEndTransaction(SCARDHANDLE, DWORD);
133 extern LONG SCardReconnect(SCARDHANDLE, DWORD, DWORD, DWORD, LPDWORD);
134 
135 extern LONG SCardTransmit(SCARDHANDLE, const SCARD_IO_REQUEST *, LPCBYTE,
136     DWORD, SCARD_IO_REQUEST *, LPBYTE, LPDWORD);
137 
138 extern const char *pcsc_stringify_error(const LONG);
139 
140 #ifdef __cplusplus
141 }
142 #endif
143 
144 #endif /* _WINSCARD_H */
145