michael@0: /* michael@0: * loader.h - load platform dependent DSO containing freebl implementation. michael@0: * michael@0: * This Source Code Form is subject to the terms of the Mozilla Public michael@0: * License, v. 2.0. If a copy of the MPL was not distributed with this michael@0: * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ michael@0: michael@0: #ifndef _LOADER_H_ michael@0: #define _LOADER_H_ 1 michael@0: michael@0: #include "blapi.h" michael@0: michael@0: #define FREEBL_VERSION 0x0311 michael@0: michael@0: struct FREEBLVectorStr { michael@0: michael@0: unsigned short length; /* of this struct in bytes */ michael@0: unsigned short version; /* of this struct. */ michael@0: michael@0: RSAPrivateKey * (* p_RSA_NewKey)(int keySizeInBits, michael@0: SECItem * publicExponent); michael@0: michael@0: SECStatus (* p_RSA_PublicKeyOp) (RSAPublicKey * key, michael@0: unsigned char * output, michael@0: const unsigned char * input); michael@0: michael@0: SECStatus (* p_RSA_PrivateKeyOp)(RSAPrivateKey * key, michael@0: unsigned char * output, michael@0: const unsigned char * input); michael@0: michael@0: SECStatus (* p_DSA_NewKey)(const PQGParams * params, michael@0: DSAPrivateKey ** privKey); michael@0: michael@0: SECStatus (* p_DSA_SignDigest)(DSAPrivateKey * key, michael@0: SECItem * signature, michael@0: const SECItem * digest); michael@0: michael@0: SECStatus (* p_DSA_VerifyDigest)(DSAPublicKey * key, michael@0: const SECItem * signature, michael@0: const SECItem * digest); michael@0: michael@0: SECStatus (* p_DSA_NewKeyFromSeed)(const PQGParams *params, michael@0: const unsigned char * seed, michael@0: DSAPrivateKey **privKey); michael@0: michael@0: SECStatus (* p_DSA_SignDigestWithSeed)(DSAPrivateKey * key, michael@0: SECItem * signature, michael@0: const SECItem * digest, michael@0: const unsigned char * seed); michael@0: michael@0: SECStatus (* p_DH_GenParam)(int primeLen, DHParams ** params); michael@0: michael@0: SECStatus (* p_DH_NewKey)(DHParams * params, michael@0: DHPrivateKey ** privKey); michael@0: michael@0: SECStatus (* p_DH_Derive)(SECItem * publicValue, michael@0: SECItem * prime, michael@0: SECItem * privateValue, michael@0: SECItem * derivedSecret, michael@0: unsigned int maxOutBytes); michael@0: michael@0: SECStatus (* p_KEA_Derive)(SECItem *prime, michael@0: SECItem *public1, michael@0: SECItem *public2, michael@0: SECItem *private1, michael@0: SECItem *private2, michael@0: SECItem *derivedSecret); michael@0: michael@0: PRBool (* p_KEA_Verify)(SECItem *Y, SECItem *prime, SECItem *subPrime); michael@0: michael@0: RC4Context * (* p_RC4_CreateContext)(const unsigned char *key, int len); michael@0: michael@0: void (* p_RC4_DestroyContext)(RC4Context *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_RC4_Encrypt)(RC4Context *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_RC4_Decrypt)(RC4Context *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: RC2Context * (* p_RC2_CreateContext)(const unsigned char *key, michael@0: unsigned int len, const unsigned char *iv, michael@0: int mode, unsigned effectiveKeyLen); michael@0: michael@0: void (* p_RC2_DestroyContext)(RC2Context *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_RC2_Encrypt)(RC2Context *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_RC2_Decrypt)(RC2Context *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: RC5Context *(* p_RC5_CreateContext)(const SECItem *key, unsigned int rounds, michael@0: unsigned int wordSize, const unsigned char *iv, int mode); michael@0: michael@0: void (* p_RC5_DestroyContext)(RC5Context *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_RC5_Encrypt)(RC5Context *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_RC5_Decrypt)(RC5Context *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: DESContext *(* p_DES_CreateContext)(const unsigned char *key, michael@0: const unsigned char *iv, michael@0: int mode, PRBool encrypt); michael@0: michael@0: void (* p_DES_DestroyContext)(DESContext *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_DES_Encrypt)(DESContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_DES_Decrypt)(DESContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: AESContext * (* p_AES_CreateContext)(const unsigned char *key, michael@0: const unsigned char *iv, michael@0: int mode, int encrypt, unsigned int keylen, michael@0: unsigned int blocklen); michael@0: michael@0: void (* p_AES_DestroyContext)(AESContext *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_AES_Encrypt)(AESContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_AES_Decrypt)(AESContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_MD5_Hash)(unsigned char *dest, const char *src); michael@0: michael@0: SECStatus (* p_MD5_HashBuf)(unsigned char *dest, const unsigned char *src, michael@0: PRUint32 src_length); michael@0: michael@0: MD5Context *(* p_MD5_NewContext)(void); michael@0: michael@0: void (* p_MD5_DestroyContext)(MD5Context *cx, PRBool freeit); michael@0: michael@0: void (* p_MD5_Begin)(MD5Context *cx); michael@0: michael@0: void (* p_MD5_Update)(MD5Context *cx, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: void (* p_MD5_End)(MD5Context *cx, unsigned char *digest, michael@0: unsigned int *digestLen, unsigned int maxDigestLen); michael@0: michael@0: unsigned int (* p_MD5_FlattenSize)(MD5Context *cx); michael@0: michael@0: SECStatus (* p_MD5_Flatten)(MD5Context *cx,unsigned char *space); michael@0: michael@0: MD5Context * (* p_MD5_Resurrect)(unsigned char *space, void *arg); michael@0: michael@0: void (* p_MD5_TraceState)(MD5Context *cx); michael@0: michael@0: SECStatus (* p_MD2_Hash)(unsigned char *dest, const char *src); michael@0: michael@0: MD2Context *(* p_MD2_NewContext)(void); michael@0: michael@0: void (* p_MD2_DestroyContext)(MD2Context *cx, PRBool freeit); michael@0: michael@0: void (* p_MD2_Begin)(MD2Context *cx); michael@0: michael@0: void (* p_MD2_Update)(MD2Context *cx, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: void (* p_MD2_End)(MD2Context *cx, unsigned char *digest, michael@0: unsigned int *digestLen, unsigned int maxDigestLen); michael@0: michael@0: unsigned int (* p_MD2_FlattenSize)(MD2Context *cx); michael@0: michael@0: SECStatus (* p_MD2_Flatten)(MD2Context *cx,unsigned char *space); michael@0: michael@0: MD2Context * (* p_MD2_Resurrect)(unsigned char *space, void *arg); michael@0: michael@0: SECStatus (* p_SHA1_Hash)(unsigned char *dest, const char *src); michael@0: michael@0: SECStatus (* p_SHA1_HashBuf)(unsigned char *dest, const unsigned char *src, michael@0: PRUint32 src_length); michael@0: michael@0: SHA1Context *(* p_SHA1_NewContext)(void); michael@0: michael@0: void (* p_SHA1_DestroyContext)(SHA1Context *cx, PRBool freeit); michael@0: michael@0: void (* p_SHA1_Begin)(SHA1Context *cx); michael@0: michael@0: void (* p_SHA1_Update)(SHA1Context *cx, const unsigned char *input, michael@0: unsigned int inputLen); michael@0: michael@0: void (* p_SHA1_End)(SHA1Context *cx, unsigned char *digest, michael@0: unsigned int *digestLen, unsigned int maxDigestLen); michael@0: michael@0: void (* p_SHA1_TraceState)(SHA1Context *cx); michael@0: michael@0: unsigned int (* p_SHA1_FlattenSize)(SHA1Context *cx); michael@0: michael@0: SECStatus (* p_SHA1_Flatten)(SHA1Context *cx,unsigned char *space); michael@0: michael@0: SHA1Context * (* p_SHA1_Resurrect)(unsigned char *space, void *arg); michael@0: michael@0: SECStatus (* p_RNG_RNGInit)(void); michael@0: michael@0: SECStatus (* p_RNG_RandomUpdate)(const void *data, size_t bytes); michael@0: michael@0: SECStatus (* p_RNG_GenerateGlobalRandomBytes)(void *dest, size_t len); michael@0: michael@0: void (* p_RNG_RNGShutdown)(void); michael@0: michael@0: SECStatus (* p_PQG_ParamGen)(unsigned int j, PQGParams **pParams, michael@0: PQGVerify **pVfy); michael@0: michael@0: SECStatus (* p_PQG_ParamGenSeedLen)( unsigned int j, unsigned int seedBytes, michael@0: PQGParams **pParams, PQGVerify **pVfy); michael@0: michael@0: SECStatus (* p_PQG_VerifyParams)(const PQGParams *params, michael@0: const PQGVerify *vfy, SECStatus *result); michael@0: michael@0: /* Version 3.001 came to here */ michael@0: michael@0: SECStatus (* p_RSA_PrivateKeyOpDoubleChecked)(RSAPrivateKey *key, michael@0: unsigned char *output, michael@0: const unsigned char *input); michael@0: michael@0: SECStatus (* p_RSA_PrivateKeyCheck)(const RSAPrivateKey *key); michael@0: michael@0: void (* p_BL_Cleanup)(void); michael@0: michael@0: /* Version 3.002 came to here */ michael@0: michael@0: SHA256Context *(* p_SHA256_NewContext)(void); michael@0: void (* p_SHA256_DestroyContext)(SHA256Context *cx, PRBool freeit); michael@0: void (* p_SHA256_Begin)(SHA256Context *cx); michael@0: void (* p_SHA256_Update)(SHA256Context *cx, const unsigned char *input, michael@0: unsigned int inputLen); michael@0: void (* p_SHA256_End)(SHA256Context *cx, unsigned char *digest, michael@0: unsigned int *digestLen, unsigned int maxDigestLen); michael@0: SECStatus (* p_SHA256_HashBuf)(unsigned char *dest, const unsigned char *src, michael@0: PRUint32 src_length); michael@0: SECStatus (* p_SHA256_Hash)(unsigned char *dest, const char *src); michael@0: void (* p_SHA256_TraceState)(SHA256Context *cx); michael@0: unsigned int (* p_SHA256_FlattenSize)(SHA256Context *cx); michael@0: SECStatus (* p_SHA256_Flatten)(SHA256Context *cx,unsigned char *space); michael@0: SHA256Context * (* p_SHA256_Resurrect)(unsigned char *space, void *arg); michael@0: michael@0: SHA512Context *(* p_SHA512_NewContext)(void); michael@0: void (* p_SHA512_DestroyContext)(SHA512Context *cx, PRBool freeit); michael@0: void (* p_SHA512_Begin)(SHA512Context *cx); michael@0: void (* p_SHA512_Update)(SHA512Context *cx, const unsigned char *input, michael@0: unsigned int inputLen); michael@0: void (* p_SHA512_End)(SHA512Context *cx, unsigned char *digest, michael@0: unsigned int *digestLen, unsigned int maxDigestLen); michael@0: SECStatus (* p_SHA512_HashBuf)(unsigned char *dest, const unsigned char *src, michael@0: PRUint32 src_length); michael@0: SECStatus (* p_SHA512_Hash)(unsigned char *dest, const char *src); michael@0: void (* p_SHA512_TraceState)(SHA512Context *cx); michael@0: unsigned int (* p_SHA512_FlattenSize)(SHA512Context *cx); michael@0: SECStatus (* p_SHA512_Flatten)(SHA512Context *cx,unsigned char *space); michael@0: SHA512Context * (* p_SHA512_Resurrect)(unsigned char *space, void *arg); michael@0: michael@0: SHA384Context *(* p_SHA384_NewContext)(void); michael@0: void (* p_SHA384_DestroyContext)(SHA384Context *cx, PRBool freeit); michael@0: void (* p_SHA384_Begin)(SHA384Context *cx); michael@0: void (* p_SHA384_Update)(SHA384Context *cx, const unsigned char *input, michael@0: unsigned int inputLen); michael@0: void (* p_SHA384_End)(SHA384Context *cx, unsigned char *digest, michael@0: unsigned int *digestLen, unsigned int maxDigestLen); michael@0: SECStatus (* p_SHA384_HashBuf)(unsigned char *dest, const unsigned char *src, michael@0: PRUint32 src_length); michael@0: SECStatus (* p_SHA384_Hash)(unsigned char *dest, const char *src); michael@0: void (* p_SHA384_TraceState)(SHA384Context *cx); michael@0: unsigned int (* p_SHA384_FlattenSize)(SHA384Context *cx); michael@0: SECStatus (* p_SHA384_Flatten)(SHA384Context *cx,unsigned char *space); michael@0: SHA384Context * (* p_SHA384_Resurrect)(unsigned char *space, void *arg); michael@0: michael@0: /* Version 3.003 came to here */ michael@0: michael@0: AESKeyWrapContext * (* p_AESKeyWrap_CreateContext)(const unsigned char *key, michael@0: const unsigned char *iv, int encrypt, unsigned int keylen); michael@0: michael@0: void (* p_AESKeyWrap_DestroyContext)(AESKeyWrapContext *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_AESKeyWrap_Encrypt)(AESKeyWrapContext *cx, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_AESKeyWrap_Decrypt)(AESKeyWrapContext *cx, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: /* Version 3.004 came to here */ michael@0: michael@0: PRBool (*p_BLAPI_SHVerify)(const char *name, PRFuncPtr addr); michael@0: PRBool (*p_BLAPI_VerifySelf)(const char *name); michael@0: michael@0: /* Version 3.005 came to here */ michael@0: michael@0: SECStatus (* p_EC_NewKey)(ECParams * params, michael@0: ECPrivateKey ** privKey); michael@0: michael@0: SECStatus (* p_EC_NewKeyFromSeed)(ECParams * params, michael@0: ECPrivateKey ** privKey, michael@0: const unsigned char * seed, michael@0: int seedlen); michael@0: michael@0: SECStatus (* p_EC_ValidatePublicKey)(ECParams * params, michael@0: SECItem * publicValue); michael@0: michael@0: SECStatus (* p_ECDH_Derive)(SECItem * publicValue, michael@0: ECParams * params, michael@0: SECItem * privateValue, michael@0: PRBool withCofactor, michael@0: SECItem * derivedSecret); michael@0: michael@0: SECStatus (* p_ECDSA_SignDigest)(ECPrivateKey * key, michael@0: SECItem * signature, michael@0: const SECItem * digest); michael@0: michael@0: SECStatus (* p_ECDSA_VerifyDigest)(ECPublicKey * key, michael@0: const SECItem * signature, michael@0: const SECItem * digest); michael@0: michael@0: SECStatus (* p_ECDSA_SignDigestWithSeed)(ECPrivateKey * key, michael@0: SECItem * signature, michael@0: const SECItem * digest, michael@0: const unsigned char * seed, michael@0: const int seedlen); michael@0: michael@0: /* Version 3.006 came to here */ michael@0: michael@0: /* no modification to FREEBLVectorStr itself michael@0: * but ECParamStr was modified michael@0: */ michael@0: michael@0: /* Version 3.007 came to here */ michael@0: michael@0: SECStatus (* p_AES_InitContext)(AESContext *cx, michael@0: const unsigned char *key, michael@0: unsigned int keylen, michael@0: const unsigned char *iv, michael@0: int mode, michael@0: unsigned int encrypt, michael@0: unsigned int blocklen); michael@0: SECStatus (* p_AESKeyWrap_InitContext)(AESKeyWrapContext *cx, michael@0: const unsigned char *key, michael@0: unsigned int keylen, michael@0: const unsigned char *iv, michael@0: int mode, michael@0: unsigned int encrypt, michael@0: unsigned int blocklen); michael@0: SECStatus (* p_DES_InitContext)(DESContext *cx, michael@0: const unsigned char *key, michael@0: unsigned int keylen, michael@0: const unsigned char *iv, michael@0: int mode, michael@0: unsigned int encrypt, michael@0: unsigned int ); michael@0: SECStatus (* p_RC2_InitContext)(RC2Context *cx, michael@0: const unsigned char *key, michael@0: unsigned int keylen, michael@0: const unsigned char *iv, michael@0: int mode, michael@0: unsigned int effectiveKeyLen, michael@0: unsigned int ); michael@0: SECStatus (* p_RC4_InitContext)(RC4Context *cx, michael@0: const unsigned char *key, michael@0: unsigned int keylen, michael@0: const unsigned char *, michael@0: int, michael@0: unsigned int , michael@0: unsigned int ); michael@0: michael@0: AESContext *(*p_AES_AllocateContext)(void); michael@0: AESKeyWrapContext *(*p_AESKeyWrap_AllocateContext)(void); michael@0: DESContext *(*p_DES_AllocateContext)(void); michael@0: RC2Context *(*p_RC2_AllocateContext)(void); michael@0: RC4Context *(*p_RC4_AllocateContext)(void); michael@0: michael@0: void (* p_MD2_Clone)(MD2Context *dest, MD2Context *src); michael@0: void (* p_MD5_Clone)(MD5Context *dest, MD5Context *src); michael@0: void (* p_SHA1_Clone)(SHA1Context *dest, SHA1Context *src); michael@0: void (* p_SHA256_Clone)(SHA256Context *dest, SHA256Context *src); michael@0: void (* p_SHA384_Clone)(SHA384Context *dest, SHA384Context *src); michael@0: void (* p_SHA512_Clone)(SHA512Context *dest, SHA512Context *src); michael@0: michael@0: SECStatus (* p_TLS_PRF)(const SECItem *secret, const char *label, michael@0: SECItem *seed, SECItem *result, PRBool isFIPS); michael@0: michael@0: const SECHashObject *(* p_HASH_GetRawHashObject)(HASH_HashType hashType); michael@0: michael@0: HMACContext * (* p_HMAC_Create)(const SECHashObject *hashObj, michael@0: const unsigned char *secret, michael@0: unsigned int secret_len, PRBool isFIPS); michael@0: SECStatus (* p_HMAC_Init)(HMACContext *cx, const SECHashObject *hash_obj, michael@0: const unsigned char *secret, michael@0: unsigned int secret_len, PRBool isFIPS); michael@0: void (* p_HMAC_Begin)(HMACContext *cx); michael@0: void (* p_HMAC_Update)(HMACContext *cx, const unsigned char *data, michael@0: unsigned int data_len); michael@0: HMACContext * (* p_HMAC_Clone)(HMACContext *cx); michael@0: SECStatus (* p_HMAC_Finish)(HMACContext *cx, unsigned char *result, michael@0: unsigned int *result_len, michael@0: unsigned int max_result_len); michael@0: void (* p_HMAC_Destroy)(HMACContext *cx, PRBool freeit); michael@0: michael@0: void (* p_RNG_SystemInfoForRNG)(void); michael@0: michael@0: /* Version 3.008 came to here */ michael@0: michael@0: SECStatus (* p_FIPS186Change_GenerateX)(unsigned char *XKEY, michael@0: const unsigned char *XSEEDj, michael@0: unsigned char *x_j); michael@0: SECStatus (* p_FIPS186Change_ReduceModQForDSA)(const unsigned char *w, michael@0: const unsigned char *q, michael@0: unsigned char *xj); michael@0: michael@0: /* Version 3.009 came to here */ michael@0: michael@0: SECStatus (* p_Camellia_InitContext)(CamelliaContext *cx, michael@0: const unsigned char *key, michael@0: unsigned int keylen, michael@0: const unsigned char *iv, michael@0: int mode, michael@0: unsigned int encrypt, michael@0: unsigned int unused); michael@0: michael@0: CamelliaContext *(*p_Camellia_AllocateContext)(void); michael@0: CamelliaContext * (* p_Camellia_CreateContext)(const unsigned char *key, michael@0: const unsigned char *iv, michael@0: int mode, int encrypt, michael@0: unsigned int keylen); michael@0: void (* p_Camellia_DestroyContext)(CamelliaContext *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_Camellia_Encrypt)(CamelliaContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: michael@0: SECStatus (* p_Camellia_Decrypt)(CamelliaContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: michael@0: void (* p_PQG_DestroyParams)(PQGParams *params); michael@0: michael@0: void (* p_PQG_DestroyVerify)(PQGVerify *vfy); michael@0: michael@0: /* Version 3.010 came to here */ michael@0: michael@0: SECStatus (* p_SEED_InitContext)(SEEDContext *cx, michael@0: const unsigned char *key, michael@0: unsigned int keylen, michael@0: const unsigned char *iv, michael@0: int mode, michael@0: unsigned int encrypt, michael@0: unsigned int ); michael@0: michael@0: SEEDContext *(*p_SEED_AllocateContext)(void); michael@0: michael@0: SEEDContext *(* p_SEED_CreateContext)(const unsigned char *key, michael@0: const unsigned char *iv, michael@0: int mode, PRBool encrypt); michael@0: michael@0: void (* p_SEED_DestroyContext)(SEEDContext *cx, PRBool freeit); michael@0: michael@0: SECStatus (* p_SEED_Encrypt)(SEEDContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: SECStatus (* p_SEED_Decrypt)(SEEDContext *cx, unsigned char *output, michael@0: unsigned int *outputLen, unsigned int maxOutputLen, michael@0: const unsigned char *input, unsigned int inputLen); michael@0: michael@0: michael@0: michael@0: SECStatus (* p_BL_Init)(void); michael@0: void ( * p_BL_SetForkState)(PRBool); michael@0: michael@0: SECStatus (* p_PRNGTEST_Instantiate)(const PRUint8 *entropy, michael@0: unsigned int entropy_len, michael@0: const PRUint8 *nonce, michael@0: unsigned int nonce_len, michael@0: const PRUint8 *personal_string, michael@0: unsigned int ps_len); michael@0: michael@0: SECStatus (* p_PRNGTEST_Reseed)(const PRUint8 *entropy, michael@0: unsigned int entropy_len, michael@0: const PRUint8 *additional, michael@0: unsigned int additional_len); michael@0: michael@0: SECStatus (* p_PRNGTEST_Generate)(PRUint8 *bytes, michael@0: unsigned int bytes_len, michael@0: const PRUint8 *additional, michael@0: unsigned int additional_len); michael@0: michael@0: SECStatus (* p_PRNGTEST_Uninstantiate)(void); michael@0: /* Version 3.011 came to here */ michael@0: michael@0: SECStatus (*p_RSA_PopulatePrivateKey)(RSAPrivateKey *key); michael@0: michael@0: SECStatus (*p_DSA_NewRandom)(PLArenaPool * arena, const SECItem * q, michael@0: SECItem * seed); michael@0: michael@0: SECStatus (*p_JPAKE_Sign)(PLArenaPool * arena, const PQGParams * pqg, michael@0: HASH_HashType hashType, const SECItem * signerID, michael@0: const SECItem * x, const SECItem * testRandom, michael@0: const SECItem * gxIn, SECItem * gxOut, michael@0: SECItem * gv, SECItem * r); michael@0: michael@0: SECStatus (*p_JPAKE_Verify)(PLArenaPool * arena, const PQGParams * pqg, michael@0: HASH_HashType hashType, const SECItem * signerID, michael@0: const SECItem * peerID, const SECItem * gx, michael@0: const SECItem * gv, const SECItem * r); michael@0: michael@0: SECStatus (*p_JPAKE_Round2)(PLArenaPool * arena, const SECItem * p, michael@0: const SECItem *q, const SECItem * gx1, michael@0: const SECItem * gx3, const SECItem * gx4, michael@0: SECItem * base, const SECItem * x2, michael@0: const SECItem * s, SECItem * x2s); michael@0: michael@0: SECStatus (*p_JPAKE_Final)(PLArenaPool * arena, const SECItem * p, michael@0: const SECItem *q, const SECItem * x2, michael@0: const SECItem * gx4, const SECItem * x2s, michael@0: const SECItem * B, SECItem * K); michael@0: michael@0: /* Version 3.012 came to here */ michael@0: michael@0: SECStatus (* p_TLS_P_hash)(HASH_HashType hashAlg, michael@0: const SECItem *secret, michael@0: const char *label, michael@0: SECItem *seed, michael@0: SECItem *result, michael@0: PRBool isFIPS); michael@0: michael@0: SHA224Context *(*p_SHA224_NewContext)(void); michael@0: void (* p_SHA224_DestroyContext)(SHA224Context *cx, PRBool freeit); michael@0: void (* p_SHA224_Begin)(SHA224Context *cx); michael@0: void (* p_SHA224_Update)(SHA224Context *cx, const unsigned char *input, michael@0: unsigned int inputLen); michael@0: void (* p_SHA224_End)(SHA224Context *cx, unsigned char *digest, michael@0: unsigned int *digestLen, unsigned int maxDigestLen); michael@0: SECStatus (*p_SHA224_HashBuf)(unsigned char *dest, const unsigned char *src, michael@0: PRUint32 src_length); michael@0: SECStatus (*p_SHA224_Hash)(unsigned char *dest, const char *src); michael@0: void (*p_SHA224_TraceState)(SHA224Context *cx); michael@0: unsigned int (* p_SHA224_FlattenSize)(SHA224Context *cx); michael@0: SECStatus (* p_SHA224_Flatten)(SHA224Context *cx,unsigned char *space); michael@0: SHA224Context * (* p_SHA224_Resurrect)(unsigned char *space, void *arg); michael@0: void (* p_SHA224_Clone)(SHA224Context *dest, SHA224Context *src); michael@0: PRBool (*p_BLAPI_SHVerifyFile)(const char *name); michael@0: michael@0: /* Version 3.013 came to here */ michael@0: michael@0: SECStatus (* p_PQG_ParamGenV2)( unsigned int L, unsigned int N, michael@0: unsigned int seedBytes, michael@0: PQGParams **pParams, PQGVerify **pVfy); michael@0: SECStatus (*p_PRNGTEST_RunHealthTests)(void); michael@0: michael@0: /* Version 3.014 came to here */ michael@0: michael@0: SECStatus (* p_HMAC_ConstantTime)( michael@0: unsigned char *result, michael@0: unsigned int *resultLen, michael@0: unsigned int maxResultLen, michael@0: const SECHashObject *hashObj, michael@0: const unsigned char *secret, michael@0: unsigned int secretLen, michael@0: const unsigned char *header, michael@0: unsigned int headerLen, michael@0: const unsigned char *body, michael@0: unsigned int bodyLen, michael@0: unsigned int bodyTotalLen); michael@0: michael@0: SECStatus (* p_SSLv3_MAC_ConstantTime)( michael@0: unsigned char *result, michael@0: unsigned int *resultLen, michael@0: unsigned int maxResultLen, michael@0: const SECHashObject *hashObj, michael@0: const unsigned char *secret, michael@0: unsigned int secretLen, michael@0: const unsigned char *header, michael@0: unsigned int headerLen, michael@0: const unsigned char *body, michael@0: unsigned int bodyLen, michael@0: unsigned int bodyTotalLen); michael@0: michael@0: /* Version 3.015 came to here */ michael@0: michael@0: SECStatus (* p_RSA_SignRaw)(RSAPrivateKey *key, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_CheckSignRaw)(RSAPublicKey *key, michael@0: const unsigned char *sig, michael@0: unsigned int sigLen, michael@0: const unsigned char *hash, michael@0: unsigned int hashLen); michael@0: SECStatus (* p_RSA_CheckSignRecoverRaw)(RSAPublicKey *key, michael@0: unsigned char *data, michael@0: unsigned int *dataLen, michael@0: unsigned int maxDataLen, michael@0: const unsigned char *sig, michael@0: unsigned int sigLen); michael@0: SECStatus (* p_RSA_EncryptRaw)(RSAPublicKey *key, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_DecryptRaw)(RSAPrivateKey *key, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_EncryptOAEP)(RSAPublicKey *key, michael@0: HASH_HashType hashAlg, michael@0: HASH_HashType maskHashAlg, michael@0: const unsigned char *label, michael@0: unsigned int labelLen, michael@0: const unsigned char *seed, michael@0: unsigned int seedLen, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_DecryptOAEP)(RSAPrivateKey *key, michael@0: HASH_HashType hashAlg, michael@0: HASH_HashType maskHashAlg, michael@0: const unsigned char *label, michael@0: unsigned int labelLen, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_EncryptBlock)(RSAPublicKey *key, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_DecryptBlock)(RSAPrivateKey *key, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_SignPSS)(RSAPrivateKey *key, michael@0: HASH_HashType hashAlg, michael@0: HASH_HashType maskHashAlg, michael@0: const unsigned char *salt, michael@0: unsigned int saltLen, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_CheckSignPSS)(RSAPublicKey *key, michael@0: HASH_HashType hashAlg, michael@0: HASH_HashType maskHashAlg, michael@0: unsigned int saltLen, michael@0: const unsigned char *sig, michael@0: unsigned int sigLen, michael@0: const unsigned char *hash, michael@0: unsigned int hashLen); michael@0: SECStatus (* p_RSA_Sign)(RSAPrivateKey *key, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *input, michael@0: unsigned int inputLen); michael@0: SECStatus (* p_RSA_CheckSign)(RSAPublicKey *key, michael@0: const unsigned char *sig, michael@0: unsigned int sigLen, michael@0: const unsigned char *data, michael@0: unsigned int dataLen); michael@0: SECStatus (* p_RSA_CheckSignRecover)(RSAPublicKey *key, michael@0: unsigned char *output, michael@0: unsigned int *outputLen, michael@0: unsigned int maxOutputLen, michael@0: const unsigned char *sig, michael@0: unsigned int sigLen); michael@0: michael@0: /* Version 3.016 came to here */ michael@0: michael@0: SECStatus (* p_EC_FillParams)(PLArenaPool *arena, michael@0: const SECItem *encodedParams, ECParams *params); michael@0: SECStatus (* p_EC_DecodeParams)(const SECItem *encodedParams, michael@0: ECParams **ecparams); michael@0: SECStatus (* p_EC_CopyParams)(PLArenaPool *arena, ECParams *dstParams, michael@0: const ECParams *srcParams); michael@0: michael@0: /* Version 3.017 came to here */ michael@0: michael@0: /* Add new function pointers at the end of this struct and bump michael@0: * FREEBL_VERSION at the beginning of this file. */ michael@0: }; michael@0: michael@0: typedef struct FREEBLVectorStr FREEBLVector; michael@0: michael@0: SEC_BEGIN_PROTOS michael@0: michael@0: typedef const FREEBLVector * FREEBLGetVectorFn(void); michael@0: michael@0: extern FREEBLGetVectorFn FREEBL_GetVector; michael@0: michael@0: SEC_END_PROTOS michael@0: michael@0: #endif