<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> <title>Crypto++: fips140.h File Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <link href="doxygen.css" rel="stylesheet" type="text/css"/> </head> <body> <!-- Generated by Doxygen 1.6.1 --> <div class="navigation" id="top"> <div class="tabs"> <ul> <li><a href="index.html"><span>Main Page</span></a></li> <li><a href="namespaces.html"><span>Namespaces</span></a></li> <li><a href="annotated.html"><span>Classes</span></a></li> <li class="current"><a href="files.html"><span>Files</span></a></li> </ul> </div> <div class="tabs"> <ul> <li><a href="files.html"><span>File List</span></a></li> <li><a href="globals.html"><span>File Members</span></a></li> </ul> </div> </div> <div class="contents"> <h1>fips140.h File Reference</h1><code>#include "<a class="el" href="cryptlib_8h_source.html">cryptlib.h</a>"</code><br/> <code>#include "secblock.h"</code><br/> <p><a href="fips140_8h_source.html">Go to the source code of this file.</a></p> <table border="0" cellpadding="0" cellspacing="0"> <tr><td colspan="2"><h2>Classes</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top">class </td><td class="memItemRight" valign="bottom"><a class="el" href="class_self_test_failure.html">SelfTestFailure</a></td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">exception thrown when a crypto algorithm is used after a self test fails <a href="class_self_test_failure.html#_details">More...</a><br/></td></tr> <tr><td colspan="2"><h2>Defines</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="afa5d25ce1be2e8d1beda9340260a4d77"></a><!-- doxytag: member="fips140.h::CRYPTOPP_DUMMY_DLL_MAC" ref="afa5d25ce1be2e8d1beda9340260a4d77" args="" --> #define </td><td class="memItemRight" valign="bottom"><b>CRYPTOPP_DUMMY_DLL_MAC</b> "MAC_51f34b8db820ae8"</td></tr> <tr><td colspan="2"><h2>Typedefs</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="abc11727dc5acc942c5378eabf45d05c5"></a><!-- doxytag: member="fips140.h::PGetPowerUpSelfTestStatus" ref="abc11727dc5acc942c5378eabf45d05c5" args=")()" --> typedef <a class="el" href="fips140_8h.html#a8ccac50ac3bfc5abaa6cb457f0ded35d">PowerUpSelfTestStatus</a>(__cdecl * </td><td class="memItemRight" valign="bottom"><b>PGetPowerUpSelfTestStatus</b> )()</td></tr> <tr><td colspan="2"><h2>Enumerations</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top">enum </td><td class="memItemRight" valign="bottom"><a class="el" href="fips140_8h.html#a8ccac50ac3bfc5abaa6cb457f0ded35d">PowerUpSelfTestStatus</a> { <b>POWER_UP_SELF_TEST_NOT_DONE</b>, <b>POWER_UP_SELF_TEST_FAILED</b>, <b>POWER_UP_SELF_TEST_PASSED</b> }</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight"><p>enum values representing status of the power-up self test </p> <br/></td></tr> <tr><td colspan="2"><h2>Functions</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a5919c8bca9d826449d64c681f18c6a3e"></a><!-- doxytag: member="fips140.h::FIPS_140_2_ComplianceEnabled" ref="a5919c8bca9d826449d64c681f18c6a3e" args="()" --> bool __cdecl </td><td class="memItemRight" valign="bottom"><a class="el" href="fips140_8h.html#a5919c8bca9d826449d64c681f18c6a3e">FIPS_140_2_ComplianceEnabled</a> ()</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">returns whether FIPS 140-2 compliance features were enabled at compile time <br/></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="afbf72ca41794ab8c4be31b31070a903f"></a><!-- doxytag: member="fips140.h::DoPowerUpSelfTest" ref="afbf72ca41794ab8c4be31b31070a903f" args="(const char *moduleFilename, const byte *expectedModuleMac)" --> void __cdecl </td><td class="memItemRight" valign="bottom"><a class="el" href="fips140_8h.html#afbf72ca41794ab8c4be31b31070a903f">DoPowerUpSelfTest</a> (const char *moduleFilename, const byte *expectedModuleMac)</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">perform the power-up self test, and set the self test status <br/></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a0391333183b583a192abc0184483ae38"></a><!-- doxytag: member="fips140.h::DoDllPowerUpSelfTest" ref="a0391333183b583a192abc0184483ae38" args="()" --> void __cdecl </td><td class="memItemRight" valign="bottom"><a class="el" href="fips140_8h.html#a0391333183b583a192abc0184483ae38">DoDllPowerUpSelfTest</a> ()</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">perform the power-up self test using the filename of this DLL and the embedded module MAC <br/></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a3efa0579397f723b28de429c37c09db6"></a><!-- doxytag: member="fips140.h::SimulatePowerUpSelfTestFailure" ref="a3efa0579397f723b28de429c37c09db6" args="()" --> void __cdecl </td><td class="memItemRight" valign="bottom"><a class="el" href="fips140_8h.html#a3efa0579397f723b28de429c37c09db6">SimulatePowerUpSelfTestFailure</a> ()</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">set the power-up self test status to POWER_UP_SELF_TEST_FAILED <br/></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a979349106412329dc642e8bec3001125"></a><!-- doxytag: member="fips140.h::GetPowerUpSelfTestStatus" ref="a979349106412329dc642e8bec3001125" args="()" --> <a class="el" href="fips140_8h.html#a8ccac50ac3bfc5abaa6cb457f0ded35d">PowerUpSelfTestStatus</a> __cdecl </td><td class="memItemRight" valign="bottom"><a class="el" href="fips140_8h.html#a979349106412329dc642e8bec3001125">GetPowerUpSelfTestStatus</a> ()</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">return the current power-up self test status <br/></td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a766d57f0d6451c714b95ba126258b487"></a><!-- doxytag: member="fips140.h::NewIntegrityCheckingMAC" ref="a766d57f0d6451c714b95ba126258b487" args="()" --> <a class="el" href="class_message_authentication_code.html">MessageAuthenticationCode</a> *__cdecl </td><td class="memItemRight" valign="bottom"><b>NewIntegrityCheckingMAC</b> ()</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a422b2c96912953afb9b01b7c498baed3"></a><!-- doxytag: member="fips140.h::IntegrityCheckModule" ref="a422b2c96912953afb9b01b7c498baed3" args="(const char *moduleFilename, const byte *expectedModuleMac, SecByteBlock *pActualMac=NULL, unsigned long *pMacFileLocation=NULL)" --> bool __cdecl </td><td class="memItemRight" valign="bottom"><b>IntegrityCheckModule</b> (const char *moduleFilename, const byte *expectedModuleMac, <a class="el" href="class_sec_block.html">SecByteBlock</a> *pActualMac=NULL, unsigned long *pMacFileLocation=NULL)</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a132df8551bd9afe0a02f48826d389777"></a><!-- doxytag: member="fips140.h::PowerUpSelfTestInProgressOnThisThread" ref="a132df8551bd9afe0a02f48826d389777" args="()" --> bool </td><td class="memItemRight" valign="bottom"><b>PowerUpSelfTestInProgressOnThisThread</b> ()</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a5631fb1f075ea6c7645064faac39f748"></a><!-- doxytag: member="fips140.h::SetPowerUpSelfTestInProgressOnThisThread" ref="a5631fb1f075ea6c7645064faac39f748" args="(bool inProgress)" --> void </td><td class="memItemRight" valign="bottom"><b>SetPowerUpSelfTestInProgressOnThisThread</b> (bool inProgress)</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a4324298bf57523064d0866f7fb6d8eef"></a><!-- doxytag: member="fips140.h::SignaturePairwiseConsistencyTest" ref="a4324298bf57523064d0866f7fb6d8eef" args="(const PK_Signer &signer, const PK_Verifier &verifier)" --> void </td><td class="memItemRight" valign="bottom"><b>SignaturePairwiseConsistencyTest</b> (const <a class="el" href="class_p_k___signer.html">PK_Signer</a> &signer, const <a class="el" href="class_p_k___verifier.html">PK_Verifier</a> &verifier)</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a5508585427d867fafa5eba22fde6ba7d"></a><!-- doxytag: member="fips140.h::EncryptionPairwiseConsistencyTest" ref="a5508585427d867fafa5eba22fde6ba7d" args="(const PK_Encryptor &encryptor, const PK_Decryptor &decryptor)" --> void </td><td class="memItemRight" valign="bottom"><b>EncryptionPairwiseConsistencyTest</b> (const <a class="el" href="class_p_k___encryptor.html">PK_Encryptor</a> &encryptor, const <a class="el" href="class_p_k___decryptor.html">PK_Decryptor</a> &decryptor)</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="af071091de2c1ffaedf72a854bc957e62"></a><!-- doxytag: member="fips140.h::SignaturePairwiseConsistencyTest_FIPS_140_Only" ref="af071091de2c1ffaedf72a854bc957e62" args="(const PK_Signer &signer, const PK_Verifier &verifier)" --> void </td><td class="memItemRight" valign="bottom"><b>SignaturePairwiseConsistencyTest_FIPS_140_Only</b> (const <a class="el" href="class_p_k___signer.html">PK_Signer</a> &signer, const <a class="el" href="class_p_k___verifier.html">PK_Verifier</a> &verifier)</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ae3da40dd5fac183297b5f4753027f579"></a><!-- doxytag: member="fips140.h::EncryptionPairwiseConsistencyTest_FIPS_140_Only" ref="ae3da40dd5fac183297b5f4753027f579" args="(const PK_Encryptor &encryptor, const PK_Decryptor &decryptor)" --> void </td><td class="memItemRight" valign="bottom"><b>EncryptionPairwiseConsistencyTest_FIPS_140_Only</b> (const <a class="el" href="class_p_k___encryptor.html">PK_Encryptor</a> &encryptor, const <a class="el" href="class_p_k___decryptor.html">PK_Decryptor</a> &decryptor)</td></tr> </table> <hr/><a name="_details"></a><h2>Detailed Description</h2> <p>FIPS 140 related functions and classes. </p> <p>Definition in file <a class="el" href="fips140_8h_source.html">fips140.h</a>.</p> </div> <hr size="1"/><address style="text-align: right;"><small>Generated on 9 Dec 2009 for Crypto++ by <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.1 </small></address> </body> </html>