diff options
author | Ard Biesheuvel <ardb@kernel.org> | 2020-12-07 20:40:53 +0300 |
---|---|---|
committer | Ard Biesheuvel <ardb@kernel.org> | 2020-12-09 10:37:27 +0300 |
commit | 4dbe44fb538c59a4adae5abfa9ded2f310250315 (patch) | |
tree | da4f681ca5b596a899337141cf3cfadc185a98b9 /arch/arm64/include/asm/efi.h | |
parent | 91c1c092f27da4164d55ca81e0a483108f8a3235 (diff) | |
download | linux-4dbe44fb538c59a4adae5abfa9ded2f310250315.tar.xz |
efi: capsule: clean scatter-gather entries from the D-cache
Scatter-gather lists passed to UpdateCapsule() should be cleaned
from the D-cache to ensure that they are visible to the CPU after a
warm reboot before the MMU is enabled. On ARM and arm64 systems, this
implies a D-cache clean by virtual address to the point of coherency.
However, due to the fact that the firmware itself is not able to map
physical addresses back to virtual addresses when running under the OS,
this must be done by the caller.
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Diffstat (limited to 'arch/arm64/include/asm/efi.h')
-rw-r--r-- | arch/arm64/include/asm/efi.h | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/arch/arm64/include/asm/efi.h b/arch/arm64/include/asm/efi.h index 973b14415271..00bd1e179d36 100644 --- a/arch/arm64/include/asm/efi.h +++ b/arch/arm64/include/asm/efi.h @@ -141,4 +141,9 @@ static inline void efi_set_pgd(struct mm_struct *mm) void efi_virtmap_load(void); void efi_virtmap_unload(void); +static inline void efi_capsule_flush_cache_range(void *addr, int size) +{ + __flush_dcache_area(addr, size); +} + #endif /* _ASM_EFI_H */ |