| // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CRYPTO_CAPI_UTIL_H_ |
| #define CRYPTO_CAPI_UTIL_H_ |
| |
| #include <windows.h> |
| #include <wincrypt.h> |
| |
| #include "crypto/crypto_export.h" |
| |
| namespace crypto { |
| |
| // CryptAcquireContext when passed CRYPT_NEWKEYSET or CRYPT_DELETEKEYSET in |
| // flags is not thread-safe. For such calls, we create a global lock to |
| // synchronize it. |
| // |
| // From "Threading Issues with Cryptographic Service Providers", |
| // <http://msdn.microsoft.com/en-us/library/aa388149(v=VS.85).aspx>: |
| // |
| // "The CryptAcquireContext function is generally thread safe unless |
| // CRYPT_NEWKEYSET or CRYPT_DELETEKEYSET is specified in the dwFlags |
| // parameter." |
| CRYPTO_EXPORT BOOL CryptAcquireContextLocked(HCRYPTPROV* prov, |
| LPCWSTR container, |
| LPCWSTR provider, |
| DWORD prov_type, |
| DWORD flags); |
| |
| // Wrappers of malloc and free for CryptoAPI routines that need memory |
| // allocators, such as in CRYPT_DECODE_PARA. Such routines require WINAPI |
| // calling conventions. |
| CRYPTO_EXPORT void* WINAPI CryptAlloc(size_t size); |
| CRYPTO_EXPORT void WINAPI CryptFree(void* p); |
| |
| } // namespace crypto |
| |
| #endif // CRYPTO_CAPI_UTIL_H_ |