xref: /linux/Documentation/admin-guide/hw-vuln/processor_mmio_stale_data.rst (revision 3f2a5ba784b808109cac0aac921213e43143a216)
1=========================================
2Processor MMIO Stale Data Vulnerabilities
3=========================================
4
5Processor MMIO Stale Data Vulnerabilities are a class of memory-mapped I/O
6(MMIO) vulnerabilities that can expose data. The sequences of operations for
7exposing data range from simple to very complex. Because most of the
8vulnerabilities require the attacker to have access to MMIO, many environments
9are not affected. System environments using virtualization where MMIO access is
10provided to untrusted guests may need mitigation. These vulnerabilities are
11not transient execution attacks. However, these vulnerabilities may propagate
12stale data into core fill buffers where the data can subsequently be inferred
13by an unmitigated transient execution attack. Mitigation for these
14vulnerabilities includes a combination of microcode update and software
15changes, depending on the platform and usage model. Some of these mitigations
16are similar to those used to mitigate Microarchitectural Data Sampling (MDS) or
17those used to mitigate Special Register Buffer Data Sampling (SRBDS).
18
19Data Propagators
20================
21Propagators are operations that result in stale data being copied or moved from
22one microarchitectural buffer or register to another. Processor MMIO Stale Data
23Vulnerabilities are operations that may result in stale data being directly
24read into an architectural, software-visible state or sampled from a buffer or
25register.
26
27Fill Buffer Stale Data Propagator (FBSDP)
28-----------------------------------------
29Stale data may propagate from fill buffers (FB) into the non-coherent portion
30of the uncore on some non-coherent writes. Fill buffer propagation by itself
31does not make stale data architecturally visible. Stale data must be propagated
32to a location where it is subject to reading or sampling.
33
34Sideband Stale Data Propagator (SSDP)
35-------------------------------------
36The sideband stale data propagator (SSDP) is limited to the client (including
37Intel Xeon server E3) uncore implementation. The sideband response buffer is
38shared by all client cores. For non-coherent reads that go to sideband
39destinations, the uncore logic returns 64 bytes of data to the core, including
40both requested data and unrequested stale data, from a transaction buffer and
41the sideband response buffer. As a result, stale data from the sideband
42response and transaction buffers may now reside in a core fill buffer.
43
44Primary Stale Data Propagator (PSDP)
45------------------------------------
46The primary stale data propagator (PSDP) is limited to the client (including
47Intel Xeon server E3) uncore implementation. Similar to the sideband response
48buffer, the primary response buffer is shared by all client cores. For some
49processors, MMIO primary reads will return 64 bytes of data to the core fill
50buffer including both requested data and unrequested stale data. This is
51similar to the sideband stale data propagator.
52
53Vulnerabilities
54===============
55Device Register Partial Write (DRPW) (CVE-2022-21166)
56-----------------------------------------------------
57Some endpoint MMIO registers incorrectly handle writes that are smaller than
58the register size. Instead of aborting the write or only copying the correct
59subset of bytes (for example, 2 bytes for a 2-byte write), more bytes than
60specified by the write transaction may be written to the register. On
61processors affected by FBSDP, this may expose stale data from the fill buffers
62of the core that created the write transaction.
63
64Shared Buffers Data Sampling (SBDS) (CVE-2022-21125)
65----------------------------------------------------
66After propagators may have moved data around the uncore and copied stale data
67into client core fill buffers, processors affected by MFBDS can leak data from
68the fill buffer. It is limited to the client (including Intel Xeon server E3)
69uncore implementation.
70
71Shared Buffers Data Read (SBDR) (CVE-2022-21123)
72------------------------------------------------
73It is similar to Shared Buffer Data Sampling (SBDS) except that the data is
74directly read into the architectural software-visible state. It is limited to
75the client (including Intel Xeon server E3) uncore implementation.
76
77Affected Processors
78===================
79Not all the CPUs are affected by all the variants. For instance, most
80processors for the server market (excluding Intel Xeon E3 processors) are
81impacted by only Device Register Partial Write (DRPW).
82
83Below is the list of affected Intel processors [#f1]_:
84
85   ===================  ============  =========
86   Common name          Family_Model  Steppings
87   ===================  ============  =========
88   HASWELL_X            06_3FH        2,4
89   SKYLAKE_L            06_4EH        3
90   BROADWELL_X          06_4FH        All
91   SKYLAKE_X            06_55H        3,4,6,7,11
92   BROADWELL_D          06_56H        3,4,5
93   SKYLAKE              06_5EH        3
94   ICELAKE_X            06_6AH        4,5,6
95   ICELAKE_D            06_6CH        1
96   ICELAKE_L            06_7EH        5
97   ATOM_TREMONT_D       06_86H        All
98   LAKEFIELD            06_8AH        1
99   KABYLAKE_L           06_8EH        9 to 12
100   ATOM_TREMONT         06_96H        1
101   ATOM_TREMONT_L       06_9CH        0
102   KABYLAKE             06_9EH        9 to 13
103   COMETLAKE            06_A5H        2,3,5
104   COMETLAKE_L          06_A6H        0,1
105   ROCKETLAKE           06_A7H        1
106   ===================  ============  =========
107
108If a CPU is in the affected processor list, but not affected by a variant, it
109is indicated by new bits in MSR IA32_ARCH_CAPABILITIES. As described in a later
110section, mitigation largely remains the same for all the variants, i.e. to
111clear the CPU fill buffers via VERW instruction.
112
113New bits in MSRs
114================
115Newer processors and microcode update on existing affected processors added new
116bits to IA32_ARCH_CAPABILITIES MSR. These bits can be used to enumerate
117specific variants of Processor MMIO Stale Data vulnerabilities and mitigation
118capability.
119
120MSR IA32_ARCH_CAPABILITIES
121--------------------------
122Bit 13 - SBDR_SSDP_NO - When set, processor is not affected by either the
123	 Shared Buffers Data Read (SBDR) vulnerability or the sideband stale
124	 data propagator (SSDP).
125Bit 14 - FBSDP_NO - When set, processor is not affected by the Fill Buffer
126	 Stale Data Propagator (FBSDP).
127Bit 15 - PSDP_NO - When set, processor is not affected by Primary Stale Data
128	 Propagator (PSDP).
129Bit 17 - FB_CLEAR - When set, VERW instruction will overwrite CPU fill buffer
130	 values as part of MD_CLEAR operations. Processors that do not
131	 enumerate MDS_NO (meaning they are affected by MDS) but that do
132	 enumerate support for both L1D_FLUSH and MD_CLEAR implicitly enumerate
133	 FB_CLEAR as part of their MD_CLEAR support.
134Bit 18 - FB_CLEAR_CTRL - Processor supports read and write to MSR
135	 IA32_MCU_OPT_CTRL[FB_CLEAR_DIS]. On such processors, the FB_CLEAR_DIS
136	 bit can be set to cause the VERW instruction to not perform the
137	 FB_CLEAR action. Not all processors that support FB_CLEAR will support
138	 FB_CLEAR_CTRL.
139
140MSR IA32_MCU_OPT_CTRL
141---------------------
142Bit 3 - FB_CLEAR_DIS - When set, VERW instruction does not perform the FB_CLEAR
143action. This may be useful to reduce the performance impact of FB_CLEAR in
144cases where system software deems it warranted (for example, when performance
145is more critical, or the untrusted software has no MMIO access). Note that
146FB_CLEAR_DIS has no impact on enumeration (for example, it does not change
147FB_CLEAR or MD_CLEAR enumeration) and it may not be supported on all processors
148that enumerate FB_CLEAR.
149
150Mitigation
151==========
152Like MDS, all variants of Processor MMIO Stale Data vulnerabilities  have the
153same mitigation strategy to force the CPU to clear the affected buffers before
154an attacker can extract the secrets.
155
156This is achieved by using the otherwise unused and obsolete VERW instruction in
157combination with a microcode update. The microcode clears the affected CPU
158buffers when the VERW instruction is executed.
159
160Kernel does the buffer clearing with x86_clear_cpu_buffers().
161
162On MDS affected CPUs, the kernel already invokes CPU buffer clear on
163kernel/userspace, hypervisor/guest and C-state (idle) transitions. No
164additional mitigation is needed on such CPUs.
165
166For CPUs not affected by MDS or TAA, mitigation is needed only for the attacker
167with MMIO capability. Therefore, VERW is not required for kernel/userspace. For
168virtualization case, VERW is only needed at VMENTER for a guest with MMIO
169capability.
170
171Mitigation points
172-----------------
173Return to user space
174^^^^^^^^^^^^^^^^^^^^
175Same mitigation as MDS when affected by MDS/TAA, otherwise no mitigation
176needed.
177
178C-State transition
179^^^^^^^^^^^^^^^^^^
180Control register writes by CPU during C-state transition can propagate data
181from fill buffer to uncore buffers. Execute VERW before C-state transition to
182clear CPU fill buffers.
183
184Guest entry point
185^^^^^^^^^^^^^^^^^
186Same mitigation as MDS when processor is also affected by MDS/TAA, otherwise
187execute VERW at VMENTER only for MMIO capable guests. On CPUs not affected by
188MDS/TAA, guest without MMIO access cannot extract secrets using Processor MMIO
189Stale Data vulnerabilities, so there is no need to execute VERW for such guests.
190
191Mitigation control on the kernel command line
192---------------------------------------------
193The kernel command line allows to control the Processor MMIO Stale Data
194mitigations at boot time with the option "mmio_stale_data=". The valid
195arguments for this option are:
196
197  ==========  =================================================================
198  full        If the CPU is vulnerable, enable mitigation; CPU buffer clearing
199              on exit to userspace and when entering a VM. Idle transitions are
200              protected as well. It does not automatically disable SMT.
201  full,nosmt  Same as full, with SMT disabled on vulnerable CPUs. This is the
202              complete mitigation.
203  off         Disables mitigation completely.
204  ==========  =================================================================
205
206If the CPU is affected and mmio_stale_data=off is not supplied on the kernel
207command line, then the kernel selects the appropriate mitigation.
208
209Mitigation status information
210-----------------------------
211The Linux kernel provides a sysfs interface to enumerate the current
212vulnerability status of the system: whether the system is vulnerable, and
213which mitigations are active. The relevant sysfs file is:
214
215	/sys/devices/system/cpu/vulnerabilities/mmio_stale_data
216
217The possible values in this file are:
218
219  .. list-table::
220
221     * - 'Not affected'
222       - The processor is not vulnerable
223     * - 'Vulnerable'
224       - The processor is vulnerable, but no mitigation enabled
225     * - 'Vulnerable: Clear CPU buffers attempted, no microcode'
226       - The processor is vulnerable but microcode is not updated. The
227         mitigation is enabled on a best effort basis.
228
229         If the processor is vulnerable but the availability of the microcode
230         based mitigation mechanism is not advertised via CPUID, the kernel
231         selects a best effort mitigation mode. This mode invokes the mitigation
232         instructions without a guarantee that they clear the CPU buffers.
233
234         This is done to address virtualization scenarios where the host has the
235         microcode update applied, but the hypervisor is not yet updated to
236         expose the CPUID to the guest. If the host has updated microcode the
237         protection takes effect; otherwise a few CPU cycles are wasted
238         pointlessly.
239     * - 'Mitigation: Clear CPU buffers'
240       - The processor is vulnerable and the CPU buffer clearing mitigation is
241         enabled.
242     * - 'Unknown: No mitigations'
243       - The processor vulnerability status is unknown because it is
244	 out of Servicing period. Mitigation is not attempted.
245
246Definitions:
247------------
248
249Servicing period: The process of providing functional and security updates to
250Intel processors or platforms, utilizing the Intel Platform Update (IPU)
251process or other similar mechanisms.
252
253End of Servicing Updates (ESU): ESU is the date at which Intel will no
254longer provide Servicing, such as through IPU or other similar update
255processes. ESU dates will typically be aligned to end of quarter.
256
257If the processor is vulnerable then the following information is appended to
258the above information:
259
260  ========================  ===========================================
261  'SMT vulnerable'          SMT is enabled
262  'SMT disabled'            SMT is disabled
263  'SMT Host state unknown'  Kernel runs in a VM, Host SMT state unknown
264  ========================  ===========================================
265
266References
267----------
268.. [#f1] Affected Processors
269   https://www.intel.com/content/www/us/en/developer/topic-technology/software-security-guidance/processors-affected-consolidated-product-cpu-model.html
270