2 * Copyright (C) 2007 Francois Gouget
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 #ifndef __WINE_BCRYPT_H
20 #define __WINE_BCRYPT_H
23 #define WINAPI __stdcall
38 #ifndef WINE_NTSTATUS_DECLARED
39 #define WINE_NTSTATUS_DECLARED
40 typedef LONG NTSTATUS
;
43 #if defined(_MSC_VER) || defined(__MINGW32__)
44 #define BCRYPT_ALGORITHM_NAME L"AlgorithmName"
45 #define BCRYPT_AUTH_TAG_LENGTH L"AuthTagLength"
46 #define BCRYPT_BLOCK_LENGTH L"BlockLength"
47 #define BCRYPT_BLOCK_SIZE_LIST L"BlockSizeList"
48 #define BCRYPT_CHAINING_MODE L"ChainingMode"
49 #define BCRYPT_EFFECTIVE_KEY_LENGTH L"EffectiveKeyLength"
50 #define BCRYPT_HASH_BLOCK_LENGTH L"HashBlockLength"
51 #define BCRYPT_HASH_LENGTH L"HashDigestLength"
52 #define BCRYPT_HASH_OID_LIST L"HashOIDList"
53 #define BCRYPT_KEY_LENGTH L"KeyLength"
54 #define BCRYPT_KEY_LENGTHS L"KeyLengths"
55 #define BCRYPT_KEY_OBJECT_LENGTH L"KeyObjectLength"
56 #define BCRYPT_KEY_STRENGTH L"KeyStrength"
57 #define BCRYPT_OBJECT_LENGTH L"ObjectLength"
58 #define BCRYPT_PADDING_SCHEMES L"PaddingSchemes"
59 #define BCRYPT_PROVIDER_HANDLE L"ProviderHandle"
60 #define BCRYPT_SIGNATURE_LENGTH L"SignatureLength"
62 #define BCRYPT_OPAQUE_KEY_BLOB L"OpaqueKeyBlob"
63 #define BCRYPT_KEY_DATA_BLOB L"KeyDataBlob"
64 #define BCRYPT_AES_WRAP_KEY_BLOB L"Rfc3565KeyWrapBlob"
65 #define BCRYPT_ECCPUBLIC_BLOB L"ECCPUBLICBLOB"
66 #define BCRYPT_ECCPRIVATE_BLOB L"ECCPRIVATEBLOB"
67 #define BCRYPT_RSAPUBLIC_BLOB L"RSAPUBLICBLOB"
68 #define BCRYPT_RSAPRIVATE_BLOB L"RSAPRIVATEBLOB"
69 #define BCRYPT_RSAFULLPRIVATE_BLOB L"RSAFULLPRIVATEBLOB"
70 #define BCRYPT_DSA_PUBLIC_BLOB L"DSAPUBLICBLOB"
71 #define BCRYPT_DSA_PRIVATE_BLOB L"DSAPRIVATEBLOB"
72 #define BCRYPT_PUBLIC_KEY_BLOB L"PUBLICBLOB"
73 #define BCRYPT_PRIVATE_KEY_BLOB L"PRIVATEBLOB"
74 #define BCRYPT_DH_PUBLIC_BLOB L"DHPUBLICBLOB"
75 #define BCRYPT_DH_PRIVATE_BLOB L"DHPRIVATEBLOB"
76 #define LEGACY_DSA_PUBLIC_BLOB L"CAPIDSAPUBLICBLOB"
77 #define LEGACY_DSA_PRIVATE_BLOB L"CAPIDSAPRIVATEBLOB"
78 #define LEGACY_DSA_V2_PUBLIC_BLOB L"V2CAPIDSAPUBLICBLOB"
79 #define LEGACY_DSA_V2_PRIVATE_BLOB L"V2CAPIDSAPRIVATEBLOB"
80 #define LEGACY_RSAPUBLIC_BLOB L"CAPIPUBLICBLOB"
81 #define LEGACY_RSAPRIVATE_BLOB L"CAPIPRIVATEBLOB"
83 #define MS_PRIMITIVE_PROVIDER L"Microsoft Primitive Provider"
84 #define MS_PLATFORM_CRYPTO_PROVIDER L"Microsoft Platform Crypto Provider"
86 #define BCRYPT_3DES_ALGORITHM L"3DES"
87 #define BCRYPT_AES_ALGORITHM L"AES"
88 #define BCRYPT_DES_ALGORITHM L"DES"
89 #define BCRYPT_DH_ALGORITHM L"DH"
90 #define BCRYPT_DSA_ALGORITHM L"DSA"
91 #define BCRYPT_ECDH_P256_ALGORITHM L"ECDH_P256"
92 #define BCRYPT_ECDH_P384_ALGORITHM L"ECDH_P384"
93 #define BCRYPT_ECDSA_P256_ALGORITHM L"ECDSA_P256"
94 #define BCRYPT_ECDSA_P384_ALGORITHM L"ECDSA_P384"
95 #define BCRYPT_ECDSA_P521_ALGORITHM L"ECDSA_P521"
96 #define BCRYPT_MD2_ALGORITHM L"MD2"
97 #define BCRYPT_MD4_ALGORITHM L"MD4"
98 #define BCRYPT_MD5_ALGORITHM L"MD5"
99 #define BCRYPT_RC2_ALGORITHM L"RC2"
100 #define BCRYPT_RC4_ALGORITHM L"RC4"
101 #define BCRYPT_RNG_ALGORITHM L"RNG"
102 #define BCRYPT_RSA_ALGORITHM L"RSA"
103 #define BCRYPT_RSA_SIGN_ALGORITHM L"RSA_SIGN"
104 #define BCRYPT_SHA1_ALGORITHM L"SHA1"
105 #define BCRYPT_SHA256_ALGORITHM L"SHA256"
106 #define BCRYPT_SHA384_ALGORITHM L"SHA384"
107 #define BCRYPT_SHA512_ALGORITHM L"SHA512"
109 #define BCRYPT_CHAIN_MODE_NA L"ChainingModeN/A"
110 #define BCRYPT_CHAIN_MODE_CBC L"ChainingModeCBC"
111 #define BCRYPT_CHAIN_MODE_ECB L"ChainingModeECB"
112 #define BCRYPT_CHAIN_MODE_CFB L"ChainingModeCFB"
113 #define BCRYPT_CHAIN_MODE_CCM L"ChainingModeCCM"
114 #define BCRYPT_CHAIN_MODE_GCM L"ChainingModeGCM"
116 #define BCRYPT_KDF_HASH L"HASH"
117 #define BCRYPT_KDF_HMAC L"HMAC"
118 #define BCRYPT_KDF_TLS_PRF L"TLS_PRF"
119 #define BCRYPT_KDF_SP80056A_CONCAT L"SP800_56A_CONCAT"
120 #define BCRYPT_KDF_RAW_SECRET L"TRUNCATE"
122 static const WCHAR BCRYPT_ALGORITHM_NAME
[] = {'A','l','g','o','r','i','t','h','m','N','a','m','e',0};
123 static const WCHAR BCRYPT_AUTH_TAG_LENGTH
[] = {'A','u','t','h','T','a','g','L','e','n','g','t','h',0};
124 static const WCHAR BCRYPT_BLOCK_LENGTH
[] = {'B','l','o','c','k','L','e','n','g','t','h',0};
125 static const WCHAR BCRYPT_BLOCK_SIZE_LIST
[] = {'B','l','o','c','k','S','i','z','e','L','i','s','t',0};
126 static const WCHAR BCRYPT_CHAINING_MODE
[] = {'C','h','a','i','n','i','n','g','M','o','d','e',0};
127 static const WCHAR BCRYPT_EFFECTIVE_KEY_LENGTH
[] = {'E','f','f','e','c','t','i','v','e','K','e','y','L','e','n','g','t','h',0};
128 static const WCHAR BCRYPT_HASH_BLOCK_LENGTH
[] = {'H','a','s','h','B','l','o','c','k','L','e','n','g','t','h',0};
129 static const WCHAR BCRYPT_HASH_LENGTH
[] = {'H','a','s','h','D','i','g','e','s','t','L','e','n','g','t','h',0};
130 static const WCHAR BCRYPT_HASH_OID_LIST
[] = {'H','a','s','h','O','I','D','L','i','s','t',0};
131 static const WCHAR BCRYPT_KEY_LENGTH
[] = {'K','e','y','L','e','n','g','t','h',0};
132 static const WCHAR BCRYPT_KEY_LENGTHS
[] = {'K','e','y','L','e','n','g','t','h','s',0};
133 static const WCHAR BCRYPT_KEY_OBJECT_LENGTH
[] = {'K','e','y','O','b','j','e','c','t','L','e','n','g','t','h',0};
134 static const WCHAR BCRYPT_KEY_STRENGTH
[] = {'K','e','y','S','t','r','e','n','g','t','h',0};
135 static const WCHAR BCRYPT_OBJECT_LENGTH
[] = {'O','b','j','e','c','t','L','e','n','g','t','h',0};
136 static const WCHAR BCRYPT_PADDING_SCHEMES
[] = {'P','a','d','d','i','n','g','S','c','h','e','m','e','s',0};
137 static const WCHAR BCRYPT_PROVIDER_HANDLE
[] = {'P','r','o','v','i','d','e','r','H','a','n','d','l','e',0};
138 static const WCHAR BCRYPT_SIGNATURE_LENGTH
[] = {'S','i','g','n','a','t','u','r','e','L','e','n','g','t','h',0};
140 static const WCHAR BCRYPT_OPAQUE_KEY_BLOB
[] = {'O','p','a','q','u','e','K','e','y','B','l','o','b',0};
141 static const WCHAR BCRYPT_KEY_DATA_BLOB
[] = {'K','e','y','D','a','t','a','B','l','o','b',0};
142 static const WCHAR BCRYPT_AES_WRAP_KEY_BLOB
[] = {'R','f','c','3','5','6','5','K','e','y','W','r','a','p','B','l','o','b',0};
143 static const WCHAR BCRYPT_ECCPUBLIC_BLOB
[] = {'E','C','C','P','U','B','L','I','C','B','L','O','B',0};
144 static const WCHAR BCRYPT_ECCPRIVATE_BLOB
[] = {'E','C','C','P','R','I','V','A','T','E','B','L','O','B',0};
145 static const WCHAR BCRYPT_RSAPUBLIC_BLOB
[] = {'R','S','A','P','U','B','L','I','C','B','L','O','B',0};
146 static const WCHAR BCRYPT_RSAPRIVATE_BLOB
[] = {'R','S','A','P','R','I','V','A','T','E','B','L','O','B',0};
147 static const WCHAR BCRYPT_RSAFULLPRIVATE_BLOB
[] = {'R','S','A','F','U','L','L','P','R','I','V','A','T','E','B','L','O','B',0};
148 static const WCHAR BCRYPT_DSA_PUBLIC_BLOB
[] = {'D','S','A','P','U','B','L','I','C','B','L','O','B',0};
149 static const WCHAR BCRYPT_DSA_PRIVATE_BLOB
[] = {'D','S','A','P','R','I','V','A','T','E','B','L','O','B',0};
150 static const WCHAR BCRYPT_PUBLIC_KEY_BLOB
[] = {'P','U','B','L','I','C','B','L','O','B',0};
151 static const WCHAR BCRYPT_PRIVATE_KEY_BLOB
[] = {'P','R','I','V','A','T','E','B','L','O','B',0};
152 static const WCHAR BCRYPT_DH_PUBLIC_BLOB
[] = {'D','H','P','U','B','L','I','C','B','L','O','B',0};
153 static const WCHAR BCRYPT_DH_PRIVATE_BLOB
[] = {'D','H','P','R','I','V','A','T','E','B','L','O','B',0};
154 static const WCHAR LEGACY_DSA_PUBLIC_BLOB
[] = {'C','A','P','I','D','S','A','P','U','B','L','I','C','B','L','O','B',0};
155 static const WCHAR LEGACY_DSA_PRIVATE_BLOB
[] = {'C','A','P','I','D','S','A','P','R','I','V','A','T','E','B','L','O','B',0};
156 static const WCHAR LEGACY_DSA_V2_PUBLIC_BLOB
[] = {'V','2','C','A','P','I','D','S','A','P','U','B','L','I','C','B','L','O','B',0};
157 static const WCHAR LEGACY_DSA_V2_PRIVATE_BLOB
[] = {'V','2','C','A','P','I','D','S','A','P','R','I','V','A','T','E','B','L','O','B',0};
158 static const WCHAR LEGACY_RSAPUBLIC_BLOB
[] = {'C','A','P','I','P','U','B','L','I','C','B','L','O','B',0};
159 static const WCHAR LEGACY_RSAPRIVATE_BLOB
[] = {'C','A','P','I','P','R','I','V','A','T','E','B','L','O','B',0};
161 static const WCHAR MS_PRIMITIVE_PROVIDER
[] = \
162 {'M','i','c','r','o','s','o','f','t',' ','P','r','i','m','i','t','i','v','e',' ','P','r','o','v','i','d','e','r',0};
163 static const WCHAR MS_PLATFORM_CRYPTO_PROVIDER
[] = \
164 {'M','i','c','r','o','s','o','f','t',' ','P','l','a','t','f','o','r','m',' ','C','r','y','p','t','o',' ','P','r','o','v','i','d','e','r',0};
166 static const WCHAR BCRYPT_3DES_ALGORITHM
[] = {'3','D','E','S',0};
167 static const WCHAR BCRYPT_AES_ALGORITHM
[] = {'A','E','S',0};
168 static const WCHAR BCRYPT_DES_ALGORITHM
[] = {'D','E','S',0};
169 static const WCHAR BCRYPT_DH_ALGORITHM
[] = {'D','H',0};
170 static const WCHAR BCRYPT_DSA_ALGORITHM
[] = {'D','S','A',0};
171 static const WCHAR BCRYPT_ECDH_P256_ALGORITHM
[] = {'E','C','D','H','_','P','2','5','6',0};
172 static const WCHAR BCRYPT_ECDH_P384_ALGORITHM
[] = {'E','C','D','H','_','P','3','8','4',0};
173 static const WCHAR BCRYPT_ECDSA_P256_ALGORITHM
[] = {'E','C','D','S','A','_','P','2','5','6',0};
174 static const WCHAR BCRYPT_ECDSA_P384_ALGORITHM
[] = {'E','C','D','S','A','_','P','3','8','4',0};
175 static const WCHAR BCRYPT_ECDSA_P521_ALGORITHM
[] = {'E','C','D','S','A','_','P','5','2','1',0};
176 static const WCHAR BCRYPT_MD2_ALGORITHM
[] = {'M','D','2',0};
177 static const WCHAR BCRYPT_MD4_ALGORITHM
[] = {'M','D','4',0};
178 static const WCHAR BCRYPT_MD5_ALGORITHM
[] = {'M','D','5',0};
179 static const WCHAR BCRYPT_RC2_ALGORITHM
[] = {'R','C','2',0};
180 static const WCHAR BCRYPT_RC4_ALGORITHM
[] = {'R','C','4',0};
181 static const WCHAR BCRYPT_RNG_ALGORITHM
[] = {'R','N','G',0};
182 static const WCHAR BCRYPT_RSA_ALGORITHM
[] = {'R','S','A',0};
183 static const WCHAR BCRYPT_RSA_SIGN_ALGORITHM
[] = {'R','S','A','_','S','I','G','N',0};
184 static const WCHAR BCRYPT_SHA1_ALGORITHM
[] = {'S','H','A','1',0};
185 static const WCHAR BCRYPT_SHA256_ALGORITHM
[] = {'S','H','A','2','5','6',0};
186 static const WCHAR BCRYPT_SHA384_ALGORITHM
[] = {'S','H','A','3','8','4',0};
187 static const WCHAR BCRYPT_SHA512_ALGORITHM
[] = {'S','H','A','5','1','2',0};
189 static const WCHAR BCRYPT_CHAIN_MODE_NA
[] = {'C','h','a','i','n','i','n','g','M','o','d','e','N','/','A',0};
190 static const WCHAR BCRYPT_CHAIN_MODE_CBC
[] = {'C','h','a','i','n','i','n','g','M','o','d','e','C','B','C',0};
191 static const WCHAR BCRYPT_CHAIN_MODE_ECB
[] = {'C','h','a','i','n','i','n','g','M','o','d','e','E','C','B',0};
192 static const WCHAR BCRYPT_CHAIN_MODE_CFB
[] = {'C','h','a','i','n','i','n','g','M','o','d','e','C','F','B',0};
193 static const WCHAR BCRYPT_CHAIN_MODE_CCM
[] = {'C','h','a','i','n','i','n','g','M','o','d','e','C','C','M',0};
194 static const WCHAR BCRYPT_CHAIN_MODE_GCM
[] = {'C','h','a','i','n','i','n','g','M','o','d','e','G','C','M',0};
196 static const WCHAR BCRYPT_KDF_HASH
[] = {'H','A','S','H',0};
197 static const WCHAR BCRYPT_KDF_HMAC
[] = {'H','M','A','C',0};
198 static const WCHAR BCRYPT_KDF_TLS_PRF
[] = {'T','L','S','_','P','R','F',0};
199 static const WCHAR BCRYPT_KDF_SP80056A_CONCAT
[] = {'S','P','8','0','0','_','5','6','A','_','C','O','N','C','A','T',0};
200 static const WCHAR BCRYPT_KDF_RAW_SECRET
[] = {'T','R','U','N','C','A','T','E',0};
203 #define BCRYPT_ECDSA_PUBLIC_P256_MAGIC 0x31534345
204 #define BCRYPT_ECDSA_PRIVATE_P256_MAGIC 0x32534345
205 #define BCRYPT_ECDSA_PUBLIC_P384_MAGIC 0x33534345
206 #define BCRYPT_ECDSA_PRIVATE_P384_MAGIC 0x34534345
207 #define BCRYPT_ECDSA_PUBLIC_P521_MAGIC 0x35534345
208 #define BCRYPT_ECDSA_PRIVATE_P521_MAGIC 0x36534345
210 #define BCRYPT_ECDH_PUBLIC_P256_MAGIC 0x314b4345
211 #define BCRYPT_ECDH_PRIVATE_P256_MAGIC 0x324b4345
212 #define BCRYPT_ECDH_PUBLIC_P384_MAGIC 0x334b4345
213 #define BCRYPT_ECDH_PRIVATE_P384_MAGIC 0x344b4345
214 #define BCRYPT_ECDH_PUBLIC_P521_MAGIC 0x354b4345
215 #define BCRYPT_ECDH_PRIVATE_P521_MAGIC 0x364b4345
217 #define BCRYPT_CIPHER_OPERATION 0x00000001
218 #define BCRYPT_HASH_OPERATION 0x00000002
219 #define BCRYPT_ASYMMETRIC_ENCRYPTION_OPERATION 0x00000004
220 #define BCRYPT_SECRET_AGREEMENT_OPERATION 0x00000008
221 #define BCRYPT_SIGNATURE_OPERATION 0x00000010
222 #define BCRYPT_RNG_OPERATION 0x00000020
224 #define BCRYPT_CIPHER_INTERFACE 0x00000001
225 #define BCRYPT_HASH_INTERFACE 0x00000002
226 #define BCRYPT_ASYMMETRIC_ENCRYPTION_INTERFACE 0x00000003
227 #define BCRYPT_SECRET_AGREEMENT_INTERFACE 0x00000004
228 #define BCRYPT_SIGNATURE_INTERFACE 0x00000005
229 #define BCRYPT_RNG_INTERFACE 0x00000006
230 #define BCRYPT_KEY_DERIVATION_INTERFACE 0x00000007
232 #define BCRYPT_SUPPORTED_PAD_ROUTER 0x00000001
233 #define BCRYPT_SUPPORTED_PAD_PKCS1_ENC 0x00000002
234 #define BCRYPT_SUPPORTED_PAD_PKCS1_SIG 0x00000004
235 #define BCRYPT_SUPPORTED_PAD_OAEP 0x00000008
236 #define BCRYPT_SUPPORTED_PAD_PSS 0x00000010
238 typedef struct _BCRYPT_ALGORITHM_IDENTIFIER
243 } BCRYPT_ALGORITHM_IDENTIFIER
;
245 typedef struct __BCRYPT_KEY_LENGTHS_STRUCT
250 } BCRYPT_KEY_LENGTHS_STRUCT
, BCRYPT_AUTH_TAG_LENGTHS_STRUCT
;
252 typedef struct _BCRYPT_AUTHENTICATED_CIPHER_MODE_INFO
267 } BCRYPT_AUTHENTICATED_CIPHER_MODE_INFO
, *PBCRYPT_AUTHENTICATED_CIPHER_MODE_INFO
;
269 typedef struct _BCRYPT_KEY_BLOB
274 typedef struct _BCRYPT_ECCKEY_BLOB
278 } BCRYPT_ECCKEY_BLOB
, *PBCRYPT_ECCKEY_BLOB
;
280 #define BCRYPT_RSAPUBLIC_MAGIC 0x31415352
281 #define BCRYPT_RSAPRIVATE_MAGIC 0x32415352
282 #define BCRYPT_RSAFULLPRIVATE_MAGIC 0x33415352
284 typedef struct _BCRYPT_RSAKEY_BLOB
292 } BCRYPT_RSAKEY_BLOB
;
294 typedef struct _BCRYPT_PKCS1_PADDING_INFO
297 } BCRYPT_PKCS1_PADDING_INFO
;
299 typedef struct _BCRYPT_PSS_PADDING_INFO
303 } BCRYPT_PSS_PADDING_INFO
;
305 typedef struct _BCRYPT_OAEP_PADDING_INFO
310 } BCRYPT_OAEP_PADDING_INFO
;
312 #define BCRYPT_PAD_NONE 0x00000001
313 #define BCRYPT_PAD_PKCS1 0x00000002
314 #define BCRYPT_PAD_OAEP 0x00000004
315 #define BCRYPT_PAD_PSS 0x00000008
316 #define BCRYPT_PAD_PKCS1_OPTIONAL_HASH_OID 0x00000010
318 #define BCRYPT_DSA_PUBLIC_MAGIC 0x42505344
319 #define BCRYPT_DSA_PRIVATE_MAGIC 0x56505344
321 typedef struct _BCRYPT_DSA_KEY_BLOB
328 } BCRYPT_DSA_KEY_BLOB
, *PBCRYPT_DSA_KEY_BLOB
;
330 #define BCRYPT_DSA_PUBLIC_MAGIC_V2 0x32425044
331 #define BCRYPT_DSA_PRIVATE_MAGIC_V2 0x32565044
335 DSA_HASH_ALGORITHM_SHA1
,
336 DSA_HASH_ALGORITHM_SHA256
,
337 DSA_HASH_ALGORITHM_SHA512
338 } HASHALGORITHM_ENUM
;
344 } DSAFIPSVERSION_ENUM
;
346 typedef struct _BCRYPT_DSA_KEY_BLOB_V2
350 HASHALGORITHM_ENUM hashAlgorithm
;
351 DSAFIPSVERSION_ENUM standardVersion
;
355 } BCRYPT_DSA_KEY_BLOB_V2
, *PBCRYPT_DSA_KEY_BLOB_V2
;
357 #define BCRYPT_DH_PUBLIC_MAGIC 0x42504844
358 #define BCRYPT_DH_PRIVATE_MAGIC 0x56504844
360 typedef struct _BCRYPT_DH_KEY_BLOB
364 } BCRYPT_DH_KEY_BLOB
, *PBCRYPT_DH_KEY_BLOB
;
366 #define BCRYPT_AUTHENTICATED_CIPHER_MODE_INFO_VERSION 1
368 #define BCRYPT_AUTH_MODE_CHAIN_CALLS_FLAG 0x00000001
369 #define BCRYPT_AUTH_MODE_IN_PROGRESS_FLAG 0x00000002
371 typedef struct _CRYPT_INTERFACE_REG
376 PWSTR
*rgpszFunctions
;
377 } CRYPT_INTERFACE_REG
, *PCRYPT_INTERFACE_REG
;
379 typedef struct _CRYPT_IMAGE_REG
383 PCRYPT_INTERFACE_REG
*rgpInterfaces
;
384 } CRYPT_IMAGE_REG
, *PCRYPT_IMAGE_REG
;
386 typedef struct _CRYPT_PROVIDER_REG
390 PCRYPT_IMAGE_REG pUM
;
391 PCRYPT_IMAGE_REG pKM
;
392 } CRYPT_PROVIDER_REG
, *PCRYPT_PROVIDER_REG
;
394 typedef struct _BCRYPT_KEY_DATA_BLOB_HEADER
399 } BCRYPT_KEY_DATA_BLOB_HEADER
, *PBCRYPT_KEY_DATA_BLOB_HEADER
;
401 #define KDF_HASH_ALGORITHM 0x00000000
402 #define KDF_SECRET_PREPEND 0x00000001
403 #define KDF_SECRET_APPEND 0x00000002
405 typedef struct _BCryptBuffer
410 } BCryptBuffer
, *PBCryptBuffer
;
412 #define BCRYPTBUFFER_VERSION 0
414 typedef struct _BCryptBufferDesc
418 PBCryptBuffer pBuffers
;
419 } BCryptBufferDesc
, *PBCryptBufferDesc
;
421 #define BCRYPT_KEY_DATA_BLOB_MAGIC 0x4d42444b
422 #define BCRYPT_KEY_DATA_BLOB_VERSION1 1
424 typedef PVOID BCRYPT_ALG_HANDLE
;
425 typedef PVOID BCRYPT_KEY_HANDLE
;
426 typedef PVOID BCRYPT_HANDLE
;
427 typedef PVOID BCRYPT_HASH_HANDLE
;
428 typedef PVOID BCRYPT_SECRET_HANDLE
;
431 #define BCRYPT_MD2_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000001)
432 #define BCRYPT_MD4_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000011)
433 #define BCRYPT_MD5_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000021)
434 #define BCRYPT_SHA1_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000031)
435 #define BCRYPT_SHA256_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000041)
436 #define BCRYPT_SHA384_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000051)
437 #define BCRYPT_SHA512_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000061)
438 #define BCRYPT_RC4_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000071)
439 #define BCRYPT_RNG_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000081)
440 #define BCRYPT_HMAC_MD5_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000091)
441 #define BCRYPT_HMAC_SHA1_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000000a1)
442 #define BCRYPT_HMAC_SHA256_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000000b1)
443 #define BCRYPT_HMAC_SHA384_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000000c1)
444 #define BCRYPT_HMAC_SHA512_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000000d1)
445 #define BCRYPT_RSA_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000000e1)
446 #define BCRYPT_ECDSA_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000000f1)
447 #define BCRYPT_AES_CMAC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000101)
448 #define BCRYPT_AES_GMAC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000111)
449 #define BCRYPT_HMAC_MD2_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000121)
450 #define BCRYPT_HMAC_MD4_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000131)
451 #define BCRYPT_3DES_CBC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000141)
452 #define BCRYPT_3DES_ECB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000151)
453 #define BCRYPT_3DES_CFB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000161)
454 #define BCRYPT_3DES_112_CBC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000171)
455 #define BCRYPT_3DES_112_ECB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000181)
456 #define BCRYPT_3DES_112_CFB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000191)
457 #define BCRYPT_AES_CBC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000001a1)
458 #define BCRYPT_AES_ECB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000001b1)
459 #define BCRYPT_AES_CFB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000001c1)
460 #define BCRYPT_AES_CCM_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000001d1)
461 #define BCRYPT_AES_GCM_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000001e1)
462 #define BCRYPT_DES_CBC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000001f1)
463 #define BCRYPT_DES_ECB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000201)
464 #define BCRYPT_DES_CFB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000211)
465 #define BCRYPT_DESX_CBC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000221)
466 #define BCRYPT_DESX_ECB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000231)
467 #define BCRYPT_DESX_CFB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000241)
468 #define BCRYPT_RC2_CBC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000251)
469 #define BCRYPT_RC2_ECB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000261)
470 #define BCRYPT_RC2_CFB_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000271)
471 #define BCRYPT_DH_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000281)
472 #define BCRYPT_ECDH_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000291)
473 #define BCRYPT_ECDH_P256_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000002a1)
474 #define BCRYPT_ECDH_P384_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000002b1)
475 #define BCRYPT_ECDH_P521_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000002c1)
476 #define BCRYPT_DSA_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000002d1)
477 #define BCRYPT_ECDSA_P256_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000002e1)
478 #define BCRYPT_ECDSA_P384_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x000002f1)
479 #define BCRYPT_ECDSA_P521_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000301)
480 #define BCRYPT_RSA_SIGN_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000311)
481 #define BCRYPT_CAPI_KDF_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000321)
482 #define BCRYPT_PBKDF2_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000331)
483 #define BCRYPT_SP800108_CTR_HMAC_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000341)
484 #define BCRYPT_SP80056A_CONCAT_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000351)
485 #define BCRYPT_TLS1_1_KDF_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000361)
486 #define BCRYPT_TLS1_2_KDF_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000371)
487 #define BCRYPT_XTS_AES_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000381)
488 #define BCRYPT_HKDF_ALG_HANDLE ((BCRYPT_ALG_HANDLE)0x00000391)
490 /* Flags for BCryptGenRandom */
491 #define BCRYPT_RNG_USE_ENTROPY_IN_BUFFER 0x00000001
492 #define BCRYPT_USE_SYSTEM_PREFERRED_RNG 0x00000002
494 /* Flags for BCryptOpenAlgorithmProvider */
495 #define BCRYPT_ALG_HANDLE_HMAC_FLAG 0x00000008
497 /* Flags for BCryptEncrypt/BCryptDecrypt */
498 #define BCRYPT_BLOCK_PADDING 0x00000001
500 /* Flags for BCryptCreateHash */
501 #define BCRYPT_HASH_REUSABLE_FLAG 0x00000020
503 #define CRYPT_LOCAL 0x00000001
504 #define CRYPT_DOMAIN 0x00000002
506 typedef struct _CRYPT_CONTEXT_FUNCTIONS
509 WCHAR
**rgpszFunctions
;
510 } CRYPT_CONTEXT_FUNCTIONS
, *PCRYPT_CONTEXT_FUNCTIONS
;
512 NTSTATUS WINAPI
BCryptAddContextFunction(ULONG
, LPCWSTR
, ULONG
, LPCWSTR
, ULONG
);
513 NTSTATUS WINAPI
BCryptCloseAlgorithmProvider(BCRYPT_ALG_HANDLE
, ULONG
);
514 NTSTATUS WINAPI
BCryptCreateHash(BCRYPT_ALG_HANDLE
, BCRYPT_HASH_HANDLE
*, PUCHAR
, ULONG
, PUCHAR
, ULONG
, ULONG
);
515 NTSTATUS WINAPI
BCryptDecrypt(BCRYPT_KEY_HANDLE
, PUCHAR
, ULONG
, VOID
*, PUCHAR
, ULONG
, PUCHAR
, ULONG
, ULONG
*, ULONG
);
516 NTSTATUS WINAPI
BCryptDeriveKey(BCRYPT_SECRET_HANDLE
, LPCWSTR
, BCryptBufferDesc
*, PUCHAR
, ULONG
, ULONG
*, ULONG
);
517 NTSTATUS WINAPI
BCryptDeriveKeyCapi(BCRYPT_HASH_HANDLE
, BCRYPT_ALG_HANDLE
, PUCHAR
, ULONG
, ULONG
);
518 NTSTATUS WINAPI
BCryptDeriveKeyPBKDF2(BCRYPT_ALG_HANDLE
, PUCHAR
, ULONG
, PUCHAR
, ULONG
, ULONGLONG
, PUCHAR
, ULONG
, ULONG
);
519 NTSTATUS WINAPI
BCryptDestroyHash(BCRYPT_HASH_HANDLE
);
520 NTSTATUS WINAPI
BCryptDestroyKey(BCRYPT_KEY_HANDLE
);
521 NTSTATUS WINAPI
BCryptDestroySecret(BCRYPT_SECRET_HANDLE
);
522 NTSTATUS WINAPI
BCryptDuplicateHash(BCRYPT_HASH_HANDLE
, BCRYPT_HASH_HANDLE
*, UCHAR
*, ULONG
, ULONG
);
523 NTSTATUS WINAPI
BCryptDuplicateKey(BCRYPT_KEY_HANDLE
, BCRYPT_KEY_HANDLE
*, PUCHAR
, ULONG
, ULONG
);
524 NTSTATUS WINAPI
BCryptEncrypt(BCRYPT_KEY_HANDLE
, PUCHAR
, ULONG
, VOID
*, PUCHAR
, ULONG
, PUCHAR
, ULONG
, ULONG
*, ULONG
);
525 NTSTATUS WINAPI
BCryptEnumAlgorithms(ULONG
, ULONG
*, BCRYPT_ALGORITHM_IDENTIFIER
**, ULONG
);
526 NTSTATUS WINAPI
BCryptEnumContextFunctions(ULONG
, const WCHAR
*, ULONG
, ULONG
*, CRYPT_CONTEXT_FUNCTIONS
**);
527 NTSTATUS WINAPI
BCryptExportKey(BCRYPT_KEY_HANDLE
, BCRYPT_KEY_HANDLE
, LPCWSTR
, PUCHAR
, ULONG
, ULONG
*, ULONG
);
528 NTSTATUS WINAPI
BCryptFinalizeKeyPair(BCRYPT_KEY_HANDLE
, ULONG
);
529 NTSTATUS WINAPI
BCryptFinishHash(BCRYPT_HASH_HANDLE
, PUCHAR
, ULONG
, ULONG
);
530 void WINAPI
BCryptFreeBuffer(void *);
531 NTSTATUS WINAPI
BCryptGenRandom(BCRYPT_ALG_HANDLE
, PUCHAR
, ULONG
, ULONG
);
532 NTSTATUS WINAPI
BCryptGenerateKeyPair(BCRYPT_ALG_HANDLE
, BCRYPT_KEY_HANDLE
*, ULONG
, ULONG
);
533 NTSTATUS WINAPI
BCryptGenerateSymmetricKey(BCRYPT_ALG_HANDLE
, BCRYPT_KEY_HANDLE
*, PUCHAR
, ULONG
, PUCHAR
, ULONG
, ULONG
);
534 NTSTATUS WINAPI
BCryptGetFipsAlgorithmMode(BOOLEAN
*);
535 NTSTATUS WINAPI
BCryptGetProperty(BCRYPT_HANDLE
, LPCWSTR
, PUCHAR
, ULONG
, ULONG
*, ULONG
);
536 NTSTATUS WINAPI
BCryptHash(BCRYPT_ALG_HANDLE
, PUCHAR
, ULONG
, PUCHAR
, ULONG
, PUCHAR
, ULONG
);
537 NTSTATUS WINAPI
BCryptHashData(BCRYPT_HASH_HANDLE
, PUCHAR
, ULONG
, ULONG
);
538 NTSTATUS WINAPI
BCryptImportKey(BCRYPT_ALG_HANDLE
, BCRYPT_KEY_HANDLE
, LPCWSTR
, BCRYPT_KEY_HANDLE
*, PUCHAR
, ULONG
, PUCHAR
, ULONG
, ULONG
);
539 NTSTATUS WINAPI
BCryptImportKeyPair(BCRYPT_ALG_HANDLE
, BCRYPT_KEY_HANDLE
, LPCWSTR
, BCRYPT_KEY_HANDLE
*, UCHAR
*, ULONG
, ULONG
);
540 NTSTATUS WINAPI
BCryptOpenAlgorithmProvider(BCRYPT_ALG_HANDLE
*, LPCWSTR
, LPCWSTR
, ULONG
);
541 NTSTATUS WINAPI
BCryptRemoveContextFunction(ULONG
, LPCWSTR
, ULONG
, LPCWSTR
);
542 NTSTATUS WINAPI
BCryptSecretAgreement(BCRYPT_KEY_HANDLE
, BCRYPT_KEY_HANDLE
, BCRYPT_SECRET_HANDLE
*, ULONG
);
543 NTSTATUS WINAPI
BCryptSetProperty(BCRYPT_HANDLE
, LPCWSTR
, PUCHAR
, ULONG
, ULONG
);
544 NTSTATUS WINAPI
BCryptSignHash(BCRYPT_KEY_HANDLE
, void *, PUCHAR
, ULONG
, PUCHAR
, ULONG
, ULONG
*, ULONG
);
545 NTSTATUS WINAPI
BCryptVerifySignature(BCRYPT_KEY_HANDLE
, void *, UCHAR
*, ULONG
, UCHAR
*, ULONG
, ULONG
);
547 #endif /* __WINE_BCRYPT_H */