diff options
| author | Sean Christopherson <[email protected]> | 2024-02-23 12:42:30 -0800 | 
|---|---|---|
| committer | Sean Christopherson <[email protected]> | 2024-04-09 10:20:29 -0700 | 
| commit | c92be2fd8edf7b300a758c185fe032fd0257b886 (patch) | |
| tree | c6f077e4f821778a71256d948aa014c86395cb0f /drivers/usb/cdns3/cdns3-pci-wrap.c | |
| parent | 87e8e360a05fd29465691aeac179bcf585600c59 (diff) | |
KVM: SVM: Save/restore non-volatile GPRs in SEV-ES VMRUN via host save area
Use the host save area to save/restore non-volatile (callee-saved)
registers in __svm_sev_es_vcpu_run() to take advantage of hardware loading
all registers from the save area on #VMEXIT.  KVM still needs to save the
registers it wants restored, but the loads are handled automatically by
hardware.
Aside from less assembly code, letting hardware do the restoration means
stack frames are preserved for the entirety of __svm_sev_es_vcpu_run().
Opportunistically add a comment to call out why @svm needs to be saved
across VMRUN->#VMEXIT, as it's not easy to decipher that from the macro
hell.
Cc: Tom Lendacky <[email protected]>
Cc: Michael Roth <[email protected]>
Cc: Alexey Kardashevskiy <[email protected]>
Reviewed-by: Tom Lendacky <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Sean Christopherson <[email protected]>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-pci-wrap.c')
0 files changed, 0 insertions, 0 deletions