- FIPS 140
The Federal Information Processing Standard 140 (FIPS) are series of publications numbered 140 which are a U.S. government
computer security standards that specify requirements for cryptography modules. As of December 2006, the current version of the standard isFIPS 140-2 , issued on25 May 2001 .Purpose of FIPS 140
The
National Institute of Standards and Technology (NIST) issued the 140 Publication Series to coordinate the requirements and standards for cryptographic modules which include both hardware and software components for use by departments and agencies of theUnited States federal government. FIPS 140 does not purport to provide "sufficient" conditions to guarantee that a module conforming to its requirements is secure, still less that a system built using such modules is secure. The requirements cover not only the cryptographic modules themselves but also their documentation and (at the highest security level) some aspects of the comments contained in the source code.User agencies desiring to implement cryptographic modules should confirm that the module they are using is covered by an existing validation certificate. FIPS 140-1 and FIPS 140-2 validation certificates specify the exact module name, hardware, software, firmware, and/or applet version numbers. For Levels 2 and higher, the operating platform upon which the validation is applicable is also listed. Vendors do not always maintain their baseline validations.
The Cryptographic Module Validation Program (CMVP) is operated jointly by the United States Government's
National Institute of Standards and Technology (NIST) Computer Security Division and theCommunications Security Establishment (CSE) of the Government of Canada. The use of validated cryptographic modules is required by the United States Government for all unclassified uses of cryptography. The Government of Canada also recommends the use of FIPS 140 validated cryptographic modules in unclassified applications of its departments.ecurity levels
FIPS 140-2 defines four levels of security, simply named "Level 1" to "Level 4". It does not specify in detail what level of security is required by any particular application.
* FIPS 140-2 Level 1 the lowest, imposes very limited requirements; loosely, all components must be "production-grade" and various egregious kinds of insecurity must be absent.
* FIPS 140-2 Level 2 adds requirements for physical tamper-evidence and role-based authentication.
* FIPS 140-2 Level 3 adds requirements for physical tamper-resistance (making it difficult for attackers to gain access to sensitive information contained in the module) and identity-based authentication, and for a physical or logical separation between the interfaces by which "critical security parameters" enter and leave the module, and its other interfaces.
* FIPS 140-2 Level 4 makes the physical security requirements more stringent, and requires robustness against environmental attacks.cope of requirements
FIPS 140 imposes requirements in eleven different areas:
* "Cryptographic module specification" (what must be documented)
* "Cryptographic module parts and interfaces" (what information flows in and out, and how it must be segregated)
* "Roles, services and authentication" (who can do what with the module, and how this is checked)
* "Finite state model" (documentation of the high-level states the module can be in, and how transitions occur)
* "Physical security" (tamper evidence and resistance, and robustness against extreme environmental conditions)
* "Operational environment" (what sort ofoperating system the module uses and is used by)
* "Cryptographic key management" (generation, entry, output, storage and destruction of keys)
* "EMI/EMC"
* "Self-tests" (what must be tested and when, and what must be done if a test fails)
* "Design assurance" (what documentation must be provided to demonstrate that the module has been well designed and implemented)
* "Mitigation of other attacks" (if a module is designed to mitigate against, say,TEMPEST attacks then its documentation must say how)Brief history
FIPS 140-1, issued on
11 January 1994 , was developed by a government and industry working group, composed of vendors and users of cryptographic equipment. The group identified the four "security levels" and eleven "requirement areas" listed above, and specified requirements for each area at each level.FIPS 140-2 , issued on25 May 2001 , takes account of changes in available technology and official standards since 1994, and of comments received from the vendor, tester, and user communities. It was the main input document to the international standard ISO/IEC 19790:2006 "Security requirements for cryptographic modules" issued on1 March 2006 .FIPS 140-3 is a new version of the standard which is currently under development.
External links
* [http://csrc.nist.gov/publications/fips/fips140-2/fips1402.pdf Full text of FIPS 140-2]
* [http://csrc.nist.gov/publications/fips/ General information about Federal Information Processing Standards; includes pointers to FIPS 140-2 and its annexes]
* [http://csrc.nist.gov/cryptval/1401labs.htm List of FIPS 140-2 Testing Labs]
* [http://wiki.mozilla.org/FIPS_Validation Opensource FIPS 140-2 Validation Project for Mozilla NSS]
Wikimedia Foundation. 2010.