US7318150B2 - System and method to support platform firmware as a trusted process - Google Patents

System and method to support platform firmware as a trusted process Download PDF

Info

Publication number
US7318150B2
US7318150B2 US10/786,284 US78628404A US7318150B2 US 7318150 B2 US7318150 B2 US 7318150B2 US 78628404 A US78628404 A US 78628404A US 7318150 B2 US7318150 B2 US 7318150B2
Authority
US
United States
Prior art keywords
firmware
trusted
measurement
locality
original
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related, expires
Application number
US10/786,284
Other versions
US20050262571A1 (en
Inventor
Vincent J. Zimmer
Willard M. Wiseman
Jing Li
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Tahoe Research Ltd
Original Assignee
Intel Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corp filed Critical Intel Corp
Priority to US10/786,284 priority Critical patent/US7318150B2/en
Assigned to INTEL CORPORATION reassignment INTEL CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: WISEMAN, WILLARD M., LI, JING, ZIMMER, VINCENT J.
Publication of US20050262571A1 publication Critical patent/US20050262571A1/en
Application granted granted Critical
Publication of US7318150B2 publication Critical patent/US7318150B2/en
Assigned to TAHOE RESEARCH, LTD. reassignment TAHOE RESEARCH, LTD. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: INTEL CORPORATION
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/57Certifying or maintaining trusted computer platforms, e.g. secure boots or power-downs, version controls, system software checks, secure updates or assessing vulnerabilities

Definitions

  • the field of invention relates generally to computer systems and, more specifically but not exclusively relates to techniques for supporting execution of platform firmware as a trusted process.
  • networks are also prone to security breaches that enable data to be “stolen.” For example, recent attacks have been made on various electronic storefront servers to steal credit card information and other user information. These types of attacks have lead to an escalating need for substantially improved security measures.
  • the new approach begins with a trusted core that may only be accessed by users having appropriate security credentials.
  • users are not limited to humans, but rather also include programmatic entities such as software applications and the like.
  • a chain of trust is maintained by the TOS or STOS to ensure that only trustworthy users may access secured portions of the OS, while other unsecure portions do not require the same level of authentication to access. The end result is that unqualified access is denied.
  • firmware security relates to trusted processes.
  • STOS's provide mechanisms to ensure all secure software processes are trusted. There are no equivalent mechanisms for ensuring firmware processes are trusted; as such, firmware is deemed to be untrustworthy.
  • various firmware architectures support “hidden” firmware operations during operating system runtime. Depending on the particular architecture, these runtime firmware operations may have access to all of a system's resources, including the full memory address space. Thus, malicious firmware may cause havoc to operating systems an/or applications by modifying (e.g., deleting, replacing) portions of memory that are thought to be secured by the TOS or STOS.
  • FIG. 1 is a schematic diagram of an exemplary platform configuration via which embodiments of the invention may be implemented
  • FIG. 2 is a flowchart illustrating operations and logic performed during initialization of a system to securely store measurements of trusted firmware, according to one embodiment of the invention
  • FIG. 3 is a flowchart illustrating operations and logic performed during an operating system (OS)-runtime evaluation, wherein secure firmware processing is effectuated, according to one embodiment of the invention
  • FIG. 4 is a flowchart illustrating operations and logic performed in response to a system management interrupt (SMI) or a platform management interrupt (PMI) event, wherein a trusted firmware process may be effectuated, according to one embodiment of the invention;
  • SMI system management interrupt
  • PMI platform management interrupt
  • FIG. 5 is a schematic diagram illustrating a technique for storing a secret in a platform configuration register (PCR) having a trusted locality, according to one embodiment of the invention
  • FIG. 6 a is a schematic diagram illustrating a technique for sealing a secret to a trusted platform module (TPM), wherein the secret is contained in a digest including one or more integrity metric measurements, at least one of which is stored in a PCR having a trusted locality, according to one embodiment of the invention;
  • TPM trusted platform module
  • FIG. 6 b is a schematic diagram illustrating a technique for sealing a secret to a TPM, wherein the secret is contained in a digest including one or more integrity metric measurements plus indicia identifying a locality that was asserted at the time the secret is sealed, wherein at least one of the measurements is stored in a PCR having a trusted locality, according to one embodiment of the invention.
  • FIG. 6 c is a schematic diagram illustrating a technique for sealing a secret to a TPM, wherein the secret is contained in a digest including one or more integrity metric measurements plus indicia identifying a locality that was asserted at the time the secret is sealed, according to one embodiment of the invention.
  • Embodiments of systems and methods for supporting platform firmware as a trusted process are described herein.
  • numerous specific details are set forth to provide a thorough understanding of embodiments of the invention.
  • One skilled in the relevant art will recognize, however, that the invention can be practiced without one or more of the specific details, or with other methods, components, materials, etc.
  • well-known structures, materials, or operations are not shown or described in detail to avoid obscuring aspects of the invention.
  • trusted firmware processes are effectuated via trusted platform technology in combination with a secure authentication credential storage scheme. These security measures ensure the trustworthiness of firmware, while preventing attacks via execution of malicious firmware.
  • FIG. 1 An exemplary computer architecture 100 suited for implementing embodiments of the invention described herein is shown in FIG. 1 .
  • the architecture includes a processor 102 coupled, via a bus 104 , to a memory controller hub (MCH) 106 , commonly referred to as the “Northbridge” under well-known Intel® chipset schemes.
  • MCH 106 is coupled via respective buses 108 and 110 to system memory (i.e., RAM) 112 and an advanced graphics port (AGP) 114 .
  • MCH 106 provides memory control functions, and includes a device protection mechanism 111 that enables access to protected memory pages 113 in system memory 112 .
  • MCH 106 is further coupled to an Input/Output (I/O) controller hub (ICH) 116 via a bus 118 .
  • I/O Input/Output
  • the ICH which is commonly referred to as the “Southbridge,” provides a hardware interface to various I/O buses, ports and devices, depicted as items 120 . These include a PCI bus, and IDE interface, a universal serial bus (USB), etc.
  • ICH 116 is further coupled to a network port 122 via an I/O path 124 .
  • the network port 122 may be coupled to a network 125 .
  • the architecture 100 of FIG. 1 also includes a firmware hub 126 coupled to ICH 116 via a low pin count (LPC) bus 128 , which is configured per Intel LPC Interface Specification Revision 1.0, Sep. 29, 1997.
  • the firmware hub includes various firmware components, including a BIOS boot block 130 and replaceable or modular firmware code 131 .
  • the architecture may include a non-volatile (NV) store 134 in which non-volatile data used by the firmware and/or other components may be stored.
  • NV non-volatile
  • a Trusted Computing Group (http://www.trustedcomputinggroup.org) security scheme is implemented to store and retrieve security-related data.
  • TCG Trusted Computing Group
  • a TCG token comprising a trusted platform module (TPM) is employed.
  • TPM functionality may be embodied as a hardware device (most common) or via software.
  • Integrated circuits have been recently introduced to support TPM functionality, such as National Semiconductor's LPC-based TCG-compliant security controller. Such an integrated circuit is depicted as a TPM 136 in FIG. 1 .
  • TCG is an industry consortium concerned with platform and network security.
  • the TCG main specification (Version 1.2, October, 2003—hereinafter referred to as the “version 1.2 specification”) is a platform-independent industry specification that covers trust in computing platforms in general.
  • the TCG main specification defines a trusted platform subsystem that employs cryptographic methods when establishing trust.
  • the trusted platform may be embodied as a device or devices, or may be integrated into some existing platform component or components.
  • the trusted platform enables an authentication agent to determine the state of a platform environment and seal data particular to that platform environment. Subsequently, authentication data (e.g., integrity metrics) stored in a TPM may be returned in response to an authentication challenge to authenticate the platform.
  • authentication data e.g., integrity metrics
  • a “trusted measurement root” measures certain platform characteristics, logs the measurement data, and stores the final result in a TPM (which contains the root of trust for storing and reporting integrity metrics).
  • TPM which contains the root of trust for storing and reporting integrity metrics.
  • the trusted platform agent gathers the following information: the final results from the TPM, the log of the measurement data from the trusted platform measurement store, and TCG validation data that states the values that the measurements should produce in a platform configured in accordance with the configuration that existed at the time the integrity measurements were sealed.
  • TPM which contains the root of trust for storing and reporting integrity metrics.
  • TPM 136 provides several functions relating to security. These include an cryptographic co-processor 138 , an HMAC (Hashing for Message Authentication Codes) engine 140 , and SHA (security hash algorithm)-1 engine 142 , an Opt-In component 144 , non-volatile memory 146 , a key generator 148 , a random number generator (RNG) 150 , an execution engine 152 , volatile memory 156 , and Platform Configuration Registers (PCRs) 156 . Also provided in one TPM embodiment but not shown are an input/output component and a power detection component.
  • a TPM by itself provides a baseline level of security for storing and accessing trust-related data and authentication measures.
  • a TPM is to be an independent device that is not susceptible to tampering or incorrect usage.
  • an embodiment of the invention implements a hidden access mechanism that enables access to TPM 136 via special bus cycles invoked on low pin count (LPC) bus 128 .
  • LPC low pin count
  • TPM Trusted Multimedia Subsystem
  • secrets e.g., keys, certificates, etc.
  • TPM architecture addresses this aspect using a mechanism referred to as “locality.”
  • the concept of locality was introduced in the TPM Main Specification version 1.2. Locality allows for Dynamic RTMs in addition to static RTMs. Locality also allows more that one simultaneous root of trust to exist per platform operational state.
  • the idea behind locality is that certain combinations of software and hardware are allowed more privileges than other combinations. This is enforced by a hierarchical access structure. For instance, the highest level of locality might be cycles that only hardware could create. Since the hardware is virus-proof (at least in theory), it has a higher level of trust than cycles code generates. Under the version 1.2 specification, Locality 4 is the highest level defined. These cycles are generated by hardware. This would include things like TPM_PCR_Reset or the TPM_HASH_* LPC commands. The hardware guarantees that the TPM_PCR_RESET or HASH operations occurred, and that the correct data was sent.
  • a platform is initialized to support a trusted firmware process effectuated via locality in the following manner.
  • the process starts in a block 200 in response to a restart event.
  • a restart event implies the system has been restarted, such as via a cold boot or system reset (a.k.a., warm boot).
  • processor, chipset, and memory initialization operations are performed. These include initializing the platform memory and I/O complex, as depicted in a block 202 .
  • This component or components are used to derive the core root of trust measurement (CRTM).
  • CRTM is the basis for all subsequent trust measurements.
  • the TPM is used to store these measurements.
  • a TPM exists, the answer to decision block 204 is YES, and the logic proceeds to a block 206 .
  • the TPM_STARTUP command is issued.
  • a static CRTM is then created via a measurement of the platform's base firmware.
  • the base firmware is a portion of firmware provided by the platform that cannot be partially replaced.
  • the CRTM must be an immutable portion of the platform's initialization code that executes upon any platform reset.
  • the trust in the platform is based on the CRTM.
  • the trust in all measurements is based on the integrity of this component.
  • the static CRTM is derived from a measurement of “static” firmware.
  • the first CRTM architecture measures the BIOS boot block 130 (a.k.a., firmware boot block or trusted boot block).
  • the firmware is composed of the BIOS boot block and a POST (power-on self-test) BIOS. These are individual components and each can be updated independent of the other.
  • the BIOS boot block is the CRTM while the POST BIOS is not, but is a measured component of the Chain of Trust. If there are multiple execution points for the BIOS boot block, they must all be within the CRTM.
  • the CRTM is measured over the entire BIOS.
  • the BIOS is composed of a single atomic entity.
  • the entire BIOS is updated, modified, or maintained as a single component, and cannot be partially replaced.
  • a measured portion of the BIOS is used to measure the CRTM-applicable components, and then store the measurement in PCRO in the TPM, such as depicted by a static CRTM 158 .
  • special processor microcode is used to perform the “dynamic” CRTM measurement and storage operations. Each of these techniques is performed in connection with inherent functionality provided by the TPM for such purposes.
  • trusted firmware is assigned to locality 1 .
  • the processor must be in a secure execution mode (SEM) to enter locality 1 .
  • SEM secure execution mode
  • the SEM is entered by issuing an “SENTER” instruction to processor 102 . While in secure execution mode, all existing and potential future processor users are blocked from accessing the processor. SEM also temporarily blocks all interrupts (the interrupts are redirected for subsequent handling after exiting SEM), including system management interrupts (SMIs), as depicted by an SMI redirection block 160 .
  • SMI system management interrupts
  • processor 102 contains special instructions and microcode 162 to access certain devices coupled to LPC 142 via special bus cycle timing. These devices include TPM 136 . This physical access scheme provides one level of security between data stored in TPM 136 and attacks on platform architecture 100 .
  • a second level of security is provided by storing integrity metric data in platform configuration registers 156 .
  • PCR's 156 are employed for securely storing data in a manner where certain authentication information must be provided to TPM 136 in order to access a given PCR.
  • the processor controls the locality, thus enabling certain PCR's from being accessed unless operating in the locality corresponding to those registers. Further security may be provided by sealing the locality in the measurement, as described below.
  • a PCR is a 160-bit storage location for discrete integrity measurements. All PCR registers are shielded-locations and are inside of the TPM. The decision of whether a PCR contains a standard measurement or if the PCR is available for general use is deferred to the platform specific specification.
  • a large number of integrity metrics may be measured in a platform, and a particular integrity metric may change with time and a new value may need to be stored. It is difficult to authenticate the source of measurement of integrity metrics, and as a result a new value of an integrity metric cannot be permitted to simply overwrite an existing value. (A rogue entity could erase an existing value that indicates subversion and replace it with a benign value.) Thus, if values of integrity metrics are individually stored, and updates of integrity metrics must be individually stored, it is difficult to place an upper bound on the size of memory that is required to store integrity metrics.
  • a PCR is designed to hold an unlimited number of measurements in the register. It does this by using a cryptographic hash and hashing all updates to a PCR.
  • PCR[0] provides the capability of being reset. Accordingly, hash-extend operations may be performed in a manner that produces PCR[ 0 ] values that are independent of previously stored register values. This is advantageous with respect to being able to store integrity metrics corresponding to a given platform environment, and then subsequently compare integrity metrics corresponding to a current platform environment with the given platform environment.
  • PCR[0] is reset, and a hash-extend is performed on the trusted BIOS boot block code (the core integrity measurement) using SHA-1 engine 142 , with the result being stored in PCR[0].
  • the hash-extend operates on a reset register value (i.e., 0), and so the hash-extend simply reflects a hash of the trusted code.
  • the trusted BIOS boot block corresponds to one of the platform firmware environment components, while the hash of the component comprises an integrity metric corresponding to the platform environment, in this case the static CRTM.
  • an integrity metric corresponding to a platform environment may reflect a single environment component (i.e., firmware/software component), or a combination of components used to form an environment that exists at the time the integrity metric is measured.)
  • a static CRTM and a dynamic CRTM may exist.
  • a dynamic CRTM is derived from the processor itself. It is sealed during platform manufacturing in PCR[17], which may only be accessed while in locality 4 ; a sealed dynamic CRTM 164 is shown in FIG. 1 .
  • SMM startup code relates to code that is executed by a “hidden” processor mode known as system management mode (SMM) on an IA-32 (Intel® Architecture, 32-bit) processor in response to a system management interrupt (SMI) event.
  • SMM system management mode
  • PMI platform management interrupt
  • startup code relates to code that is executed in a somewhat analogous processor mode on an IA-64 processor, such as a member of the Intel® Itanium® family.
  • SMI and PMI signals are sometimes referred to herein as “xMI” signals. It will be understood that reference to an xMI signal means one of an SMI signal or a PMI signal.
  • SMM- and PMI-based code comprises firmware that is loaded during the pre-boot into a reserved portion of memory.
  • the location at which the startup portion of this code is stored by the xMI_DESCRIPTOR This portion of firmware is depicted as SMM or PMI startup code 132 in FIG. 1 .
  • the startup code is also referred to as the SMBASE.
  • the CRTM in the trusted building block measures the SMM- or PMI-based startup code in a block 212 .
  • the startup code concerns the portion of the SMM- or PMI-based firmware that is fixed by the platform (e.g., at manufacture).
  • firmware models that exist that enable third-party SMM and PMI code to be loaded for execution in response to corresponding SMI- and PMI-based events. This extensible portion of the SMM or PMI code, shown at 133 , is not measured in block 212 .
  • each of the logic flows for a NO result of decision block 204 , or completion of either of blocks 210 or 212 , lead to a decision block 214 .
  • a determination is made to whether the system employs an IA-32 processor. If it does, the SMBASE (i.e., SMM-startup code) is relocated from an address of 0x3000:00 (its default address in firmware storage) to one of the H-segment, T-segment, and/or the compatibility segment in a block 216 . If the answer to decision block 214 is NO, the processor is an IA-64 processor, and the PMI entry point is registered with the IA-64 processor abstraction layer (PAL) in a block 218 .
  • PAL IA-64 processor abstraction layer
  • FIG. 3 Operations performed to ensure a secure firmware-processing environment during OS-runtime in accordance with one embodiment are shown in FIG. 3 .
  • the process begins with an SMI or PMI event. These events correspond to situations that cause the processor to switch from it current tasks to execute SMI or PMI-based code to service the event.
  • the system asserts locality 1 in a block 302 .
  • the processor first asserts locality 4 , and then locality 1 . In one embodiment, this is performed by issuing an SENTER command, causing execution control to pass to processor 102 .
  • the processor then executes microcode 162 to assert locality 4 .
  • the SMM or PMI startup code 132 then begins to execute. This startup code includes instructions to assert locality 1 .
  • the TPM ordinals may comprise a shared secret or certificate that is stored in either a PCR or a non-volatile storage means. This shared secret is extracted by the SMM or PMI code and provided to a challenger, who has requested authentication credentials. The results correspond to information sent back to the client being challenged (i.e., the platform hosting the TPM in which the credentials are sealed).
  • other SMM or PMI processing may be performed in a block 308 .
  • FIG. 4 shows a flowchart corresponding to one embodiment of a mechanism for performing trusted firmware processes during OS-runtime. It will be understood that the initialization operations of FIG. 2 or similar operations will have been performed during the pre-boot prior to booting and operating system and entering the OS-runtime phase.
  • the process starts with an SMI or PMI event in a block 400 .
  • the current SMM or PMI startup code is measured in a block 402 . This measurement is analogous to the measurements performed in blocks 212 and 222 of FIG. 2 .
  • the SMM or PMI startup code Prior to this measurement, the SMM or PMI startup code is deemed “unqualified.” This is because there is no way to verify whether the current SMM or PMI startup code is trustworthy or not without some sort of qualification, such as the measurement performed in block 402 .
  • a block 404 the system asserts locality 1 .
  • the original SMM or PMI code measurement is then retrieved from a locality 1 PCR in a block 406 .
  • a determination to whether or not the SMM/PMI startup code measurements of blocks 402 and 406 match is made in a decision block 408 . What this determination does, in effect, is verify that the current SMM or PMI startup code is identical to the startup code that was measured during the initialization operation of either block 212 or block 222 .
  • the startup code measured during the initialization is deemed trustworthy. This mechanism authenticates the trustworthiness of the current SMM or PMI startup code.
  • the operation of blocks 402 , 406 and 408 may be performed on a one-time basis (e.g., once per OS-runtime session), or every time an SMI or PMI event occurs.
  • information is stored on the platform (e.g., at a known memory location, in NVRAM, etc.) indicating that the SMM/PMI startup code is deemed trustworthy. This is depicted by an optional block 414 .
  • a principle advantage concerns storing security and authentication data. These type of data are generally referred to as “secrets,” and include such objects as keys and authentication certificates.
  • secrets are generally referred to as “secrets,” and include such objects as keys and authentication certificates.
  • the embodiments described below employ both physical mechanisms and logical mechanisms to prevent unauthorized access to such secrets.
  • the asserted locality corresponds to a privileged access level within a hierarchy, wherein the higher the locality, the higher the hierarchy level and thus privilege.
  • the hierarchy level reflect trustworthiness of the process—the processes that are deemed the most trustworthy are allowed access to all operations, while less trustworthy processes are denied access to certain operations, based on the locality asserted for the processes.
  • secrets may be stored directly in PCR's corresponding to a processes' asserted locality.
  • a secret 500 is stored to a PCR[20].
  • the following table defines the PCR usage for the various localities defined by the version 1.2 specification:
  • Each locality level “inherits” the privileges of all of the localities below it.
  • the process for which the locality is asserted in FIG. 5 must have a locality of 1 or higher.
  • endpoints are minimally comprised of asymmetric keys, key storage and processing that protects protocol data items.
  • TCG defines four classes of protected message exchange; Binding, Signing, Sealed-Binding (a.k.a. Sealing) and Sealed-Signing. Binding is the traditional operation of encrypting a message using a public key. That is, the sender uses the public key of the intended recipient to encrypt the message. The message is only recoverable by decryption using the recipient's private key. When the private key is managed by the TPM as a non-migratable key, only the TPM that created the key may use it. Hence, a message encrypted with the public key, “bound” to a particular instance of a TPM.
  • Sealing takes binding one step further. Sealed messages are bound to a set of platform metrics specified by the message sender. Platform metrics specify platform configuration state that must exist before decryption will be allowed. Sealing associates the encrypted message (actually the symmetric key used to encrypt the message) with a set of PCR register values and a non-migratable asymmetric key.
  • a sealed message is created by selecting a range of PCR register values and asymmetrically encrypting the PCR values plus the symmetric key used to encrypt the message.
  • the TPM with the asymmetric decryption key may only decrypt the symmetric key when the platform configuration matches the PCR register values specified by the sender. Sealing is a powerful feature of the TPM. It provides assurance that protected messages or secrets are only recoverable when the platform is functioning in a very specific known configuration.
  • FIGS. 6 a , 6 b , and 6 c involve the use of sealing information to a TPM.
  • the techniques used for these purposes may be used for stand-alone purposes, such as guaranteeing process security, or may be combined with operations involving another system, such as an attestation performed via a message exchange.
  • the SEAL operation allows software to explicitly state a future “trusted” configuration that the platform must be in for the secret (stored via the TPM_Seal command) to be revealed.
  • the SEAL operation also implicitly includes the relevant platform configuration (PCR-values) when the SEAL operation was performed.
  • the SEAL operation uses the tmpproof value to BIND a BLOB (Binary Large Object) to an individual TPM. To retrieve the secret, and UNSEAL operation is performed. If the UNSEAL operation succeeds, proof of the platform configuration that was in effect when the SEAL operation was performed is returned to the caller, as well as the secret data.
  • TPM_Seal command In response to the TPM_Seal command, external data is concatenated with a value of integrity metric sequence and encrypted under a parent key.
  • the TPM_Unseal command may be subsequently used to decrypt the BLOB using the parent key and export the plaintext data if the current integrity metric sequence inside the TPM matches the value of integrity metric sequence inside the BLOB.
  • an embodiment is shown that seals a secret 600 to TPM 156 using one or more integrity metrics.
  • various platform integrity metrics are measured and stored in respective PCR's.
  • these include a CRTM 602 , SMM/PMI startup code 132 , and an optional integrity metric 604 .
  • the CRTM measurement is stored in PCR[0]
  • the SMM/PMI startup code measurement is stored in PCR[20].
  • the optional integrity metric 604 is stored in a PCR[M].
  • Each of PCR[0] and PCR[M] have a locality requirement of 0.
  • PCR[20] requires a locality of 1 or greater. Thus, in order to store an integrity metric in PCR[20], locality 1 or greater must be asserted.
  • the secret 600 is concatenated with the values in PCR[0], PCR[M] (if an optional integrity measurement was made), and PCR[20].
  • the resulting digest 606 is then sealed to TPM 156 using the TMP_Seal command.
  • the platform configuration metrics that currently exist must match corresponding integrity metrics stored in PCR[0], PCR[M] (if an optional integrity measurement was made), and PCR[20].
  • the process must be in locality 1 to access the value in PCR[20], and the integrity metrics must match.
  • the SMM/PMI startup code and the CRTM measurement e.g., BIOS boot block 130
  • the secret 600 can be returned by issuing the TMP_Unseal command (with the appropriate command parameters).
  • FIG. 6 b The embodiment of FIG. 6 b is analogous to that shown in FIG. 6 a , except for it goes one step further. While the embodiment of FIG. 6 a prevents locality 0 users from accessing secret 600 (no matter what the current integrity metrics are), it does not prevent users in localities 2 and 3 from accessing the secret. (It is noted that the locality 4 user, the processor, would have no motivation to access secret 600 , although it would also not be precluded from accessing all of the PCR's for in which the trusted configuration integrity metric data are stored.)
  • FIG. 6 b addresses this potential problem by including locality information 608 in a digest 606 A identifying that locality 1 was asserted when the digest was sealed to TPM 156 .
  • this embodiment requires locality 1 to be asserted while the secret 600 is attempted to be retrieved using TPM_Unseal.
  • users in any locality other than locality 1 may not access secret 600 under any condition.
  • FIG. 6 c is analogous to that shown in FIG. 6 b , except in this instance all of the integrity metrics are stored in locality 0 PCR's.
  • One disadvantage with this approach is that the integrity metric in PCR[M] may be extended by a locality 0 user, which would cause a denial of service. (This deficiency may also exist with both of the embodiments of FIGS. 6 a and 6 b if an optional integrity metric is used and the value of PCR[M] is extended.)
  • one or more of the integrity metrics may actually be used in generating the respective digests 600 A, 600 B, and 600 C.
  • optional integrity metrics may typically relate to other firmware components, such as Option ROMs.
  • PCR[2] is designated for storing Option ROM code measurements
  • PCR[3] is designated for storing Option ROM configuration measurements. It should be unlikely that a non-software locality 0 user would attempt to extend either PCR[2] or PCR[3], unless motivated by malicious intent. Furthermore, a rogue software entity would need to provide some mechanism for accessing the TPM in the first place, which again is not likely.
  • embodiments of this invention may be used as or to support a software/firmware program or module executed upon some form of processing core (such as the computer processor) or otherwise implemented or realized upon or within a machine-readable medium.
  • a machine-readable medium includes any mechanism for storing or transmitting information in a form readable by a machine (e.g., a computer).
  • a machine-readable medium can include, for example, a read only memory (ROM); a random access memory (RAM); a magnetic disk storage media; an optical storage media; and a flash memory device, etc.
  • a machine-readable medium can include propagated signals such as electrical, optical, acoustical or other form of propagated signals (e.g., carrier waves, infrared signals, digital signals, etc.). For instance, all or a portion of the firmware instructions may be loaded from a network store.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Storage Device Security (AREA)

Abstract

A system and method to support platform firmware as a trusted process. Measurement of a trusted portion of original firmware are measured by a core root of trust measurement (CRTM). The measurement is stored in a secure manner during pre-boot. During operating system (OS)-runtime, requests are made to access an unqualified current version of firmware corresponding to a secure execution mode. A portion of the current firmware analogous to the trusted portion is measured. The measurements of the trusted original portion and unqualified current portion are compared to verify they match. If they match, it indicates that the current portion and the trusted portion are one in the same. Thus, the current portion of firmware is trustworthy. Accordingly, the firmware may be executed as a trusted process. Embodiments employ locality to enforce the trusted process. The use of locality prevents unqualified users (i.e., software) from accessing data stored by trusted firmware.

Description

FIELD OF THE INVENTION
The field of invention relates generally to computer systems and, more specifically but not exclusively relates to techniques for supporting execution of platform firmware as a trusted process.
BACKGROUND INFORMATION
The past few years have seen an ever-increasing level of attacks on computer systems and servers. Malicious hackers spend hours on end trying to identify security holes via which they can embed viruses, Trojans, etc. Almost as soon as an operating system (OS) vendor publishes a security patch to defeat a particular attack scheme, the hackers have figured out another way to defeat the software. Once viruses and the like appear on servers, an entire network of computers is susceptible to attack by those viruses.
In addition to malicious attacks in which the intent is to cause widespread system damage, networks are also prone to security breaches that enable data to be “stolen.” For example, recent attacks have been made on various electronic storefront servers to steal credit card information and other user information. These types of attacks have lead to an escalating need for substantially improved security measures.
In view of the severity and frequency of the foregoing, a new direction has been proposed to replace today's security paradigm. A more proactive approach to security is presently being designed into the next generation of operating systems, which are referred to as trusted operating systems (TOS), secure operating systems (SOS), and secure and trusted operating systems (STOS). As stated in an NSA Operating System Security Paper, NISSC, October 1998, “Current security efforts suffer from the flawed assumption that adequate security can be provided in applications with the existing security mechanisms of mainstream operating systems. In reality, the need for secure operating systems is growing in today's computing environment due to substantial increases in connectivity and data sharing. The threats posed by the modern computing environment cannot be addressed without secure operating systems. Any security effort which ignores this fact can only result in a ‘fortress built upon sand’.”
In contrast to today's scheme of security mechanisms layered over an unsecure core (e.g., a mainstream OS), the new approach begins with a trusted core that may only be accessed by users having appropriate security credentials. In this context, it is noted that users are not limited to humans, but rather also include programmatic entities such as software applications and the like. A chain of trust is maintained by the TOS or STOS to ensure that only trustworthy users may access secured portions of the OS, while other unsecure portions do not require the same level of authentication to access. The end result is that unqualified access is denied.
While efforts are being made to dramatically enhance operating system security, there are no commensurate endeavors that have been directed at system firmware. Although less susceptible to attacks than software, there are still situations under which system firmware may be attacked. In general, an attack may be direct (e.g., immediate deletion or corruption of critical BIOS components), or latent (e.g., a firmware Trojan to be activated at a future time). While operating systems attacks are generally somewhat recoverable, a firmware attack may be fatal. Consider, an errant operating system can be replaced, while errant firmware may totally disable a system or server.
Another aspect of firmware security relates to trusted processes. STOS's provide mechanisms to ensure all secure software processes are trusted. There are no equivalent mechanisms for ensuring firmware processes are trusted; as such, firmware is deemed to be untrustworthy. For example, various firmware architectures support “hidden” firmware operations during operating system runtime. Depending on the particular architecture, these runtime firmware operations may have access to all of a system's resources, including the full memory address space. Thus, malicious firmware may cause havoc to operating systems an/or applications by modifying (e.g., deleting, replacing) portions of memory that are thought to be secured by the TOS or STOS.
BRIEF DESCRIPTION OF THE DRAWINGS
The foregoing aspects and many of the attendant advantages of this invention will become more readily appreciated as the same becomes better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein like reference numerals refer to like parts throughout the various views unless otherwise specified:
FIG. 1 is a schematic diagram of an exemplary platform configuration via which embodiments of the invention may be implemented;
FIG. 2 is a flowchart illustrating operations and logic performed during initialization of a system to securely store measurements of trusted firmware, according to one embodiment of the invention;
FIG. 3 is a flowchart illustrating operations and logic performed during an operating system (OS)-runtime evaluation, wherein secure firmware processing is effectuated, according to one embodiment of the invention;
FIG. 4 is a flowchart illustrating operations and logic performed in response to a system management interrupt (SMI) or a platform management interrupt (PMI) event, wherein a trusted firmware process may be effectuated, according to one embodiment of the invention;
FIG. 5 is a schematic diagram illustrating a technique for storing a secret in a platform configuration register (PCR) having a trusted locality, according to one embodiment of the invention;
FIG. 6 a is a schematic diagram illustrating a technique for sealing a secret to a trusted platform module (TPM), wherein the secret is contained in a digest including one or more integrity metric measurements, at least one of which is stored in a PCR having a trusted locality, according to one embodiment of the invention;
FIG. 6 b is a schematic diagram illustrating a technique for sealing a secret to a TPM, wherein the secret is contained in a digest including one or more integrity metric measurements plus indicia identifying a locality that was asserted at the time the secret is sealed, wherein at least one of the measurements is stored in a PCR having a trusted locality, according to one embodiment of the invention; and
FIG. 6 c is a schematic diagram illustrating a technique for sealing a secret to a TPM, wherein the secret is contained in a digest including one or more integrity metric measurements plus indicia identifying a locality that was asserted at the time the secret is sealed, according to one embodiment of the invention.
DETAILED DESCRIPTION
Embodiments of systems and methods for supporting platform firmware as a trusted process are described herein. In the following description, numerous specific details are set forth to provide a thorough understanding of embodiments of the invention. One skilled in the relevant art will recognize, however, that the invention can be practiced without one or more of the specific details, or with other methods, components, materials, etc. In other instances, well-known structures, materials, or operations are not shown or described in detail to avoid obscuring aspects of the invention.
Reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Thus, the appearances of the phrases “in one embodiment” or “in an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures, or characteristics may be combined in any suitable manner in one or more embodiments.
In accordance with aspects of the embodiments disclosed herein, trusted firmware processes are effectuated via trusted platform technology in combination with a secure authentication credential storage scheme. These security measures ensure the trustworthiness of firmware, while preventing attacks via execution of malicious firmware.
An exemplary computer architecture 100 suited for implementing embodiments of the invention described herein is shown in FIG. 1. The architecture includes a processor 102 coupled, via a bus 104, to a memory controller hub (MCH) 106, commonly referred to as the “Northbridge” under well-known Intel® chipset schemes. MCH 106 is coupled via respective buses 108 and 110 to system memory (i.e., RAM) 112 and an advanced graphics port (AGP) 114. MCH 106 provides memory control functions, and includes a device protection mechanism 111 that enables access to protected memory pages 113 in system memory 112. MCH 106 is further coupled to an Input/Output (I/O) controller hub (ICH) 116 via a bus 118. The ICH, which is commonly referred to as the “Southbridge,” provides a hardware interface to various I/O buses, ports and devices, depicted as items 120. These include a PCI bus, and IDE interface, a universal serial bus (USB), etc. ICH 116 is further coupled to a network port 122 via an I/O path 124. In turn, the network port 122 may be coupled to a network 125.
The architecture 100 of FIG. 1 also includes a firmware hub 126 coupled to ICH 116 via a low pin count (LPC) bus 128, which is configured per Intel LPC Interface Specification Revision 1.0, Sep. 29, 1997. The firmware hub includes various firmware components, including a BIOS boot block 130 and replaceable or modular firmware code 131. The architecture may include a non-volatile (NV) store 134 in which non-volatile data used by the firmware and/or other components may be stored.
In accordance with one aspect of the embodiments, a Trusted Computing Group (TCG) (http://www.trustedcomputinggroup.org) security scheme is implemented to store and retrieve security-related data. In the embodiment of FIG. 1, a TCG token comprising a trusted platform module (TPM) is employed. Generally, TPM functionality may be embodied as a hardware device (most common) or via software. For example, Integrated circuits have been recently introduced to support TPM functionality, such as National Semiconductor's LPC-based TCG-compliant security controller. Such an integrated circuit is depicted as a TPM 136 in FIG. 1.
TCG is an industry consortium concerned with platform and network security. The TCG main specification (Version 1.2, October, 2003—hereinafter referred to as the “version 1.2 specification”) is a platform-independent industry specification that covers trust in computing platforms in general. The TCG main specification defines a trusted platform subsystem that employs cryptographic methods when establishing trust. The trusted platform may be embodied as a device or devices, or may be integrated into some existing platform component or components. The trusted platform enables an authentication agent to determine the state of a platform environment and seal data particular to that platform environment. Subsequently, authentication data (e.g., integrity metrics) stored in a TPM may be returned in response to an authentication challenge to authenticate the platform.
A “trusted measurement root” measures certain platform characteristics, logs the measurement data, and stores the final result in a TPM (which contains the root of trust for storing and reporting integrity metrics). When an integrity challenge is received, the trusted platform agent gathers the following information: the final results from the TPM, the log of the measurement data from the trusted platform measurement store, and TCG validation data that states the values that the measurements should produce in a platform configured in accordance with the configuration that existed at the time the integrity measurements were sealed. The operations of making an identity and enabling key-pair for the pre-boot environment enables TPM functionality to be employed for authentication purposes during and after pre-boot. Further details concerning the use of TPM 136 are discussed below.
TPM 136 provides several functions relating to security. These include an cryptographic co-processor 138, an HMAC (Hashing for Message Authentication Codes) engine 140, and SHA (security hash algorithm)-1 engine 142, an Opt-In component 144, non-volatile memory 146, a key generator 148, a random number generator (RNG) 150, an execution engine 152, volatile memory 156, and Platform Configuration Registers (PCRs) 156. Also provided in one TPM embodiment but not shown are an input/output component and a power detection component.
Generally, a TPM by itself provides a baseline level of security for storing and accessing trust-related data and authentication measures. Under TPM Main Specification, Part 1 Design Principles (Oct. 2, 2003) a TPM is to be an independent device that is not susceptible to tampering or incorrect usage. Accordingly, to further enhance this baseline security, an embodiment of the invention implements a hidden access mechanism that enables access to TPM 136 via special bus cycles invoked on low pin count (LPC) bus 128.
In order to provide for trust processes, there must be a mechanism to ensure that security-related data, such as secrets (e.g., keys, certificates, etc.) may not be accessed by unqualified users. In the context of TPM usage, users may comprise software, firmware or hardware; for convenience, all users are generally referred to as software. The TPM architecture addresses this aspect using a mechanism referred to as “locality.” The concept of locality was introduced in the TPM Main Specification version 1.2. Locality allows for Dynamic RTMs in addition to static RTMs. Locality also allows more that one simultaneous root of trust to exist per platform operational state.
The idea behind locality is that certain combinations of software and hardware are allowed more privileges than other combinations. This is enforced by a hierarchical access structure. For instance, the highest level of locality might be cycles that only hardware could create. Since the hardware is virus-proof (at least in theory), it has a higher level of trust than cycles code generates. Under the version 1.2 specification, Locality 4 is the highest level defined. These cycles are generated by hardware. This would include things like TPM_PCR_Reset or the TPM_HASH_* LPC commands. The hardware guarantees that the TPM_PCR_RESET or HASH operations occurred, and that the correct data was sent.
Next, consider the case of a platform that has both: 1) software based on either using no PCRs or a set of resettable PCRs (the OS based on the Static RTM or Static OS); and 2) trusted software (i.e., a trusted OS). In this case, there is a need to differentiate cycles from the OS's. Localities 1-3 may be used by the TOS for its transactions. The version 1.2 specification includes definitions for new resettable PCRs assigned to specific localities. Only trusted software should be able to issue commands based on those PCRs. This software is locality 1-3 software.
With reference to the flowchart of FIG. 2, in one embodiment a platform is initialized to support a trusted firmware process effectuated via locality in the following manner. The process starts in a block 200 in response to a restart event. A restart event implies the system has been restarted, such as via a cold boot or system reset (a.k.a., warm boot). In response, processor, chipset, and memory initialization operations are performed. These include initializing the platform memory and I/O complex, as depicted in a block 202.
Next, a determination is made to whether the platform has a TPM in a decision block 204. In order to enforce trustworthiness, there must be some component(s) that are inherently deemed trustworthy. This component or components are used to derive the core root of trust measurement (CRTM). A CRTM is the basis for all subsequent trust measurements. The TPM is used to store these measurements.
If a TPM exists, the answer to decision block 204 is YES, and the logic proceeds to a block 206. In this block, the TPM_STARTUP command is issued. A static CRTM is then created via a measurement of the platform's base firmware. The base firmware is a portion of firmware provided by the platform that cannot be partially replaced. The CRTM must be an immutable portion of the platform's initialization code that executes upon any platform reset. The trust in the platform is based on the CRTM. The trust in all measurements is based on the integrity of this component. Thus, the static CRTM is derived from a measurement of “static” firmware.
Currently, in a PC, there are at least two types of static CTRM architectures. The first CRTM architecture measures the BIOS boot block 130 (a.k.a., firmware boot block or trusted boot block). In this architecture, the firmware is composed of the BIOS boot block and a POST (power-on self-test) BIOS. These are individual components and each can be updated independent of the other. In this architecture, the BIOS boot block is the CRTM while the POST BIOS is not, but is a measured component of the Chain of Trust. If there are multiple execution points for the BIOS boot block, they must all be within the CRTM.
Under a second architecture, the CRTM is measured over the entire BIOS. In this architecture, the BIOS is composed of a single atomic entity. The entire BIOS is updated, modified, or maintained as a single component, and cannot be partially replaced.
In some embodiments, a measured portion of the BIOS is used to measure the CRTM-applicable components, and then store the measurement in PCRO in the TPM, such as depicted by a static CRTM 158. In other embodiments, special processor microcode is used to perform the “dynamic” CRTM measurement and storage operations. Each of these techniques is performed in connection with inherent functionality provided by the TPM for such purposes.
In one embodiment, trusted firmware is assigned to locality 1. In one embodiment, the processor must be in a secure execution mode (SEM) to enter locality 1. For IA-32 processors, the SEM is entered by issuing an “SENTER” instruction to processor 102. While in secure execution mode, all existing and potential future processor users are blocked from accessing the processor. SEM also temporarily blocks all interrupts (the interrupts are redirected for subsequent handling after exiting SEM), including system management interrupts (SMIs), as depicted by an SMI redirection block 160.
In accordance with one aspect of SEM operation, processor 102 contains special instructions and microcode 162 to access certain devices coupled to LPC 142 via special bus cycle timing. These devices include TPM 136. This physical access scheme provides one level of security between data stored in TPM 136 and attacks on platform architecture 100.
A second level of security is provided by storing integrity metric data in platform configuration registers 156. PCR's 156 are employed for securely storing data in a manner where certain authentication information must be provided to TPM 136 in order to access a given PCR. In particular, the processor controls the locality, thus enabling certain PCR's from being accessed unless operating in the locality corresponding to those registers. Further security may be provided by sealing the locality in the measurement, as described below.
A PCR is a 160-bit storage location for discrete integrity measurements. All PCR registers are shielded-locations and are inside of the TPM. The decision of whether a PCR contains a standard measurement or if the PCR is available for general use is deferred to the platform specific specification.
A large number of integrity metrics may be measured in a platform, and a particular integrity metric may change with time and a new value may need to be stored. It is difficult to authenticate the source of measurement of integrity metrics, and as a result a new value of an integrity metric cannot be permitted to simply overwrite an existing value. (A rogue entity could erase an existing value that indicates subversion and replace it with a benign value.) Thus, if values of integrity metrics are individually stored, and updates of integrity metrics must be individually stored, it is difficult to place an upper bound on the size of memory that is required to store integrity metrics.
A PCR is designed to hold an unlimited number of measurements in the register. It does this by using a cryptographic hash and hashing all updates to a PCR. The pseudo code for this is:
PCR i New=HASH (PCR i Old value∥value to add)
Updates to a PCR register are sometimes referred to as “extending” the PCR, while the data measured to the PCR is sometimes called the “extend.” Since the resultant hash is dependant on existing data (the Old value), a chain of trust is formed that is incremented with each extend operation.
In one embodiment, PCR[0] provides the capability of being reset. Accordingly, hash-extend operations may be performed in a manner that produces PCR[0] values that are independent of previously stored register values. This is advantageous with respect to being able to store integrity metrics corresponding to a given platform environment, and then subsequently compare integrity metrics corresponding to a current platform environment with the given platform environment.
For example, in one embodiment of block 206, PCR[0] is reset, and a hash-extend is performed on the trusted BIOS boot block code (the core integrity measurement) using SHA-1 engine 142, with the result being stored in PCR[0]. In this context, the hash-extend operates on a reset register value (i.e., 0), and so the hash-extend simply reflects a hash of the trusted code. Thus, once loaded, the trusted BIOS boot block corresponds to one of the platform firmware environment components, while the hash of the component comprises an integrity metric corresponding to the platform environment, in this case the static CRTM. (it is noted that an integrity metric corresponding to a platform environment may reflect a single environment component (i.e., firmware/software component), or a combination of components used to form an environment that exists at the time the integrity metric is measured.)
Continuing with the flowchart of FIG. 2, in a decision block 208 a determination is made to whether the processor supports dynamic CRTM measurements. With the extension of the locality functionality that was added to the TPM by the version 1.2 specification, both a static CRTM and a dynamic CRTM may exist. A dynamic CRTM is derived from the processor itself. It is sealed during platform manufacturing in PCR[17], which may only be accessed while in locality 4; a sealed dynamic CRTM 164 is shown in FIG. 1.
If the answer to decision block 208 is YES, the logic proceeds to a block 210 in which an xMI_DESCRIPTOR data structure is created that indicates “where” the SMM or PMI-based startup code exists. Generally, SMM startup code relates to code that is executed by a “hidden” processor mode known as system management mode (SMM) on an IA-32 (Intel® Architecture, 32-bit) processor in response to a system management interrupt (SMI) event. Meanwhile, PMI (platform management interrupt) startup code relates to code that is executed in a somewhat analogous processor mode on an IA-64 processor, such as a member of the Intel® Itanium® family. For simplicity, both SMI and PMI signals are sometimes referred to herein as “xMI” signals. It will be understood that reference to an xMI signal means one of an SMI signal or a PMI signal.
As describe in further detail below, SMM- and PMI-based code comprises firmware that is loaded during the pre-boot into a reserved portion of memory. In block 210, the location at which the startup portion of this code is stored by the xMI_DESCRIPTOR. This portion of firmware is depicted as SMM or PMI startup code 132 in FIG. 1. For SMM code, the startup code is also referred to as the SMBASE.
If there is no dynamic CRTM defined for the processor, the CRTM in the trusted building block (TBB) measures the SMM- or PMI-based startup code in a block 212. In these embodiments, the startup code concerns the portion of the SMM- or PMI-based firmware that is fixed by the platform (e.g., at manufacture). There are firmware models that exist that enable third-party SMM and PMI code to be loaded for execution in response to corresponding SMI- and PMI-based events. This extensible portion of the SMM or PMI code, shown at 133, is not measured in block 212.
Continuing with the initialization process, each of the logic flows for a NO result of decision block 204, or completion of either of blocks 210 or 212, lead to a decision block 214. In this decision block, a determination is made to whether the system employs an IA-32 processor. If it does, the SMBASE (i.e., SMM-startup code) is relocated from an address of 0x3000:00 (its default address in firmware storage) to one of the H-segment, T-segment, and/or the compatibility segment in a block 216. If the answer to decision block 214 is NO, the processor is an IA-64 processor, and the PMI entry point is registered with the IA-64 processor abstraction layer (PAL) in a block 218.
Following the completion of either of blocks 216 and 218 (as applicable), a determination is made in a decision block 218 to whether there is dynamic CRTM defined for the processor. This is analogous to the determination made in decision block 208 discussed above. If the answer is YES, the processor microcode measures the PMI code or the SMM code referenced by the xMI_DESCRIPTOR created in block 210 above, as depicted in a block 220. The initialization of the system is then completing and the operating system is booted in a block 222. If the answer to decision block 220 is NO, the operation of block 222 is skipped. After the completion of loading the OS, the system is in OS-runtime.
Operations performed to ensure a secure firmware-processing environment during OS-runtime in accordance with one embodiment are shown in FIG. 3. The process begins with an SMI or PMI event. These events correspond to situations that cause the processor to switch from it current tasks to execute SMI or PMI-based code to service the event.
In response to the event, the system asserts locality 1 in a block 302. In practice, the processor first asserts locality 4, and then locality 1. In one embodiment, this is performed by issuing an SENTER command, causing execution control to pass to processor 102. The processor then executes microcode 162 to assert locality 4. The SMM or PMI startup code 132 then begins to execute. This startup code includes instructions to assert locality 1.
In a decision block 304 a determination is made to whether the event involves security processing. If it does, the logic flows to a block 306, wherein TPM ordinals are sent and results are returned. For example, the TPM ordinals may comprise a shared secret or certificate that is stored in either a PCR or a non-volatile storage means. This shared secret is extracted by the SMM or PMI code and provided to a challenger, who has requested authentication credentials. The results correspond to information sent back to the client being challenged (i.e., the platform hosting the TPM in which the credentials are sealed). After the completion of the operations in block 306, other SMM or PMI processing may be performed in a block 308.
FIG. 4 shows a flowchart corresponding to one embodiment of a mechanism for performing trusted firmware processes during OS-runtime. It will be understood that the initialization operations of FIG. 2 or similar operations will have been performed during the pre-boot prior to booting and operating system and entering the OS-runtime phase. The process starts with an SMI or PMI event in a block 400. In response, the current SMM or PMI startup code is measured in a block 402. This measurement is analogous to the measurements performed in blocks 212 and 222 of FIG. 2. Prior to this measurement, the SMM or PMI startup code is deemed “unqualified.” This is because there is no way to verify whether the current SMM or PMI startup code is trustworthy or not without some sort of qualification, such as the measurement performed in block 402.
In a block 404, the system asserts locality 1. The original SMM or PMI code measurement is then retrieved from a locality 1 PCR in a block 406. A determination to whether or not the SMM/PMI startup code measurements of blocks 402 and 406 match is made in a decision block 408. What this determination does, in effect, is verify that the current SMM or PMI startup code is identical to the startup code that was measured during the initialization operation of either block 212 or block 222. The startup code measured during the initialization is deemed trustworthy. This mechanism authenticates the trustworthiness of the current SMM or PMI startup code.
If the answer to decision block 408 is YES, indicating that startup code is trustworthy, the processing is allowed to continue in locality 1, as depicted by a block 410. Thus, all locality 1 privileges are made available to any subsequent SMM or PMI firmware processing performed in a block 412. If the SMM/PMI startup code does not match, the firmware is deemed untrustworthy. Thus, in a block 414, the locality 0 privilege level is asserted, and any subsequent SMM/PMI processing performed in block 412 may only operate in this locality, precluding the firmware from accessing locality 1 PCRs.
In the foregoing scheme, the operation of blocks 402, 406 and 408 may be performed on a one-time basis (e.g., once per OS-runtime session), or every time an SMI or PMI event occurs. In accordance with one embodiment of the one-time basis, information is stored on the platform (e.g., at a known memory location, in NVRAM, etc.) indicating that the SMM/PMI startup code is deemed trustworthy. This is depicted by an optional block 414.
Secure Processing Operations—Protected Security/Authentication Data
There are many advantages to being able to operate in a locality above locality 0. A principle advantage concerns storing security and authentication data. These type of data are generally referred to as “secrets,” and include such objects as keys and authentication certificates. The embodiments described below employ both physical mechanisms and logical mechanisms to prevent unauthorized access to such secrets.
As discussed above, the asserted locality corresponds to a privileged access level within a hierarchy, wherein the higher the locality, the higher the hierarchy level and thus privilege. Also, the hierarchy level reflect trustworthiness of the process—the processes that are deemed the most trustworthy are allowed access to all operations, while less trustworthy processes are denied access to certain operations, based on the locality asserted for the processes.
Under the most basic secret-protection scheme, secrets may be stored directly in PCR's corresponding to a processes' asserted locality. For example, as shown in FIG. 5, a secret 500 is stored to a PCR[20]. The following table defines the PCR usage for the various localities defined by the version 1.2 specification:
TABLE 1
PCR that can be
Locality Entity in PCRs that can be extended by this
Modifier Control reset by the locality locality
Any Any Software 15 15
0 Platform or None 0–14, 23
Static OS
1 Dynamic OS None 20
2 Dynamic OS 20, 21, 22 20, 21, 22
3 An auxiliary None 18, 19, 20
level of a
trusted
component
4 Hardware/ 17, 18, 19, 20 17, 18
Dynamic RTM
The combination of the TPM and the processor effectuate a physical security enforcement mechanism in the embodiment of FIG. 5. Each locality level “inherits” the privileges of all of the localities below it. Thus, the process for which the locality is asserted in FIG. 5 must have a locality of 1 or higher.
Designers of secure distributed systems, when considering exchange of information between systems, must identify the endpoints of communication. The composition and makeup of the endpoint is as important to the overall security of the system as is the communications protocol. As specified by the TCG, endpoints are minimally comprised of asymmetric keys, key storage and processing that protects protocol data items.
Classic message exchange based on asymmetric cryptography suggests that messages intended for one and only one individual can be encrypted using a public key. Furthermore, the message can be protected from tampering by signing with the private key. Keys are communication endpoints and improperly managed keys can result in loss of security. Additionally, improperly configured endpoints may also result in loss of security. The TPM aids in improving security by providing both key management and configuration management features (e.g., Protected Storage, Measurement and Reporting). These features can be combined to “seal” keys and platform configuration making endpoint definition stronger.
TCG defines four classes of protected message exchange; Binding, Signing, Sealed-Binding (a.k.a. Sealing) and Sealed-Signing. Binding is the traditional operation of encrypting a message using a public key. That is, the sender uses the public key of the intended recipient to encrypt the message. The message is only recoverable by decryption using the recipient's private key. When the private key is managed by the TPM as a non-migratable key, only the TPM that created the key may use it. Hence, a message encrypted with the public key, “bound” to a particular instance of a TPM.
Sealing takes binding one step further. Sealed messages are bound to a set of platform metrics specified by the message sender. Platform metrics specify platform configuration state that must exist before decryption will be allowed. Sealing associates the encrypted message (actually the symmetric key used to encrypt the message) with a set of PCR register values and a non-migratable asymmetric key.
A sealed message is created by selecting a range of PCR register values and asymmetrically encrypting the PCR values plus the symmetric key used to encrypt the message. The TPM with the asymmetric decryption key may only decrypt the symmetric key when the platform configuration matches the PCR register values specified by the sender. Sealing is a powerful feature of the TPM. It provides assurance that protected messages or secrets are only recoverable when the platform is functioning in a very specific known configuration.
Each of the embodiments of FIGS. 6 a, 6 b, and 6 c involve the use of sealing information to a TPM. The techniques used for these purposes may be used for stand-alone purposes, such as guaranteeing process security, or may be combined with operations involving another system, such as an attestation performed via a message exchange.
Sealing is effectuated via the TPM_Seal command. The SEAL operation allows software to explicitly state a future “trusted” configuration that the platform must be in for the secret (stored via the TPM_Seal command) to be revealed. The SEAL operation also implicitly includes the relevant platform configuration (PCR-values) when the SEAL operation was performed. The SEAL operation uses the tmpproof value to BIND a BLOB (Binary Large Object) to an individual TPM. To retrieve the secret, and UNSEAL operation is performed. If the UNSEAL operation succeeds, proof of the platform configuration that was in effect when the SEAL operation was performed is returned to the caller, as well as the secret data.
In response to the TPM_Seal command, external data is concatenated with a value of integrity metric sequence and encrypted under a parent key. The TPM_Unseal command may be subsequently used to decrypt the BLOB using the parent key and export the plaintext data if the current integrity metric sequence inside the TPM matches the value of integrity metric sequence inside the BLOB.
With reference to FIG. 6 a, an embodiment is shown that seals a secret 600 to TPM 156 using one or more integrity metrics. During pre-boot, various platform integrity metrics are measured and stored in respective PCR's. In the illustrated embodiment, these include a CRTM 602, SMM/PMI startup code 132, and an optional integrity metric 604. The CRTM measurement is stored in PCR[0], while the SMM/PMI startup code measurement is stored in PCR[20]. The optional integrity metric 604 is stored in a PCR[M]. Each of PCR[0] and PCR[M] have a locality requirement of 0. PCR[20] requires a locality of 1 or greater. Thus, in order to store an integrity metric in PCR[20], locality 1 or greater must be asserted.
The secret 600 is concatenated with the values in PCR[0], PCR[M] (if an optional integrity measurement was made), and PCR[20]. The resulting digest 606 is then sealed to TPM 156 using the TMP_Seal command.
As discussed above, in order to access the secret 600, the platform configuration metrics that currently exist must match corresponding integrity metrics stored in PCR[0], PCR[M] (if an optional integrity measurement was made), and PCR[20]. As a result, the process must be in locality 1 to access the value in PCR[20], and the integrity metrics must match. Accordingly, the SMM/PMI startup code and the CRTM measurement (e.g., BIOS boot block 130) must be the same as corresponding components that existed at the measurements were stored in PCR[0], PCR[M] (optional), and PCR[20]. If the integrity metrics match, the secret 600 can be returned by issuing the TMP_Unseal command (with the appropriate command parameters).
The embodiment of FIG. 6 b is analogous to that shown in FIG. 6 a, except for it goes one step further. While the embodiment of FIG. 6 a prevents locality 0 users from accessing secret 600 (no matter what the current integrity metrics are), it does not prevent users in localities 2 and 3 from accessing the secret. (It is noted that the locality 4 user, the processor, would have no motivation to access secret 600, although it would also not be precluded from accessing all of the PCR's for in which the trusted configuration integrity metric data are stored.)
The embodiment of FIG. 6 b addresses this potential problem by including locality information 608 in a digest 606A identifying that locality 1 was asserted when the digest was sealed to TPM 156. Thus, this embodiment requires locality 1 to be asserted while the secret 600 is attempted to be retrieved using TPM_Unseal. As a result, users in any locality other than locality 1 may not access secret 600 under any condition.
The embodiment of FIG. 6 c is analogous to that shown in FIG. 6 b, except in this instance all of the integrity metrics are stored in locality 0 PCR's. One disadvantage with this approach is that the integrity metric in PCR[M] may be extended by a locality 0 user, which would cause a denial of service. (This deficiency may also exist with both of the embodiments of FIGS. 6 a and 6 b if an optional integrity metric is used and the value of PCR[M] is extended.)
It is noted that in each of the embodiments of FIGS. 6 a-c, one or more of the integrity metrics may actually be used in generating the respective digests 600A, 600B, and 600C. It is further noted that optional integrity metrics may typically relate to other firmware components, such as Option ROMs. In this case, PCR[2] is designated for storing Option ROM code measurements, while PCR[3] is designated for storing Option ROM configuration measurements. It should be unlikely that a non-software locality 0 user would attempt to extend either PCR[2] or PCR[3], unless motivated by malicious intent. Furthermore, a rogue software entity would need to provide some mechanism for accessing the TPM in the first place, which again is not likely.
Many of the various operations performed during initialization and OS-runtime use of the embodiments described above are enabled via execution of firmware instructions. Thus, embodiments of this invention may be used as or to support a software/firmware program or module executed upon some form of processing core (such as the computer processor) or otherwise implemented or realized upon or within a machine-readable medium. A machine-readable medium includes any mechanism for storing or transmitting information in a form readable by a machine (e.g., a computer). For example, a machine-readable medium can include, for example, a read only memory (ROM); a random access memory (RAM); a magnetic disk storage media; an optical storage media; and a flash memory device, etc. In addition, a machine-readable medium can include propagated signals such as electrical, optical, acoustical or other form of propagated signals (e.g., carrier waves, infrared signals, digital signals, etc.). For instance, all or a portion of the firmware instructions may be loaded from a network store.
The above description of illustrated embodiments of the invention, including what is described in the Abstract, is not intended to be exhaustive or to limit the invention to the precise forms disclosed. While specific embodiments of, and examples for, the invention are described herein for illustrative purposes, various equivalent modifications are possible within the scope of the invention, as those skilled in the relevant art will recognize.
These modifications can be made to the invention in light of the above detailed description. The terms used in the following claims should not be construed to limit the invention to the specific embodiments disclosed in the specification and the claims. Rather, the scope of the invention is to be determined entirely by the following claims, which are to be construed in accordance with established doctrines of claim interpretation.

Claims (26)

1. A method comprising:
measuring a trusted original portion of firmware of a computer system, wherein the original portion of firmware comprises a startup portion of at least one of system management mode (SMM) firmware code or platform management interrupt (PMI) firmware code;
securely storing the measurement of the trusted original portion of firmware;
measuring an unqualified current portion of firmware during an operating system (OS)-runtime phase of the computer system;
retrieving the measurement of the trusted original portion of firmware;
comparing the measurement of the trusted original portion of firmware to the measurement of the unqualified current portion of firmware; and
if the measurements match, executing the current portion of firmware as a trusted process.
2. The method of claim 1, wherein securely storing the measurement of the trusted portion of original firmware comprises storing the measurement in a trusted platform module (TPM).
3. The method of claim 2, wherein the trusted platform module is embodied as a hardware component.
4. The method of claim 2, wherein the trusted platform module is embodied as a software-based component.
5. The method of claim 1, further comprising:
enforcing a locality-based security mechanism, wherein a processor must be operating in at least one of a given locality and a higher locality to retrieve the measurement of the trusted portion of firmware.
6. The method of claim 1, wherein measuring the unqualified current portion of firmware comprises measuring a current portion of at least one of system management mode (SMM) firmware code or platform management interrupt (PMI) firmware code.
7. The method of claim 1, further comprising performing a core root of trust measurement (CRTM).
8. The method of claim 7, wherein the CRTM is a static CRTM comprising a measurement of a trusted bootable portion of firmware.
9. The method of claim 7, wherein the CRTM is a dynamic CRTM measured via execution of processor microcode.
10. The method of claim 1, further comprising:
creating a descriptor indicating where the trusted original portion of firmware is located.
11. A method, comprising:
measuring at least one integrity metric corresponding to a trusted portion of an original firmware configuration of a computer system, wherein the trusted portion of the original firmware configuration includes a startup portion of at least one of system management mode (SMM) firmware code or platform management interrupt (PMI) firmware code;
measuring an unqualified current portion of firmware during an operating system (OS)-runtime phase of the computer system;
storing a respective measurement corresponding to each of said at least one integrity metric in a corresponding platform configuration register (PCR) of a trusted platform module(TPM); and
sealing a secret to the TPM, the secret contained in a digest including the secret concatenated with the respective measurement(s) stored in the PCR(s), wherein a current firmware configuration includes a portion that matches the trusted portion of the original firmware configuration to unseal the secret attempting to unseal the secret sealed to the TPM during an operating system (OS)-runtime phase of the computer system.
12. The method of claim 11, further comprising:
specifying a locality to be associated with a trusted firmware process; and concatenating the locality to the secret and the respective measurement(s) used to form the digest stored in the PCR(s).
13. The method of claim 11, further comprising:
asserting a locality corresponding to an execution privilege level;
storing at least one of the respective measurement(s) in a PCR that may be extended if a current execution privilege level matches or exceeds the locality of the execution privilege level that is asserted.
14. The method of claim 12, wherein the locality is locality 1.
15. The method of claim 11, wherein the trusted portion of the original firmware configuration includes a trusted boot block.
16. The method of claim 15, further comprising:
measuring the trusted boot block to obtain a core root of trust measurement (CRTM).
17. The method of claim 11, wherein the portion of the firmware configuration includes a current portion of at least one of system management mode (SMM) firmware code or platform management interrupt (PMI) firmware code.
18. The method of claim 11, further comprising:
executing firmware as a trusted process if the secret is unsealed, otherwise executing the firmware process as an untrusted process.
19. The method of claim 11, wherein the integrity metric is measured by executing microcode on a processor.
20. An article of manufacture, comprising:
a machine-readable medium have instructions stored thereon, which when executed perform operations including:
measuring a trusted portion of an original set of firmware components during a pre-boot phase of a computer system;
storing the measurement of the trusted portion of the original set of firmware components in a trusted platform module (TPM) platform configuration register (PCR);
measuring an unqualified portion of a current set of firmware components during an operating system (OS)-runtime phase of the computer system;
determining if the measurement of the portion of the current set of firmware components matches the measurement of the portion of the original firmware components; and
providing indicia to a processor to execute the portion of the current set of firmware components as a trusted process if the measurements match wherein each of the original and current sets of firmware components correspond to a portion of at least one of system management mode (SMM) firmware code or platform management interrupt (PMI) firmware code.
21. The article of manufacture of claim 20, wherein the machine-readable medium comprises further instructions to perform the operation of performing a core root of trust measurement (CRTM).
22. The article of manufacture of claim 20, wherein the machine-readable medium comprises further instructions to perform operations including:
sealing a secret to the TPM, the secret contained in a digest including the secret concatenated with the measurement of the trusted portion of the original set of firmware that is stored in the PCR.
23. The article of manufacture of claim 20, wherein the article comprises a flash device.
24. A system comprising:
a processor, including microcode instructions;
memory, operatively coupled to the processor;
a trusted platform module, operatively coupled to the processor; and
a flash device having firmware instructions stored thereon, which when executed on the processor perform operations including:
retrieving a first measurement stored in the TPM, the first measurement comprising a measurement of a trusted portion of the firmware instructions;
measuring an unqualified current portion of firmware instructions during an operating system (OS)-runtime phase of the system, the current portion of firmware instructions analogous to the trusted portion of the firmware instructions to obtain a second measurement, wherein each of the trusted and current portions of firmware instructions correspond to a portion of at least one of system management mode (SMM) firmware or platform management interrupt (PMI) firmware;
comparing the first measurement to the second measurement; and if the first and second measurements match, programming the processor to execute the current portion of firmware instructions as a secure process.
25. The system of claim 24, wherein the microcode instructions may be executed to perform the operations of generating a dynamic core root of trust measurement (CRTM) for the system.
26. The system of claim 24, wherein the microcode instructions may be executed to perform operations including:
measuring the trusted portion of the firmware instructions to produce the first measurement; and
storing the first measurement in a platform configuration register (PCR) of the TPM.
US10/786,284 2004-02-25 2004-02-25 System and method to support platform firmware as a trusted process Expired - Fee Related US7318150B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/786,284 US7318150B2 (en) 2004-02-25 2004-02-25 System and method to support platform firmware as a trusted process

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US10/786,284 US7318150B2 (en) 2004-02-25 2004-02-25 System and method to support platform firmware as a trusted process

Publications (2)

Publication Number Publication Date
US20050262571A1 US20050262571A1 (en) 2005-11-24
US7318150B2 true US7318150B2 (en) 2008-01-08

Family

ID=35376725

Family Applications (1)

Application Number Title Priority Date Filing Date
US10/786,284 Expired - Fee Related US7318150B2 (en) 2004-02-25 2004-02-25 System and method to support platform firmware as a trusted process

Country Status (1)

Country Link
US (1) US7318150B2 (en)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060020792A1 (en) * 2004-07-24 2006-01-26 Weiss Jason R Volume mount authentication
US20060075223A1 (en) * 2004-10-01 2006-04-06 International Business Machines Corporation Scalable paging of platform configuration registers
US20060161784A1 (en) * 2005-01-14 2006-07-20 Microsoft Corporation Systems and methods for updating a secure boot process on a computer with a hardware security module
US20060161790A1 (en) * 2005-01-14 2006-07-20 Microsoft Corporation Systems and methods for controlling access to data on a computer with a secure boot process
US20070006306A1 (en) * 2005-06-30 2007-01-04 Jean-Pierre Seifert Tamper-aware virtual TPM
US20080005574A1 (en) * 2006-06-29 2008-01-03 Cheng Antonio S Method and apparatus for establishing prosessor as core root of trust for measurement
US20080126590A1 (en) * 2006-06-29 2008-05-29 Rothman Michael A Semiconductor based host protected addressing in computing devices
US20080148064A1 (en) * 2006-12-18 2008-06-19 David Carroll Challener Apparatus, system, and method for authentication of a core root of trust measurement chain
US20100082987A1 (en) * 2008-09-30 2010-04-01 Microsoft Corporation Transparent trust validation of an unknown platform
US7757098B2 (en) 2006-06-27 2010-07-13 Intel Corporation Method and apparatus for verifying authenticity of initial boot code
US20110099361A1 (en) * 2009-04-15 2011-04-28 Interdigital Patent Holdings, Inc. Validation And/Or Authentication Of A Device For Communication With Network
US20110138116A1 (en) * 2008-10-24 2011-06-09 Lipinski Greg J Direct-attached/network-attached Storage Device
WO2014091342A1 (en) * 2012-12-14 2014-06-19 International Business Machines Corporation User trusted device to attest trustworthiness of initialization firmware
US20140359304A1 (en) * 2013-05-30 2014-12-04 Toshiba America Electronic Components, Inc. Trusted manager bridge

Families Citing this family (37)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7526649B2 (en) * 2003-12-30 2009-04-28 Intel Corporation Session key exchange
US7725703B2 (en) * 2005-01-07 2010-05-25 Microsoft Corporation Systems and methods for securely booting a computer with a trusted processing module
US20060230439A1 (en) * 2005-03-30 2006-10-12 Smith Ned M Trusted platform module apparatus, systems, and methods
WO2007124091A1 (en) * 2006-04-21 2007-11-01 Interdigital Technology Corporation Apparatus and methods for performing trusted computing integrity measurement reporting
CN102982257B (en) 2006-05-05 2016-06-22 交互数字技术公司 The method performing completeness of platform and DRM software integrity checking between RE and TE
US20080040613A1 (en) * 2006-08-14 2008-02-14 David Carroll Challener Apparatus, system, and method for secure password reset
US20080126779A1 (en) * 2006-09-19 2008-05-29 Ned Smith Methods and apparatus to perform secure boot
US8060941B2 (en) * 2006-12-15 2011-11-15 International Business Machines Corporation Method and system to authenticate an application in a computing platform operating in trusted computing group (TCG) domain
US20080178257A1 (en) * 2007-01-20 2008-07-24 Takuya Mishina Method for integrity metrics management
US20080235754A1 (en) * 2007-03-19 2008-09-25 Wiseman Willard M Methods and apparatus for enforcing launch policies in processing systems
US20080244261A1 (en) * 2007-03-29 2008-10-02 Wiseman Willard M Separation of logical trusted platform modules within a single physical trusted platform module
US7991932B1 (en) 2007-04-13 2011-08-02 Hewlett-Packard Development Company, L.P. Firmware and/or a chipset determination of state of computer system to set chipset mode
US7853804B2 (en) * 2007-09-10 2010-12-14 Lenovo (Singapore) Pte. Ltd. System and method for secure data disposal
US7913074B2 (en) 2007-09-28 2011-03-22 Microsoft Corporation Securely launching encrypted operating systems
JP5385148B2 (en) * 2007-10-05 2014-01-08 パナソニック株式会社 Secure boot terminal, secure boot method, secure boot program, recording medium, and integrated circuit
US7921286B2 (en) * 2007-11-14 2011-04-05 Microsoft Corporation Computer initialization for secure kernel
US20090133097A1 (en) * 2007-11-15 2009-05-21 Ned Smith Device, system, and method for provisioning trusted platform module policies to a virtual machine monitor
US7802042B2 (en) * 2007-12-28 2010-09-21 Intel Corporation Method and system for handling a management interrupt event in a multi-processor computing device
US8473945B2 (en) * 2007-12-31 2013-06-25 Intel Corporation Enabling system management mode in a secure system
US8335931B2 (en) * 2008-06-20 2012-12-18 Imation Corp. Interconnectable personal computer architectures that provide secure, portable, and persistent computing environments
US8850601B2 (en) * 2009-05-18 2014-09-30 Hewlett-Packard Development Company, L.P. Systems and methods of determining a trust level from system management mode
US8615788B2 (en) * 2009-08-12 2013-12-24 International Business Machines Corporation Method and apparatus for scalable integrity attestation in virtualization environments
US8341393B2 (en) * 2009-12-17 2012-12-25 Lenovo (Singapore) Pte. Ltd. Security to extend trust
JP5736994B2 (en) * 2011-06-15 2015-06-17 株式会社リコー Information processing apparatus, validity verification method, and program
CN102841989A (en) * 2011-06-24 2012-12-26 国民技术股份有限公司 Operation system protection method and operation system protection device
US8375221B1 (en) * 2011-07-29 2013-02-12 Microsoft Corporation Firmware-based trusted platform module for arm processor architectures and trustzone security extensions
US8924737B2 (en) 2011-08-25 2014-12-30 Microsoft Corporation Digital signing authority dependent platform secret
GB2503471B (en) * 2012-06-27 2015-05-06 Nordic Semiconductor Asa Integrated-circuit radio
US9721104B2 (en) * 2013-11-26 2017-08-01 Intel Corporation CPU-based measured boot
US9413765B2 (en) 2014-03-25 2016-08-09 Intel Corporation Multinode hubs for trusted computing
CN109522721A (en) * 2017-09-19 2019-03-26 中国科学院沈阳自动化研究所 A kind of starting method of the Industry Control credible embedded platform based on TPM
CN110677250B (en) 2018-07-02 2022-09-02 阿里巴巴集团控股有限公司 Key and certificate distribution method, identity information processing method, device and medium
CN110795742B (en) 2018-08-02 2023-05-02 阿里巴巴集团控股有限公司 Metric processing method, device, storage medium and processor for high-speed cryptographic operation
CN110795774B (en) * 2018-08-02 2023-04-11 阿里巴巴集团控股有限公司 Measurement method, device and system based on trusted high-speed encryption card
CN110874478B (en) 2018-08-29 2023-05-02 阿里巴巴集团控股有限公司 Key processing method and device, storage medium and processor
US11768611B2 (en) 2020-04-02 2023-09-26 Axiado Corporation Secure boot of a processing chip
US20240031174A1 (en) * 2022-07-20 2024-01-25 Arista Networks, Inc. Establishing trust between supervisors in a network device

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040073806A1 (en) * 2002-10-09 2004-04-15 Zimmer Vincent J. Encapsulation of a TCPA trusted platform module functionality within a server management coprocessor subsystem
US20050138393A1 (en) * 2003-12-22 2005-06-23 Challener David C. Determining user security level using trusted hardware device
US6988250B1 (en) * 1999-02-15 2006-01-17 Hewlett-Packard Development Company, L.P. Trusted computing platform using a trusted device assembly
US7065654B1 (en) * 2001-05-10 2006-06-20 Advanced Micro Devices, Inc. Secure execution box
US7069439B1 (en) * 1999-03-05 2006-06-27 Hewlett-Packard Development Company, L.P. Computing apparatus and methods using secure authentication arrangements

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7707406B2 (en) * 2002-11-08 2010-04-27 General Instrument Corporation Certificate renewal in a certificate authority infrastructure
US7318235B2 (en) * 2002-12-16 2008-01-08 Intel Corporation Attestation using both fixed token and portable token
US7634807B2 (en) * 2003-08-08 2009-12-15 Nokia Corporation System and method to establish and maintain conditional trust by stating signal of distrust

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6988250B1 (en) * 1999-02-15 2006-01-17 Hewlett-Packard Development Company, L.P. Trusted computing platform using a trusted device assembly
US7069439B1 (en) * 1999-03-05 2006-06-27 Hewlett-Packard Development Company, L.P. Computing apparatus and methods using secure authentication arrangements
US7065654B1 (en) * 2001-05-10 2006-06-20 Advanced Micro Devices, Inc. Secure execution box
US20040073806A1 (en) * 2002-10-09 2004-04-15 Zimmer Vincent J. Encapsulation of a TCPA trusted platform module functionality within a server management coprocessor subsystem
US20050138393A1 (en) * 2003-12-22 2005-06-23 Challener David C. Determining user security level using trusted hardware device

Cited By (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060020792A1 (en) * 2004-07-24 2006-01-26 Weiss Jason R Volume mount authentication
USRE42382E1 (en) * 2004-07-24 2011-05-17 Bbs Technologies, Inc. Volume mount authentication
US7480931B2 (en) * 2004-07-24 2009-01-20 Bbs Technologies, Inc. Volume mount authentication
US20060075223A1 (en) * 2004-10-01 2006-04-06 International Business Machines Corporation Scalable paging of platform configuration registers
US7653819B2 (en) * 2004-10-01 2010-01-26 Lenovo Singapore Pte Ltd. Scalable paging of platform configuration registers
US20060161790A1 (en) * 2005-01-14 2006-07-20 Microsoft Corporation Systems and methods for controlling access to data on a computer with a secure boot process
US8028172B2 (en) * 2005-01-14 2011-09-27 Microsoft Corporation Systems and methods for updating a secure boot process on a computer with a hardware security module
US7565553B2 (en) 2005-01-14 2009-07-21 Microsoft Corporation Systems and methods for controlling access to data on a computer with a secure boot process
US20060161784A1 (en) * 2005-01-14 2006-07-20 Microsoft Corporation Systems and methods for updating a secure boot process on a computer with a hardware security module
US8453236B2 (en) * 2005-06-30 2013-05-28 Intel Corporation Tamper-aware virtual TPM
US20070006306A1 (en) * 2005-06-30 2007-01-04 Jean-Pierre Seifert Tamper-aware virtual TPM
US7603707B2 (en) * 2005-06-30 2009-10-13 Intel Corporation Tamper-aware virtual TPM
US20100037315A1 (en) * 2005-06-30 2010-02-11 Jean-Pierre Seifert Tamper-aware virtual tpm
US8250374B2 (en) 2006-06-27 2012-08-21 Intel Corporation Method and apparatus for verifying authenticity of initial boot code
US7757098B2 (en) 2006-06-27 2010-07-13 Intel Corporation Method and apparatus for verifying authenticity of initial boot code
US7765392B2 (en) * 2006-06-29 2010-07-27 Intel Corporation Method and apparatus for establishing processor as core root of trust for measurement
US20080005574A1 (en) * 2006-06-29 2008-01-03 Cheng Antonio S Method and apparatus for establishing prosessor as core root of trust for measurement
US20080126590A1 (en) * 2006-06-29 2008-05-29 Rothman Michael A Semiconductor based host protected addressing in computing devices
US8433924B2 (en) * 2006-12-18 2013-04-30 Lenovo (Singapore) Pte. Ltd. Apparatus, system, and method for authentication of a core root of trust measurement chain
US20080148064A1 (en) * 2006-12-18 2008-06-19 David Carroll Challener Apparatus, system, and method for authentication of a core root of trust measurement chain
US20100082987A1 (en) * 2008-09-30 2010-04-01 Microsoft Corporation Transparent trust validation of an unknown platform
US8127146B2 (en) 2008-09-30 2012-02-28 Microsoft Corporation Transparent trust validation of an unknown platform
US20110138116A1 (en) * 2008-10-24 2011-06-09 Lipinski Greg J Direct-attached/network-attached Storage Device
US9626124B2 (en) * 2008-10-24 2017-04-18 Hewlett-Packard Development Company, L.P. Direct-attached/network-attached storage device
US20110099361A1 (en) * 2009-04-15 2011-04-28 Interdigital Patent Holdings, Inc. Validation And/Or Authentication Of A Device For Communication With Network
US8701205B2 (en) * 2009-04-15 2014-04-15 Interdigital Patent Holdings, Inc. Validation and/or authentication of a device for communication with network
WO2014091342A1 (en) * 2012-12-14 2014-06-19 International Business Machines Corporation User trusted device to attest trustworthiness of initialization firmware
US9639690B2 (en) 2012-12-14 2017-05-02 International Business Machines Corporation User trusted device to attest trustworthiness of initialization firmware
US20140359304A1 (en) * 2013-05-30 2014-12-04 Toshiba America Electronic Components, Inc. Trusted manager bridge
US9379892B2 (en) * 2013-05-30 2016-06-28 Toshiba America Electronic Components, Inc. Trusted manager bridge

Also Published As

Publication number Publication date
US20050262571A1 (en) 2005-11-24

Similar Documents

Publication Publication Date Title
US7318150B2 (en) System and method to support platform firmware as a trusted process
US8213618B2 (en) Protecting content on client platforms
JP5378460B2 (en) System and method for protected operating system boot using state verification
US9361462B2 (en) Associating a signing key with a software component of a computing platform
US7421588B2 (en) Apparatus, system, and method for sealing a data repository to a trusted computing platform
US7725703B2 (en) Systems and methods for securely booting a computer with a trusted processing module
US8850212B2 (en) Extending an integrity measurement
US20100115625A1 (en) Policy enforcement in trusted platforms
US20050021968A1 (en) Method for performing a trusted firmware/bios update
EP2126770B1 (en) Trusted computing entities
US11354417B2 (en) Enhanced secure boot
Martin The ten-page introduction to Trusted Computing
Ruan et al. Boot with integrity, or don’t boot
Safford et al. A trusted linux client (tlc)
Cheruvu et al. Base Platform Security Hardware Building Blocks
Zhao Authentication and Data Protection under Strong Adversarial Model
Amato et al. Mobile Systems Secure State Management
Song et al. Check for updates TZ-IMA: Supporting Integrity Measurement for Applications with ARM TrustZone
You et al. KVSEV: A Secure In-Memory Key-Value Store with Secure Encrypted Virtualization
Francis et al. TPM: A More Trustworthy Solution to Computer Security
vor starken Angreifern et al. Trusted Systems in Untrusted Environments: Protecting against Strong Attackers
Akram et al. Trusted Platform Module: State-of-the-Art to Future Challenges

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTEL CORPORATION, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ZIMMER, VINCENT J.;WISEMAN, WILLARD M.;LI, JING;REEL/FRAME:015025/0001;SIGNING DATES FROM 20040223 TO 20040225

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20200108

AS Assignment

Owner name: TAHOE RESEARCH, LTD., IRELAND

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:INTEL CORPORATION;REEL/FRAME:061827/0686

Effective date: 20220718