From: Ashish Kalra <ashish.kalra@xxxxxxx> The patchset adds bits and pieces to get kexec (and crashkernel) work on SNP guest. This patchset requires the following fix for preventing EFI memory map corruption while doing SNP guest kexec: https://lore.kernel.org/all/16131a10-b473-41cc-a96e-d71a4d930353@xxxxxxx/T/#m77f2f33f5521d1369b0e8d461802b99005b4ffd6 The series is based off of and tested against Kirill Shutemov's tree: https://github.com/intel/tdx.git guest-kexec ---- v8: - removed fix EFI memory map corruption with kexec patch as this is a use-after-free bug that is not specific to SNP/TDX or kexec and a generic fix for the same has been posted. - Add new early_sev_detect() and move detection of SEV-ES/SNP guest and skip accessing video RAM during decompressor stage into this function as per feedback from upstream review. v7: - Rebased onto current tip/master; - Moved back to checking the md attribute instead of checking the efi_setup for detecting if running under kexec kernel as suggested in upstream review feedback. v6: - Updated and restructured the commit message for patch 1/3 to explain the issue in detail. - Updated inline comments in patch 1/3 to explain the issue in detail. - Moved back to checking efi_setup for detecting if running under kexec kernel. v5: - Removed sev_es_enabled() function and using sev_status directly to check for SEV-ES/SEV-SNP guest. - used --base option to generate patches to specify Kirill's TDX guest kexec patches as prerequisite patches to fix kernel test robot build errors. v4: - Rebased to current tip/master. - Reviewed-bys from Sathya. - Remove snp_kexec_unprep_rom_memory() as it is not needed any more as SEV-SNP code is not validating the ROM range in probe_roms() anymore. - Fix kernel test robot build error/warnings. v3: - Rebased; - moved Keep page tables that maps E820_TYPE_ACPI patch to Kirill's tdx guest kexec patch series. - checking the md attribute instead of checking the efi_setup for detecting if running under kexec kernel. - added new sev_es_enabled() function. - skip video memory access in decompressor for SEV-ES/SNP systems to prevent guest termination as boot stage2 #VC handler does not handle MMIO. v2: - address zeroing of unaccepted memory table mappings at all page table levels adding phys_pte_init(), phys_pud_init() and phys_p4d_init(). - include skip efi_arch_mem_reserve() in case of kexec as part of this patch set. - rename last_address_shd_kexec to a more appropriate kexec_last_address_to_make_private. - remove duplicate code shared with TDX and use common interfaces defined for SNP and TDX for kexec/kdump. - remove set_pte_enc() dependency on pg_level_to_pfn() and make the function simpler. - rename unshare_pte() to make_pte_private(). - clarify and make the comment for using kexec_last_address_to_make_private more understandable. - general cleanup. Ashish Kalra (2): x86/boot/compressed: Skip Video Memory access in Decompressor for SEV-ES/SNP. x86/snp: Convert shared memory back to private on kexec arch/x86/boot/compressed/misc.c | 23 +++++ arch/x86/include/asm/sev.h | 4 + arch/x86/kernel/sev.c | 168 ++++++++++++++++++++++++++++++++ arch/x86/mm/mem_encrypt_amd.c | 3 + 4 files changed, 198 insertions(+) base-commit: f87c20c019e22be5f2efd11bf9141a532ae876da prerequisite-patch-id: a911f230c2524bd791c47f62f17f0a93cbf726b6 prerequisite-patch-id: bfe2fa046349978ac1825275eb205acecfbc22f3 prerequisite-patch-id: 36fe38a0547bcc26048bd1c5568d736344173d0a prerequisite-patch-id: 1f97d0a2edb7509dd58276f628d1a4bda62c154c prerequisite-patch-id: c890aed9c68e5f6dec8e640194950f0abeddb68c prerequisite-patch-id: 17a7d996d9af56c6b24a2374e9e498feafe18216 prerequisite-patch-id: 6a8bda2b3cf9bfab8177acdcfc8dd0408ed129fa prerequisite-patch-id: 99382c42348b9a076ba930eca0dfc9d000ec951d prerequisite-patch-id: 469a0a3c78b0eca82527cd85e2205fb8fb89d645 prerequisite-patch-id: fda4eb74abfdee49760e508ee6f3b661d52ceb26 prerequisite-patch-id: 6da1f25b8b1646f326911eb10c05f3821343313e prerequisite-patch-id: 95356474298029468750a9c1bc2224fb09a86eed prerequisite-patch-id: d4966ae63e86d24b0bf578da4dae871cd9002b12 prerequisite-patch-id: fccde6f1fa385b5af0195f81fcb95acd71822428 prerequisite-patch-id: 16048ee15e392b0b9217b8923939b0059311abd2 prerequisite-patch-id: 5c9ae9aa294f72f63ae2c3551507dfbd92525803 prerequisite-patch-id: 6bd2e291bfdb1f61b6d194899d3bb3c678d534dd prerequisite-patch-id: c85fd0bb6d183a40da73720eaa607481b1d51daf prerequisite-patch-id: 60760e0c98ab7ccd2ca22ae3e9f20ff5a94c6e91 -- 2.34.1 _______________________________________________ kexec mailing list kexec@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/kexec