diff options
| author | Andi Kleen <ak@linux.intel.com> | 2024-08-07 17:02:44 -0700 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2024-08-08 17:03:12 +0200 | 
| commit | 919f18f961c03d6694aa726c514184f2311a4614 (patch) | |
| tree | 435c8edf7c8d5721948e7d241619ff029f0b8fd8 /rust/helpers/xarray.c | |
| parent | e639222a51196c69c70b49b67098ce2f9919ed08 (diff) | |
x86/mtrr: Check if fixed MTRRs exist before saving them
MTRRs have an obsolete fixed variant for fine grained caching control
of the 640K-1MB region that uses separate MSRs. This fixed variant has
a separate capability bit in the MTRR capability MSR.
So far all x86 CPUs which support MTRR have this separate bit set, so it
went unnoticed that mtrr_save_state() does not check the capability bit
before accessing the fixed MTRR MSRs.
Though on a CPU that does not support the fixed MTRR capability this
results in a #GP.  The #GP itself is harmless because the RDMSR fault is
handled gracefully, but results in a WARN_ON().
Add the missing capability check to prevent this.
Fixes: 2b1f6278d77c ("[PATCH] x86: Save the MTRRs of the BSP before booting an AP")
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/all/20240808000244.946864-1-ak@linux.intel.com
Diffstat (limited to 'rust/helpers/xarray.c')
0 files changed, 0 insertions, 0 deletions
