]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commit
KVM: arm/arm64: Add kvm_ras.h to collect kvm specific RAS plumbing
authorJames Morse <james.morse@arm.com>
Tue, 29 Jan 2019 18:48:49 +0000 (18:48 +0000)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Thu, 7 Feb 2019 22:10:45 +0000 (23:10 +0100)
commit0db5e0223035b2c84e6186831fc27511270af812
tree2951391eada8a4d03477d3373d53c5dae6acd278
parent255097c82d821bb2bb18e9c7011841ee7342840f
KVM: arm/arm64: Add kvm_ras.h to collect kvm specific RAS plumbing

To split up APEIs in_nmi() path, the caller needs to always be
in_nmi(). KVM shouldn't have to know about this, pull the RAS plumbing
out into a header file.

Currently guest synchronous external aborts are claimed as RAS
notifications by handle_guest_sea(), which is hidden in the arch codes
mm/fault.c. 32bit gets a dummy declaration in system_misc.h.

There is going to be more of this in the future if/when the kernel
supports the SError-based firmware-first notification mechanism and/or
kernel-first notifications for both synchronous external abort and
SError. Each of these will come with some Kconfig symbols and a
handful of header files.

Create a header file for all this.

This patch gives handle_guest_sea() a 'kvm_' prefix, and moves the
declarations to kvm_ras.h as preparation for a future patch that moves
the ACPI-specific RAS code out of mm/fault.c.

Signed-off-by: James Morse <james.morse@arm.com>
Reviewed-by: Punit Agrawal <punit.agrawal@arm.com>
Acked-by: Marc Zyngier <marc.zyngier@arm.com>
Tested-by: Tyler Baicar <tbaicar@codeaurora.org>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
arch/arm/include/asm/kvm_ras.h [new file with mode: 0644]
arch/arm/include/asm/system_misc.h
arch/arm64/include/asm/kvm_ras.h [new file with mode: 0644]
arch/arm64/include/asm/system_misc.h
arch/arm64/mm/fault.c
virt/kvm/arm/mmu.c