setupapi: Return CR_SUCCESS for CM_Get_DevNode_Status{_Ex}.
[wine.git] / include / bcrypt.h
blobfbfb5099c09d59e605e837f6079bb62791bb8d8d
1 /*
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
22 #ifndef WINAPI
23 #define WINAPI __stdcall
24 #endif
26 #ifndef IN
27 #define IN
28 #endif
30 #ifndef OUT
31 #define OUT
32 #endif
34 #ifndef OPTIONAL
35 #define OPTIONAL
36 #endif
38 #ifndef WINE_NTSTATUS_DECLARED
39 #define WINE_NTSTATUS_DECLARED
40 typedef LONG NTSTATUS;
41 #endif
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 LEGACY_DSA_PUBLIC_BLOB L"CAPIDSAPUBLICBLOB"
75 #define LEGACY_DSA_PRIVATE_BLOB L"CAPIDSAPRIVATEBLOB"
76 #define LEGACY_DSA_V2_PUBLIC_BLOB L"V2CAPIDSAPUBLICBLOB"
77 #define LEGACY_DSA_V2_PRIVATE_BLOB L"V2CAPIDSAPRIVATEBLOB"
79 #define MS_PRIMITIVE_PROVIDER L"Microsoft Primitive Provider"
80 #define MS_PLATFORM_CRYPTO_PROVIDER L"Microsoft Platform Crypto Provider"
82 #define BCRYPT_3DES_ALGORITHM L"3DES"
83 #define BCRYPT_AES_ALGORITHM L"AES"
84 #define BCRYPT_DES_ALGORITHM L"DES"
85 #define BCRYPT_DSA_ALGORITHM L"DSA"
86 #define BCRYPT_ECDH_P256_ALGORITHM L"ECDH_P256"
87 #define BCRYPT_ECDSA_P256_ALGORITHM L"ECDSA_P256"
88 #define BCRYPT_ECDSA_P384_ALGORITHM L"ECDSA_P384"
89 #define BCRYPT_ECDSA_P521_ALGORITHM L"ECDSA_P521"
90 #define BCRYPT_MD2_ALGORITHM L"MD2"
91 #define BCRYPT_MD4_ALGORITHM L"MD4"
92 #define BCRYPT_MD5_ALGORITHM L"MD5"
93 #define BCRYPT_RC2_ALGORITHM L"RC2"
94 #define BCRYPT_RC4_ALGORITHM L"RC4"
95 #define BCRYPT_RNG_ALGORITHM L"RNG"
96 #define BCRYPT_RSA_ALGORITHM L"RSA"
97 #define BCRYPT_RSA_SIGN_ALGORITHM L"RSA_SIGN"
98 #define BCRYPT_SHA1_ALGORITHM L"SHA1"
99 #define BCRYPT_SHA256_ALGORITHM L"SHA256"
100 #define BCRYPT_SHA384_ALGORITHM L"SHA384"
101 #define BCRYPT_SHA512_ALGORITHM L"SHA512"
103 #define BCRYPT_CHAIN_MODE_NA L"ChainingModeN/A"
104 #define BCRYPT_CHAIN_MODE_CBC L"ChainingModeCBC"
105 #define BCRYPT_CHAIN_MODE_ECB L"ChainingModeECB"
106 #define BCRYPT_CHAIN_MODE_CFB L"ChainingModeCFB"
107 #define BCRYPT_CHAIN_MODE_CCM L"ChainingModeCCM"
108 #define BCRYPT_CHAIN_MODE_GCM L"ChainingModeGCM"
110 #define BCRYPT_KDF_HASH L"HASH"
111 #define BCRYPT_KDF_HMAC L"HMAC"
112 #define BCRYPT_KDF_TLS_PRF L"TLS_PRF"
113 #define BCRYPT_KDF_SP80056A_CONCAT L"SP800_56A_CONCAT"
114 #define BCRYPT_KDF_RAW_SECRET L"TRUNCATE"
115 #else
116 static const WCHAR BCRYPT_ALGORITHM_NAME[] = {'A','l','g','o','r','i','t','h','m','N','a','m','e',0};
117 static const WCHAR BCRYPT_AUTH_TAG_LENGTH[] = {'A','u','t','h','T','a','g','L','e','n','g','t','h',0};
118 static const WCHAR BCRYPT_BLOCK_LENGTH[] = {'B','l','o','c','k','L','e','n','g','t','h',0};
119 static const WCHAR BCRYPT_BLOCK_SIZE_LIST[] = {'B','l','o','c','k','S','i','z','e','L','i','s','t',0};
120 static const WCHAR BCRYPT_CHAINING_MODE[] = {'C','h','a','i','n','i','n','g','M','o','d','e',0};
121 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};
122 static const WCHAR BCRYPT_HASH_BLOCK_LENGTH[] = {'H','a','s','h','B','l','o','c','k','L','e','n','g','t','h',0};
123 static const WCHAR BCRYPT_HASH_LENGTH[] = {'H','a','s','h','D','i','g','e','s','t','L','e','n','g','t','h',0};
124 static const WCHAR BCRYPT_HASH_OID_LIST[] = {'H','a','s','h','O','I','D','L','i','s','t',0};
125 static const WCHAR BCRYPT_KEY_LENGTH[] = {'K','e','y','L','e','n','g','t','h',0};
126 static const WCHAR BCRYPT_KEY_LENGTHS[] = {'K','e','y','L','e','n','g','t','h','s',0};
127 static const WCHAR BCRYPT_KEY_OBJECT_LENGTH[] = {'K','e','y','O','b','j','e','c','t','L','e','n','g','t','h',0};
128 static const WCHAR BCRYPT_KEY_STRENGTH[] = {'K','e','y','S','t','r','e','n','g','t','h',0};
129 static const WCHAR BCRYPT_OBJECT_LENGTH[] = {'O','b','j','e','c','t','L','e','n','g','t','h',0};
130 static const WCHAR BCRYPT_PADDING_SCHEMES[] = {'P','a','d','d','i','n','g','S','c','h','e','m','e','s',0};
131 static const WCHAR BCRYPT_PROVIDER_HANDLE[] = {'P','r','o','v','i','d','e','r','H','a','n','d','l','e',0};
132 static const WCHAR BCRYPT_SIGNATURE_LENGTH[] = {'S','i','g','n','a','t','u','r','e','L','e','n','g','t','h',0};
134 static const WCHAR BCRYPT_OPAQUE_KEY_BLOB[] = {'O','p','a','q','u','e','K','e','y','B','l','o','b',0};
135 static const WCHAR BCRYPT_KEY_DATA_BLOB[] = {'K','e','y','D','a','t','a','B','l','o','b',0};
136 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};
137 static const WCHAR BCRYPT_ECCPUBLIC_BLOB[] = {'E','C','C','P','U','B','L','I','C','B','L','O','B',0};
138 static const WCHAR BCRYPT_ECCPRIVATE_BLOB[] = {'E','C','C','P','R','I','V','A','T','E','B','L','O','B',0};
139 static const WCHAR BCRYPT_RSAPUBLIC_BLOB[] = {'R','S','A','P','U','B','L','I','C','B','L','O','B',0};
140 static const WCHAR BCRYPT_RSAPRIVATE_BLOB[] = {'R','S','A','P','R','I','V','A','T','E','B','L','O','B',0};
141 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};
142 static const WCHAR BCRYPT_DSA_PUBLIC_BLOB[] = {'D','S','A','P','U','B','L','I','C','B','L','O','B',0};
143 static const WCHAR BCRYPT_DSA_PRIVATE_BLOB[] = {'D','S','A','P','R','I','V','A','T','E','B','L','O','B',0};
144 static const WCHAR BCRYPT_PUBLIC_KEY_BLOB[] = {'P','U','B','L','I','C','B','L','O','B',0};
145 static const WCHAR BCRYPT_PRIVATE_KEY_BLOB[] = {'P','R','I','V','A','T','E','B','L','O','B',0};
146 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};
147 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};
148 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};
149 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};
151 static const WCHAR MS_PRIMITIVE_PROVIDER[] = \
152 {'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};
153 static const WCHAR MS_PLATFORM_CRYPTO_PROVIDER[] = \
154 {'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};
156 static const WCHAR BCRYPT_3DES_ALGORITHM[] = {'3','D','E','S',0};
157 static const WCHAR BCRYPT_AES_ALGORITHM[] = {'A','E','S',0};
158 static const WCHAR BCRYPT_DES_ALGORITHM[] = {'D','E','S',0};
159 static const WCHAR BCRYPT_DSA_ALGORITHM[] = {'D','S','A',0};
160 static const WCHAR BCRYPT_ECDH_P256_ALGORITHM[] = {'E','C','D','H','_','P','2','5','6',0};
161 static const WCHAR BCRYPT_ECDSA_P256_ALGORITHM[] = {'E','C','D','S','A','_','P','2','5','6',0};
162 static const WCHAR BCRYPT_ECDSA_P384_ALGORITHM[] = {'E','C','D','S','A','_','P','3','8','4',0};
163 static const WCHAR BCRYPT_ECDSA_P521_ALGORITHM[] = {'E','C','D','S','A','_','P','5','2','1',0};
164 static const WCHAR BCRYPT_MD2_ALGORITHM[] = {'M','D','2',0};
165 static const WCHAR BCRYPT_MD4_ALGORITHM[] = {'M','D','4',0};
166 static const WCHAR BCRYPT_MD5_ALGORITHM[] = {'M','D','5',0};
167 static const WCHAR BCRYPT_RC2_ALGORITHM[] = {'R','C','2',0};
168 static const WCHAR BCRYPT_RC4_ALGORITHM[] = {'R','C','4',0};
169 static const WCHAR BCRYPT_RNG_ALGORITHM[] = {'R','N','G',0};
170 static const WCHAR BCRYPT_RSA_ALGORITHM[] = {'R','S','A',0};
171 static const WCHAR BCRYPT_RSA_SIGN_ALGORITHM[] = {'R','S','A','_','S','I','G','N',0};
172 static const WCHAR BCRYPT_SHA1_ALGORITHM[] = {'S','H','A','1',0};
173 static const WCHAR BCRYPT_SHA256_ALGORITHM[] = {'S','H','A','2','5','6',0};
174 static const WCHAR BCRYPT_SHA384_ALGORITHM[] = {'S','H','A','3','8','4',0};
175 static const WCHAR BCRYPT_SHA512_ALGORITHM[] = {'S','H','A','5','1','2',0};
177 static const WCHAR BCRYPT_CHAIN_MODE_NA[] = {'C','h','a','i','n','i','n','g','M','o','d','e','N','/','A',0};
178 static const WCHAR BCRYPT_CHAIN_MODE_CBC[] = {'C','h','a','i','n','i','n','g','M','o','d','e','C','B','C',0};
179 static const WCHAR BCRYPT_CHAIN_MODE_ECB[] = {'C','h','a','i','n','i','n','g','M','o','d','e','E','C','B',0};
180 static const WCHAR BCRYPT_CHAIN_MODE_CFB[] = {'C','h','a','i','n','i','n','g','M','o','d','e','C','F','B',0};
181 static const WCHAR BCRYPT_CHAIN_MODE_CCM[] = {'C','h','a','i','n','i','n','g','M','o','d','e','C','C','M',0};
182 static const WCHAR BCRYPT_CHAIN_MODE_GCM[] = {'C','h','a','i','n','i','n','g','M','o','d','e','G','C','M',0};
184 static const WCHAR BCRYPT_KDF_HASH[] = {'H','A','S','H',0};
185 static const WCHAR BCRYPT_KDF_HMAC[] = {'H','M','A','C',0};
186 static const WCHAR BCRYPT_KDF_TLS_PRF[] = {'T','L','S','_','P','R','F',0};
187 static const WCHAR BCRYPT_KDF_SP80056A_CONCAT[] = {'S','P','8','0','0','_','5','6','A','_','C','O','N','C','A','T',0};
188 static const WCHAR BCRYPT_KDF_RAW_SECRET[] = {'T','R','U','N','C','A','T','E',0};
189 #endif
191 #define BCRYPT_ECDSA_PUBLIC_P256_MAGIC 0x31534345
192 #define BCRYPT_ECDSA_PRIVATE_P256_MAGIC 0x32534345
193 #define BCRYPT_ECDSA_PUBLIC_P384_MAGIC 0x33534345
194 #define BCRYPT_ECDSA_PRIVATE_P384_MAGIC 0x34534345
195 #define BCRYPT_ECDSA_PUBLIC_P521_MAGIC 0x35534345
196 #define BCRYPT_ECDSA_PRIVATE_P521_MAGIC 0x36534345
198 #define BCRYPT_ECDH_PUBLIC_P256_MAGIC 0x314b4345
199 #define BCRYPT_ECDH_PRIVATE_P256_MAGIC 0x324b4345
200 #define BCRYPT_ECDH_PUBLIC_P384_MAGIC 0x334b4345
201 #define BCRYPT_ECDH_PRIVATE_P384_MAGIC 0x344b4345
202 #define BCRYPT_ECDH_PUBLIC_P521_MAGIC 0x354b4345
203 #define BCRYPT_ECDH_PRIVATE_P521_MAGIC 0x364b4345
205 #define BCRYPT_CIPHER_OPERATION 0x00000001
206 #define BCRYPT_HASH_OPERATION 0x00000002
207 #define BCRYPT_ASYMMETRIC_ENCRYPTION_OPERATION 0x00000004
208 #define BCRYPT_SECRET_AGREEMENT_OPERATION 0x00000008
209 #define BCRYPT_SIGNATURE_OPERATION 0x00000010
210 #define BCRYPT_RNG_OPERATION 0x00000020
212 #define BCRYPT_CIPHER_INTERFACE 0x00000001
213 #define BCRYPT_HASH_INTERFACE 0x00000002
214 #define BCRYPT_ASYMMETRIC_ENCRYPTION_INTERFACE 0x00000003
215 #define BCRYPT_SECRET_AGREEMENT_INTERFACE 0x00000004
216 #define BCRYPT_SIGNATURE_INTERFACE 0x00000005
217 #define BCRYPT_RNG_INTERFACE 0x00000006
218 #define BCRYPT_KEY_DERIVATION_INTERFACE 0x00000007
220 #define BCRYPT_SUPPORTED_PAD_ROUTER 0x00000001
221 #define BCRYPT_SUPPORTED_PAD_PKCS1_ENC 0x00000002
222 #define BCRYPT_SUPPORTED_PAD_PKCS1_SIG 0x00000004
223 #define BCRYPT_SUPPORTED_PAD_OAEP 0x00000008
224 #define BCRYPT_SUPPORTED_PAD_PSS 0x00000010
226 typedef struct _BCRYPT_ALGORITHM_IDENTIFIER
228 LPWSTR pszName;
229 ULONG dwClass;
230 ULONG dwFlags;
231 } BCRYPT_ALGORITHM_IDENTIFIER;
233 typedef struct __BCRYPT_KEY_LENGTHS_STRUCT
235 ULONG dwMinLength;
236 ULONG dwMaxLength;
237 ULONG dwIncrement;
238 } BCRYPT_KEY_LENGTHS_STRUCT, BCRYPT_AUTH_TAG_LENGTHS_STRUCT;
240 typedef struct _BCRYPT_AUTHENTICATED_CIPHER_MODE_INFO
242 ULONG cbSize;
243 ULONG dwInfoVersion;
244 UCHAR *pbNonce;
245 ULONG cbNonce;
246 UCHAR *pbAuthData;
247 ULONG cbAuthData;
248 UCHAR *pbTag;
249 ULONG cbTag;
250 UCHAR *pbMacContext;
251 ULONG cbMacContext;
252 ULONG cbAAD;
253 ULONGLONG cbData;
254 ULONG dwFlags;
255 } BCRYPT_AUTHENTICATED_CIPHER_MODE_INFO, *PBCRYPT_AUTHENTICATED_CIPHER_MODE_INFO;
257 typedef struct _BCRYPT_KEY_BLOB
259 ULONG Magic;
260 } BCRYPT_KEY_BLOB;
262 typedef struct _BCRYPT_ECCKEY_BLOB
264 ULONG dwMagic;
265 ULONG cbKey;
266 } BCRYPT_ECCKEY_BLOB, *PBCRYPT_ECCKEY_BLOB;
268 #define BCRYPT_RSAPUBLIC_MAGIC 0x31415352
269 #define BCRYPT_RSAPRIVATE_MAGIC 0x32415352
270 #define BCRYPT_RSAFULLPRIVATE_MAGIC 0x33415352
272 typedef struct _BCRYPT_RSAKEY_BLOB
274 ULONG Magic;
275 ULONG BitLength;
276 ULONG cbPublicExp;
277 ULONG cbModulus;
278 ULONG cbPrime1;
279 ULONG cbPrime2;
280 } BCRYPT_RSAKEY_BLOB;
282 typedef struct _BCRYPT_PKCS1_PADDING_INFO
284 LPCWSTR pszAlgId;
285 } BCRYPT_PKCS1_PADDING_INFO;
287 #define BCRYPT_PAD_NONE 0x00000001
288 #define BCRYPT_PAD_PKCS1 0x00000002
289 #define BCRYPT_PAD_OAEP 0x00000004
290 #define BCRYPT_PAD_PSS 0x00000008
291 #define BCRYPT_PAD_PKCS1_OPTIONAL_HASH_OID 0x00000010
293 #define BCRYPT_DSA_PUBLIC_MAGIC 0x42505344
294 #define BCRYPT_DSA_PRIVATE_MAGIC 0x56505344
296 typedef struct _BCRYPT_DSA_KEY_BLOB
298 ULONG dwMagic;
299 ULONG cbKey;
300 UCHAR Count[4];
301 UCHAR Seed[20];
302 UCHAR q[20];
303 } BCRYPT_DSA_KEY_BLOB, *PBCRYPT_DSA_KEY_BLOB;
305 #define BCRYPT_DSA_PUBLIC_MAGIC_V2 0x32425044
306 #define BCRYPT_DSA_PRIVATE_MAGIC_V2 0x32565044
308 typedef enum
310 DSA_HASH_ALGORITHM_SHA1,
311 DSA_HASH_ALGORITHM_SHA256,
312 DSA_HASH_ALGORITHM_SHA512
313 } HASHALGORITHM_ENUM;
315 typedef enum
317 DSA_FIPS186_2,
318 DSA_FIPS186_3
319 } DSAFIPSVERSION_ENUM;
321 typedef struct _BCRYPT_DSA_KEY_BLOB_V2
323 ULONG dwMagic;
324 ULONG cbKey;
325 HASHALGORITHM_ENUM hashAlgorithm;
326 DSAFIPSVERSION_ENUM standardVersion;
327 ULONG cbSeedLength;
328 ULONG cbGroupSize;
329 UCHAR Count[4];
330 } BCRYPT_DSA_KEY_BLOB_V2, *PBCRYPT_DSA_KEY_BLOB_V2;
332 #define BCRYPT_AUTHENTICATED_CIPHER_MODE_INFO_VERSION 1
334 #define BCRYPT_AUTH_MODE_CHAIN_CALLS_FLAG 0x00000001
335 #define BCRYPT_AUTH_MODE_IN_PROGRESS_FLAG 0x00000002
337 typedef struct _CRYPT_INTERFACE_REG
339 ULONG dwInterface;
340 ULONG dwFlags;
341 ULONG cFunctions;
342 PWSTR *rgpszFunctions;
343 } CRYPT_INTERFACE_REG, *PCRYPT_INTERFACE_REG;
345 typedef struct _CRYPT_IMAGE_REG
347 PWSTR pszImage;
348 ULONG cInterfaces;
349 PCRYPT_INTERFACE_REG *rgpInterfaces;
350 } CRYPT_IMAGE_REG, *PCRYPT_IMAGE_REG;
352 typedef struct _CRYPT_PROVIDER_REG
354 ULONG cAliases;
355 PWSTR *rgpszAliases;
356 PCRYPT_IMAGE_REG pUM;
357 PCRYPT_IMAGE_REG pKM;
358 } CRYPT_PROVIDER_REG, *PCRYPT_PROVIDER_REG;
360 typedef struct _BCRYPT_KEY_DATA_BLOB_HEADER
362 ULONG dwMagic;
363 ULONG dwVersion;
364 ULONG cbKeyData;
365 } BCRYPT_KEY_DATA_BLOB_HEADER, *PBCRYPT_KEY_DATA_BLOB_HEADER;
367 #define KDF_HASH_ALGORITHM 0x00000000
368 #define KDF_SECRET_PREPEND 0x00000001
369 #define KDF_SECRET_APPEND 0x00000002
371 typedef struct _BCryptBuffer
373 ULONG cbBuffer;
374 ULONG BufferType;
375 void *pvBuffer;
376 } BCryptBuffer, *PBCryptBuffer;
378 #define BCRYPTBUFFER_VERSION 0
380 typedef struct _BCryptBufferDesc
382 ULONG ulVersion;
383 ULONG cBuffers;
384 PBCryptBuffer pBuffers;
385 } BCryptBufferDesc, *PBCryptBufferDesc;
387 #define BCRYPT_KEY_DATA_BLOB_MAGIC 0x4d42444b
388 #define BCRYPT_KEY_DATA_BLOB_VERSION1 1
390 typedef PVOID BCRYPT_ALG_HANDLE;
391 typedef PVOID BCRYPT_KEY_HANDLE;
392 typedef PVOID BCRYPT_HANDLE;
393 typedef PVOID BCRYPT_HASH_HANDLE;
394 typedef PVOID BCRYPT_SECRET_HANDLE;
396 /* Flags for BCryptGenRandom */
397 #define BCRYPT_RNG_USE_ENTROPY_IN_BUFFER 0x00000001
398 #define BCRYPT_USE_SYSTEM_PREFERRED_RNG 0x00000002
400 /* Flags for BCryptOpenAlgorithmProvider */
401 #define BCRYPT_ALG_HANDLE_HMAC_FLAG 0x00000008
403 /* Flags for BCryptEncrypt/BCryptDecrypt */
404 #define BCRYPT_BLOCK_PADDING 0x00000001
406 /* Flags for BCryptCreateHash */
407 #define BCRYPT_HASH_REUSABLE_FLAG 0x00000020
409 #define CRYPT_LOCAL 0x00000001
410 #define CRYPT_DOMAIN 0x00000002
412 typedef struct _CRYPT_CONTEXT_FUNCTIONS
414 ULONG cFunctions;
415 WCHAR **rgpszFunctions;
416 } CRYPT_CONTEXT_FUNCTIONS, *PCRYPT_CONTEXT_FUNCTIONS;
418 NTSTATUS WINAPI BCryptAddContextFunction(ULONG, LPCWSTR, ULONG, LPCWSTR, ULONG);
419 NTSTATUS WINAPI BCryptCloseAlgorithmProvider(BCRYPT_ALG_HANDLE, ULONG);
420 NTSTATUS WINAPI BCryptCreateHash(BCRYPT_ALG_HANDLE, BCRYPT_HASH_HANDLE *, PUCHAR, ULONG, PUCHAR, ULONG, ULONG);
421 NTSTATUS WINAPI BCryptDecrypt(BCRYPT_KEY_HANDLE, PUCHAR, ULONG, VOID *, PUCHAR, ULONG, PUCHAR, ULONG, ULONG *, ULONG);
422 NTSTATUS WINAPI BCryptDeriveKey(BCRYPT_SECRET_HANDLE, LPCWSTR, BCryptBufferDesc*, PUCHAR, ULONG, ULONG *, ULONG);
423 NTSTATUS WINAPI BCryptDeriveKeyCapi(BCRYPT_HASH_HANDLE, BCRYPT_ALG_HANDLE, PUCHAR, ULONG, ULONG);
424 NTSTATUS WINAPI BCryptDeriveKeyPBKDF2(BCRYPT_ALG_HANDLE, PUCHAR, ULONG, PUCHAR, ULONG, ULONGLONG, PUCHAR, ULONG, ULONG);
425 NTSTATUS WINAPI BCryptDestroyHash(BCRYPT_HASH_HANDLE);
426 NTSTATUS WINAPI BCryptDestroyKey(BCRYPT_KEY_HANDLE);
427 NTSTATUS WINAPI BCryptDestroySecret(BCRYPT_SECRET_HANDLE);
428 NTSTATUS WINAPI BCryptDuplicateHash(BCRYPT_HASH_HANDLE, BCRYPT_HASH_HANDLE *, UCHAR *, ULONG, ULONG);
429 NTSTATUS WINAPI BCryptDuplicateKey(BCRYPT_KEY_HANDLE, BCRYPT_KEY_HANDLE *, PUCHAR, ULONG, ULONG);
430 NTSTATUS WINAPI BCryptEncrypt(BCRYPT_KEY_HANDLE, PUCHAR, ULONG, VOID *, PUCHAR, ULONG, PUCHAR, ULONG, ULONG *, ULONG);
431 NTSTATUS WINAPI BCryptEnumAlgorithms(ULONG, ULONG *, BCRYPT_ALGORITHM_IDENTIFIER **, ULONG);
432 NTSTATUS WINAPI BCryptEnumContextFunctions(ULONG, const WCHAR *, ULONG, ULONG *, CRYPT_CONTEXT_FUNCTIONS **);
433 NTSTATUS WINAPI BCryptExportKey(BCRYPT_KEY_HANDLE, BCRYPT_KEY_HANDLE, LPCWSTR, PUCHAR, ULONG, ULONG *, ULONG);
434 NTSTATUS WINAPI BCryptFinalizeKeyPair(BCRYPT_KEY_HANDLE, ULONG);
435 NTSTATUS WINAPI BCryptFinishHash(BCRYPT_HASH_HANDLE, PUCHAR, ULONG, ULONG);
436 void WINAPI BCryptFreeBuffer(void *);
437 NTSTATUS WINAPI BCryptGenRandom(BCRYPT_ALG_HANDLE, PUCHAR, ULONG, ULONG);
438 NTSTATUS WINAPI BCryptGenerateKeyPair(BCRYPT_ALG_HANDLE, BCRYPT_KEY_HANDLE *, ULONG, ULONG);
439 NTSTATUS WINAPI BCryptGenerateSymmetricKey(BCRYPT_ALG_HANDLE, BCRYPT_KEY_HANDLE *, PUCHAR, ULONG, PUCHAR, ULONG, ULONG);
440 NTSTATUS WINAPI BCryptGetFipsAlgorithmMode(BOOLEAN *);
441 NTSTATUS WINAPI BCryptGetProperty(BCRYPT_HANDLE, LPCWSTR, PUCHAR, ULONG, ULONG *, ULONG);
442 NTSTATUS WINAPI BCryptHash(BCRYPT_ALG_HANDLE, PUCHAR, ULONG, PUCHAR, ULONG, PUCHAR, ULONG);
443 NTSTATUS WINAPI BCryptHashData(BCRYPT_HASH_HANDLE, PUCHAR, ULONG, ULONG);
444 NTSTATUS WINAPI BCryptImportKey(BCRYPT_ALG_HANDLE, BCRYPT_KEY_HANDLE, LPCWSTR, BCRYPT_KEY_HANDLE *, PUCHAR, ULONG, PUCHAR, ULONG, ULONG);
445 NTSTATUS WINAPI BCryptImportKeyPair(BCRYPT_ALG_HANDLE, BCRYPT_KEY_HANDLE, LPCWSTR, BCRYPT_KEY_HANDLE *, UCHAR *, ULONG, ULONG);
446 NTSTATUS WINAPI BCryptOpenAlgorithmProvider(BCRYPT_ALG_HANDLE *, LPCWSTR, LPCWSTR, ULONG);
447 NTSTATUS WINAPI BCryptRemoveContextFunction(ULONG, LPCWSTR, ULONG, LPCWSTR);
448 NTSTATUS WINAPI BCryptSecretAgreement(BCRYPT_KEY_HANDLE, BCRYPT_KEY_HANDLE, BCRYPT_SECRET_HANDLE *, ULONG);
449 NTSTATUS WINAPI BCryptSetProperty(BCRYPT_HANDLE, LPCWSTR, PUCHAR, ULONG, ULONG);
450 NTSTATUS WINAPI BCryptSignHash(BCRYPT_KEY_HANDLE, void *, PUCHAR, ULONG, PUCHAR, ULONG, ULONG *, ULONG);
451 NTSTATUS WINAPI BCryptVerifySignature(BCRYPT_KEY_HANDLE, void *, UCHAR *, ULONG, UCHAR *, ULONG, ULONG);
453 #endif /* __WINE_BCRYPT_H */