This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| realtime:documentation:howto:debugging:smi-latency:smi [2018/08/03 11:14] ebugden Add link to MSR documentation | realtime:documentation:howto:debugging:smi-latency:smi [2024/11/24 12:51] (current) costa.shul MSR_SMI_COUNT | ||
|---|---|---|---|
| Line 5: | Line 5: | ||
| ---- | ---- | ||
| - | The operating system has absolutely no control over when SMIs will happen or how long the CPU will subsequently stay in system management mode. In fact, the operating system is not even aware of the transitions to and from SMM. Thankfully, there are some ways to confirm whether or not an SMI has happened. For example, Intel x86 CPUs from after around 2008 (as of the Nehalem microarchitecture) have a model specific register (MSR) that counts the number of SMIs that have occurred in a system ([[https://software.intel.com/en-us/articles/intel-sdm|Intel SDM]], Vol.4 Table 2-14). | + | The operating system has absolutely no control over when SMIs will happen or how long the CPU will subsequently stay in system management mode. In fact, the operating system is not even aware of the transitions to and from SMM. Thankfully, there are some ways to confirm whether or not an SMI has happened. For example, Intel x86 CPUs from after around 2008 (as of the Nehalem microarchitecture) have the [[https://elixir.bootlin.com/linux/v6.12.1/A/ident/MSR_SMI_COUNT|MSR_SMI_COUNT]] model specific register that counts the number of SMIs that have occurred in a system ([[https://software.intel.com/en-us/articles/intel-sdm|Intel SDM]], Vol.4 Table 2-14). | 
| - | The concepts of SMI and SMM are specific to x86, but similar high privilege processor modes exist on some other architectures. For example, on ARM there is a [[https://developer.arm.com/docs/ddi0301/latest/programmers-model/secure-world-and-non-secure-world-operation-with-trustzone/how-the-secure-model-works|Secure Monitor mode]] that manages the switches between the Secure and Non-secure processor states. | + | The concepts of SMI and SMM are specific to x86, but similar high privilege processor modes exist on some other architectures. For example, on ARM there is a [[https://developer.arm.com/documentation/ddi0301/latest/programmer-s-model/secure-world-and-non-secure-world-operation-with-trustzone/how-the-secure-model-works|Secure Monitor mode]] that manages the switches between the Secure and Non-secure processor states. |