mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-08-31 22:23:05 +00:00

Userspace will soon be able to change the value of MIDR_EL1. Prepare by loading VPIDR_EL2 with the guest value for non-nested VMs. Since VPIDR_EL2 is set for any VM, get rid of the NV-specific cleanup of reloading the hardware value on vcpu_put(). And for nVHE, load the hardware value before switching to the host. Link: https://lore.kernel.org/r/20250225005401.679536-4-oliver.upton@linux.dev Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
38 lines
878 B
C
38 lines
878 B
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Copyright (C) 2012-2015 - ARM Ltd
|
|
* Author: Marc Zyngier <marc.zyngier@arm.com>
|
|
*/
|
|
|
|
#include <hyp/sysreg-sr.h>
|
|
|
|
#include <linux/compiler.h>
|
|
#include <linux/kvm_host.h>
|
|
|
|
#include <asm/kprobes.h>
|
|
#include <asm/kvm_asm.h>
|
|
#include <asm/kvm_emulate.h>
|
|
#include <asm/kvm_hyp.h>
|
|
|
|
/*
|
|
* Non-VHE: Both host and guest must save everything.
|
|
*/
|
|
|
|
void __sysreg_save_state_nvhe(struct kvm_cpu_context *ctxt)
|
|
{
|
|
__sysreg_save_el1_state(ctxt);
|
|
__sysreg_save_common_state(ctxt);
|
|
__sysreg_save_user_state(ctxt);
|
|
__sysreg_save_el2_return_state(ctxt);
|
|
}
|
|
|
|
void __sysreg_restore_state_nvhe(struct kvm_cpu_context *ctxt)
|
|
{
|
|
u64 midr = ctxt_midr_el1(ctxt);
|
|
|
|
__sysreg_restore_el1_state(ctxt, midr, ctxt_sys_reg(ctxt, MPIDR_EL1));
|
|
__sysreg_restore_common_state(ctxt);
|
|
__sysreg_restore_user_state(ctxt);
|
|
__sysreg_restore_el2_return_state(ctxt);
|
|
}
|