aboutsummaryrefslogtreecommitdiff
path: root/drivers/fpga/altera-hps2fpga.c
diff options
context:
space:
mode:
authorNicholas Piggin <[email protected]>2021-09-08 20:17:18 +1000
committerMichael Ellerman <[email protected]>2021-09-13 22:34:12 +1000
commit267cdfa21385d78c794768233678756e32b39ead (patch)
tree69f3ccc214148e167cc070a8b60bf9f984ae1a2e /drivers/fpga/altera-hps2fpga.c
parentae7aaecc3f2f78b76ab3a8d6178610f55aadfa56 (diff)
KVM: PPC: Book3S HV: Tolerate treclaim. in fake-suspend mode changing registers
POWER9 DD2.2 and 2.3 hardware implements a "fake-suspend" mode where certain TM instructions executed in HV=0 mode cause softpatch interrupts so the hypervisor can emulate them and prevent problematic processor conditions. In this fake-suspend mode, the treclaim. instruction does not modify registers. Unfortunately the rfscv instruction executed by the guest do not generate softpatch interrupts, which can cause the hypervisor to lose track of the fake-suspend mode, and it can execute this treclaim. while not in fake-suspend mode. This modifies GPRs and crashes the hypervisor. It's not trivial to disable scv in the guest with HFSCR now, because they assume a POWER9 has scv available. So this fix saves and restores checkpointed registers across the treclaim. Fixes: 7854f7545bff ("KVM: PPC: Book3S: Rework TM save/restore code and make it C-callable") Signed-off-by: Nicholas Piggin <[email protected]> Signed-off-by: Michael Ellerman <[email protected]> Link: https://lore.kernel.org/r/[email protected]
Diffstat (limited to 'drivers/fpga/altera-hps2fpga.c')
0 files changed, 0 insertions, 0 deletions