audk/ArmPlatformPkg
Ard Biesheuvel 492679a55d ArmPlatformPkg/PrePi: replace set/way cache ops with by-VA ones
Cache maintenance operations by set/way are only intended to be used
in the context of on/offlining a core, while it has been taken out of
the coherency domain. Any use intended to ensure that the contents of
the cache have made it to main memory is unreliable, since cacheline
migration and non-architected system caches may cause these contents
to linger elsewhere, without being visible in main memory once the
MMU and caches are disabled.

In KVM on Linux, there are horrid hacks in place to ensure that such
set/way operations are trapped, and replaced with a single by-VA
clean/invalidate of the entire guest VA space once the MMU state
changes, which can be costly, and is unnecessary if we manage the
caches a bit more carefully, and perform maintenance by virtual
address only.

So let's get rid of the call to ArmInvalidateDataCache () in the
PrePeiCore startup code, and instead, invalidate the UEFI memory
region by virtual address, which is the only memory region we will
be touching with the caches and MMU both disabled and enabled.
(This will lead to data corruption if data written with the MMU off
is shadowed by clean, stale cachelines that stick around when the
MMU is enabled again.)

Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Acked-by: Laszlo Ersek <lersek@redhat.com>
Tested-by: Pete Batard <pete@akeo.ie>
Reviewed-by: Leif Lindholm <leif@nuviainc.com>
2020-03-05 21:08:30 +00:00
..
Drivers ArmPlatformPkg/LcdGraphicsOutputDxe: add missing protocol dependency 2020-03-04 17:42:43 +00:00
Include/Library ArmPlatformPkg: Fix various typos 2019-07-04 12:20:52 +01:00
Library ArmPlatformPkg: Add missing header files in INF file 2019-09-13 18:17:14 +01:00
MemoryInitPei ArmPlatformPkg: Fix various typos 2019-07-04 12:20:52 +01:00
PlatformPei ArmPlatformPkg: Fix various typos 2019-07-04 12:20:52 +01:00
PrePeiCore ArmPlatformPkg/PrePeiCore: replace set/way cache ops with by-VA ones 2020-03-04 17:42:43 +00:00
PrePi ArmPlatformPkg/PrePi: replace set/way cache ops with by-VA ones 2020-03-05 21:08:30 +00:00
Scripts ArmPlatformPkg: convert LFs to CRLF, expand hard TABs 2020-03-04 12:22:07 +00:00
ArmPlatformPkg.dec ArmPlatformPkg: Replace BSD License with BSD+Patent License 2019-04-09 09:10:21 -07:00
ArmPlatformPkg.dsc ArmPlatformPkg: Replace BSD License with BSD+Patent License 2019-04-09 09:10:21 -07:00