Leaked source code of windows server 2003
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
//+-------------------------------------------------------------------------
// Microsoft Windows
//
// Copyright (C) Microsoft Corporation, 1996 - 1999
//
// File: pkialloc.h
//
// Contents: PKI Allocation Functions
//
// APIs:
// PkiAlloc
//
// History: 19-Jan-98 philh created
//--------------------------------------------------------------------------
#ifndef __PKIALLOC_H__
#define __PKIALLOC_H__
#include <wincrypt.h>
#ifdef __cplusplus
extern "C" { #endif
//+-------------------------------------------------------------------------
// The following functions use the 'C' runtime's allocation functions
// when DBG is defined. Otherwise, use LocalAlloc, LocalReAlloc or
// LocalFree Win32 APIs.
//--------------------------------------------------------------------------
// Calls malloc when DBG is defined. Otherwise, does a
// ZEROINIT LocalAlloc.
LPVOID WINAPI PkiAlloc( IN size_t cbBytes );
// Calls malloc and does a memory clear when DBG is defined.
// Otherwise, does a ZEROINIT LocalAlloc.
LPVOID WINAPI PkiZeroAlloc( IN size_t cbBytes );
// Calls malloc when DBG is defined. Otherwise, does a
// LocalAlloc without ZEOINIT.
LPVOID WINAPI PkiNonzeroAlloc( IN size_t cbBytes );
LPVOID WINAPI PkiRealloc( IN LPVOID pvOrg, IN size_t cbBytes );
VOID WINAPI PkiFree( IN LPVOID pv );
//+-------------------------------------------------------------------------
// The following functions always use LocalAlloc and LocalFree Win32 APIs.
//--------------------------------------------------------------------------
LPVOID WINAPI PkiDefaultCryptAlloc( IN size_t cbSize ); VOID WINAPI PkiDefaultCryptFree( IN LPVOID pv );
//+-------------------------------------------------------------------------
// The following data structure's pfnAlloc and pfnFree are set to
// PkiNonzeroAlloc and PkiFree.
//--------------------------------------------------------------------------
extern CRYPT_ENCODE_PARA PkiEncodePara;
//+-------------------------------------------------------------------------
// If pfnAlloc isn't defined, returns PkiDefaultCryptAlloc
//--------------------------------------------------------------------------
PFN_CRYPT_ALLOC WINAPI PkiGetEncodeAllocFunction( IN OPTIONAL PCRYPT_ENCODE_PARA pEncodePara );
//+-------------------------------------------------------------------------
// If pfnFree isn't defined, returns PkiDefaultCryptFree
//--------------------------------------------------------------------------
PFN_CRYPT_FREE WINAPI PkiGetEncodeFreeFunction( IN OPTIONAL PCRYPT_ENCODE_PARA pEncodePara );
//+-------------------------------------------------------------------------
// The following data structure's pfnAlloc and pfnFree are set to
// PkiNonzeroAlloc and PkiFree.
//--------------------------------------------------------------------------
extern CRYPT_DECODE_PARA PkiDecodePara;
//+-------------------------------------------------------------------------
// If pfnAlloc isn't defined, returns PkiDefaultCryptAlloc
//--------------------------------------------------------------------------
PFN_CRYPT_ALLOC WINAPI PkiGetDecodeAllocFunction( IN OPTIONAL PCRYPT_DECODE_PARA pDecodePara );
//+-------------------------------------------------------------------------
// If pfnFree isn't defined, returns PkiDefaultCryptFree
//--------------------------------------------------------------------------
PFN_CRYPT_FREE WINAPI PkiGetDecodeFreeFunction( IN OPTIONAL PCRYPT_DECODE_PARA pDecodePara );
#ifdef __cplusplus
} // Balance extern "C" above
#endif
#endif
|