fips140.h

来自「lots Elliptic curve cryptography codes. 」· C头文件 代码 · 共 60 行

H
60
字号
#ifndef CRYPTOPP_FIPS140_H#define CRYPTOPP_FIPS140_H/*! \file	FIPS 140 related functions and classes.*/#include "cryptlib.h"#include "secblock.h"NAMESPACE_BEGIN(CryptoPP)//! exception thrown when a crypto algorithm is used after a self test failsclass CRYPTOPP_DLL SelfTestFailure : public Exception{public:	explicit SelfTestFailure(const std::string &s) : Exception(OTHER_ERROR, s) {}};//! returns whether FIPS 140-2 compliance features were enabled at compile timeCRYPTOPP_DLL bool CRYPTOPP_API FIPS_140_2_ComplianceEnabled();//! enum values representing status of the power-up self testenum PowerUpSelfTestStatus {POWER_UP_SELF_TEST_NOT_DONE, POWER_UP_SELF_TEST_FAILED, POWER_UP_SELF_TEST_PASSED};//! perform the power-up self test, and set the self test statusCRYPTOPP_DLL void CRYPTOPP_API DoPowerUpSelfTest(const char *moduleFilename, const byte *expectedModuleMac);//! perform the power-up self test using the filename of this DLL and the embedded module MACCRYPTOPP_DLL void CRYPTOPP_API DoDllPowerUpSelfTest();//! set the power-up self test status to POWER_UP_SELF_TEST_FAILEDCRYPTOPP_DLL void CRYPTOPP_API SimulatePowerUpSelfTestFailure();//! return the current power-up self test statusCRYPTOPP_DLL PowerUpSelfTestStatus CRYPTOPP_API GetPowerUpSelfTestStatus();typedef PowerUpSelfTestStatus (CRYPTOPP_API * PGetPowerUpSelfTestStatus)();CRYPTOPP_DLL MessageAuthenticationCode * CRYPTOPP_API NewIntegrityCheckingMAC();CRYPTOPP_DLL bool CRYPTOPP_API IntegrityCheckModule(const char *moduleFilename, const byte *expectedModuleMac, SecByteBlock *pActualMac = NULL, unsigned long *pMacFileLocation = NULL);// this is used by Algorithm constructor to allow Algorithm objects to be constructed for the self testbool PowerUpSelfTestInProgressOnThisThread();void SetPowerUpSelfTestInProgressOnThisThread(bool inProgress);void SignaturePairwiseConsistencyTest(const PK_Signer &signer, const PK_Verifier &verifier);void EncryptionPairwiseConsistencyTest(const PK_Encryptor &encryptor, const PK_Decryptor &decryptor);void SignaturePairwiseConsistencyTest_FIPS_140_Only(const PK_Signer &signer, const PK_Verifier &verifier);void EncryptionPairwiseConsistencyTest_FIPS_140_Only(const PK_Encryptor &encryptor, const PK_Decryptor &decryptor);#define CRYPTOPP_DUMMY_DLL_MAC "MAC_51f34b8db820ae8"NAMESPACE_END#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?