The present invention relates generally to microprocessor systems, and more specifically to microprocessor systems that may operate in a trusted or secured environment.
The increasing number of financial and personal transactions being performed on local or remote microcomputers has given impetus for the establishment of “trusted” or “secured” microprocessor environments. The problem these environments try to solve is that of loss of privacy, or data being corrupted or abused. Users do not want their private data made public. They also do not want their data altered or used in inappropriate transactions. Examples of these include unintentional release of medical records or electronic theft of funds from an on-line bank or other depository. Similarly, content providers seek to protect digital content (for example, music, other audio, video, or other types of data in general) from being copied without authorization.
A system that may operate from time to time in either a trusted or an untrusted mode, or both simultaneously, may encounter a security issue with certain error reporting implementations. For example, in the Pentium®-compatible architecture a hardware error reporting system, called a machine-check architecture (MCA), is provided. The MCA may provide a mechanism for detecting and reporting hardware errors, such as system bus errors, error-correcting code (ECC) errors, parity errors, cache errors, and translation look-aside buffer (TLB) errors. The MCA may include a number of MCA-supporting registers that may be used for recording information about errors that may be detected. The MCA registers may have potential security sensitive information written to them in the event of a hardware failure during operation in a trusted mode. To better support the subsequent execution of diagnostic software, the contents of these MCA registers may survive across a processor reset event.
In some processor embodiments, there may be an internal debug flag that may influence access to yet further hardware test and debug hooks. For example, if the internal debug flag is set, access may be granted to internal processor node states that would not be available during normal processor operation. This flag may be set during manufacturing and final test, and cleared during preparation for delivery to an end user. In other embodiments, other control methods for the internal debug flag may be implemented.
The present disclosure is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
The following description describes techniques for limiting the exposure of hardware failure information collected by an error reporting system during secure or trusted mode operation of a processor system. In the following description, numerous specific details such as logic implementations, software module allocation, bus and other interface signaling techniques, and details of operation are set forth in order to provide a more thorough understanding of the present invention. It will be appreciated, however, by one skilled in the art that the invention may be practiced without such specific details. In other instances, control structures, gate level circuits and full software instruction sequences have not been shown in detail in order not to obscure the invention. Those of ordinary skill in the art, with the included descriptions, will be able to implement appropriate functionality without undue experimentation. In certain embodiments, the invention is disclosed in the form of the machine-check architecture (MCA) implemented in Pentium® compatible processors such as those produced by Intel® Corporation. However, the invention may be practiced in other kinds of error reporting systems of other kinds of processors, such as an Itanium Processor Family compatible processor, an X-Scale® family compatible processor, or any of a wide variety of different general-purpose processors from any of the processor architectures of other vendors or designers. Additionally, some embodiments may include or may be special purpose processors, such as graphics, network, image, communications, or any other known or otherwise available type of processor.
Referring now to
A secure virtual machine monitor (SVMM) 150 may selectively permit or prevent direct access to hardware 180 from one or more untrusted operating systems 140 and untrusted applications 110 through 130. In this context, “untrusted” does not necessarily mean that the operating system or applications are deliberately misbehaving, but that the size and variety of interacting code makes it impractical to reliably assert that the software is behaving as desired, and that there are no viruses or other foreign code interfering with its execution. In a typical embodiment, the untrusted code might consist of the normal operating system and applications found on today's personal computers.
SVMM 150 also selectively permits or prevents direct access to hardware 180 from one or more trusted or secure kernels 160 and one or more trusted applications 170. Such a trusted or secure kernel 160 and trusted applications 170 may be limited in size and functionality to aid in the ability to perform trust analysis upon it. The trusted application 170 may be any software code, program, routine, or set of routines which is executable in a secure environment. Thus, the trusted application 170 may be a variety of applications, or code sequences, or may be a relatively small application such as a Java applet.
Instructions or operations normally performed by operating system 140 or kernel 160 that could alter system resource protections or privileges may be trapped by SVMM 150, and selectively permitted, partially permitted, or rejected. As an example, in a typical embodiment, instructions that change the processor's page table that would normally be performed by operating system 140 or kernel 160 would instead be trapped by SVMM 150, which would ensure that the request was not attempting to change page privileges outside the domain of its virtual machine.
The processor or processors within hardware 180 may contain certain special circuits or logic elements to initiate and support secure or trusted operations. For example, a processor may support the execution of special secure mode enter (SENTER) instructions that may initiate trusted operations. When executed, the SENTER instruction may load and initiate the SVMM 150 in a trusted manner, thus initiating trusted operations in a previously untrusted system.
An initiating processor's execution of its SENTER instruction may terminate by transferring execution control to a trusted copy of the system initialization code, which may then perform its system test and configuration actions and may register the memory-resident copy of SVMM 150. Once the trusted system initialization code has completed its execution, the system initialization code may finally transfer the initializing processor's execution control to the SVMM 150. At this time, a secure mode flag may be set true in the processors of hardware 180. In one embodiment, the secure mode flag may be controlled by processor microcode, and may not be visible architecturally. From this point onwards, the overall system may be operating in trusted mode as discussed above.
To leave the trusted mode under the control of the SVMM 150, and thus return to untrusted operations, a secure exit (SEXIT) instruction may be executed. The SEXIT instruction may support the termination of trusted operations and in particular the operation of SVMM 150. At this time, the secure mode flag may be set false in the processors of hardware 180.
Referring now to
The MCA sequencer 210 may be implemented in several differing ways in differing embodiments. In one embodiment, the MCA sequencer 210 may be implemented as a hardware state machine. In other embodiments, MCA sequencer 210 may be implemented as fixed function hardware logic or as processor microcode, or as a combination of fixed function hardware logic and processor microcode. Still other embodiments may implement MCA sequencer 210 by executing processor-trusted software or firmware code that may be stored outside the processors of hardware 280.
Hardware 280 may include a secure mode flag 224. This secure mode flag 224 may be similar to that discussed above in connection with
However, when the secure mode flag is true, the MCA sequencer 210 may still load error status data into a set of MCA status registers 214, error address and other optional miscellaneous data into a set of MCA address and miscellaneous registers 216, but either inhibit loading or mark as invalid a set of machine state data into a set of MCA machine state registers 220. In this manner, error status data that is unlikely to contain security sensitive content, such as what type of error, at which address a memory error was generated, and other similar error status data, may still be placed into the appropriate MCA registers to aid in future debugging. At the same time, the machine state data, which may include such items as the contents of general purpose registers, the instruction pointer, and arithmetic flags, may not be loaded as valid data into the MCA machine state registers. Because the MCA machine state registers may be examined by untrusted software, this would prevent the disclosure of sensitive information if the general purpose registers contained items such as encryption keys, copies of both clear text and encrypted text, credit card numbers, social security numbers, and other kinds of sensitive data.
In some embodiments, the processors in hardware 280 may also include an internal debug flag 226. This internal debug flag 226 may be set (value true) at the time of manufacture of the processor, and cleared at the time of one or more defined events. In one embodiment, these defined events may include a final test or a final manufacturing step, or at the time of release of inventory product to a customer. In one embodiment, a fuse 230 may be blown during this defined event to clear (value false) the flag. In other embodiments, other methods may be used to set and clear the internal debug flag. The internal debug flag 226 may be used to enable certain test and debugging functionality for the processor manufacturer that should not normally be available to the end user of the processor.
In one embodiment, MCA sequencer 210 may also examine the value of the internal debug flag 226. In the cases where the secure mode flag 224 has value false, the value of the internal debug flag 226 would not matter, and the MCA sequencer 210 may proceed to load error status data into a set of MCA status registers 214, error address and other optional miscellaneous data into a set of MCA address and miscellaneous registers 216, and a set of machine state data into a set of MCA machine state registers 220.
In the cases where the secure mode flag 224 has value true, the value of the internal debug flag 226 would matter. When the internal debug flag 226 has value true, then the MCA sequencer 210 may override the status of the secure mode flag 224. In this case, the MCA sequencer 210 may proceed to load error status data into a set of MCA status registers 214, error address and other optional miscellaneous data into a set of MCA address and miscellaneous registers 216, and a set of machine state data into a set of MCA machine state registers 220. When the internal debug flag 226 has value false, then the MCA sequencer 210 may not override the status of the secure mode flag 224. In this case, the MCA sequencer 210 may still load error status data into a set of MCA status registers 214, error address and other optional miscellaneous data into a set of MCA address and miscellaneous registers 216, but then inhibit loading and mark as invalid a set of machine state data into a set of MCA machine state registers 220.
Referring now to
MCA architectural status register 300 may include an MCA error code field to specify the standard error codes, a model-specific error code field to specify the error codes specific to that processor's family, and a number of flag bits. Such flag bits may include a VAL bit to indicate whether the contents of the register are valid, an OVER bit to indicate that a machine-check error occurred while the results of a previous error were still in the register, a UC bit to indicate whether the processor was able to correct the error, and an EN bit to indicate that the error was enabled by a bit in a separate control register (not shown). A pair of flag bits, MISCV and ADDRV, may show if the data in the miscellaneous data register and error address registers, respectively, are valid. These miscellaneous data and error address registers may be included in the MCA address and miscellaneous registers 216 of
Referring now to
Referring now to
In one embodiment, the set of machine-check architecture state registers may include one or more miscellaneous state registers 450. In one embodiment, the miscellaneous state register 450 may contain indications of a page assist or page fault. In addition, the miscellaneous state register 450 may also include a microcode instruction pointer. In one embodiment, the MCA sequencer 210 of
Referring now to
In block 510, the process monitors the MCA activity, looking for the occurrence of errors. In block 514, such an error is detected. Then in block 518 the sequencer may log the hardware error type and source. In one embodiment, this may be performed by writing one or more error codes into a status register and also by writing the address of the code or data memory location that produced the error.
In decision block 522, it may be determined whether the secure mode flag is true. If the answer is no, then the process may exit decision block 522 along the NO path. Then in block 530, the sequencer may log the architectural state of the processor. In one embodiment, this may be performed by writing the contents of the general purpose registers, instruction pointer, and other architectural state variables into a set of machine state registers. In block 534, the sequencer may then ensure that the architectural state registers are indicated as valid. In one embodiment, this may be performed in part by ensuring that the contents of a portion of a miscellaneous state register are a valid combination of bits.
Returning to decision block 522, if the answer is yes, then the process may exit decision block 522 along the YES path. In one embodiment, the process then enters optional decision block 526, while in another embodiment the process directly enters block 538. If decision block 526 is present, then in decision block 526 it may be determined whether an internal debug flag is true. If so, then the process exits decision block 526 along the YES path, and enters block 530. If not, then the process exits decision block 526 along the NO path and enters block 538. In block 538, the architectural state may be prevented from being logged, or may be flagged as being invalid. In one embodiment, this may be performed in part by setting the contents of a portion of a miscellaneous state register to an invalid combination of bits. In one embodiment, the invalid combination of bits may be all “ones”.
Referring now to
The
Memory controller 34 may permit processors 40, 60 to read and write from system memory 10 and from a basic input/output system (BIOS) erasable programmable read-only memory (EPROM) 36. In some embodiments BIOS EPROM 36 may utilize flash memory. Memory controller 34 may include a bus interface 8 to permit memory read and write data to be carried to and from bus agents on system bus 6. Memory controller 34 may also connect with a high-performance graphics circuit 38 across a high-performance graphics interface 39. In certain embodiments the high-performance graphics interface 39 may be an advanced graphics port AGP interface. Memory controller 34 may direct data from system memory 10 to the high-performance graphics circuit 38 across high-performance graphics interface 39.
The
In the
In the foregoing specification, the invention has been described with reference to specific exemplary embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.