arm64: KVM: Add Virtual Abort injection helper
Now that we're able to context switch the HCR_EL2.VA bit, let's introduce a helper that injects an Abort into a vcpu. Signed-off-by: Marc Zyngier <marc.zyngier@arm.com> Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
This commit is contained in:
parent
44636f976f
commit
10cf33900f
|
@ -38,6 +38,7 @@ bool kvm_condition_valid32(const struct kvm_vcpu *vcpu);
|
||||||
void kvm_skip_instr32(struct kvm_vcpu *vcpu, bool is_wide_instr);
|
void kvm_skip_instr32(struct kvm_vcpu *vcpu, bool is_wide_instr);
|
||||||
|
|
||||||
void kvm_inject_undefined(struct kvm_vcpu *vcpu);
|
void kvm_inject_undefined(struct kvm_vcpu *vcpu);
|
||||||
|
void kvm_inject_vabt(struct kvm_vcpu *vcpu);
|
||||||
void kvm_inject_dabt(struct kvm_vcpu *vcpu, unsigned long addr);
|
void kvm_inject_dabt(struct kvm_vcpu *vcpu, unsigned long addr);
|
||||||
void kvm_inject_pabt(struct kvm_vcpu *vcpu, unsigned long addr);
|
void kvm_inject_pabt(struct kvm_vcpu *vcpu, unsigned long addr);
|
||||||
|
|
||||||
|
|
|
@ -231,3 +231,15 @@ void kvm_inject_undefined(struct kvm_vcpu *vcpu)
|
||||||
else
|
else
|
||||||
inject_undef64(vcpu);
|
inject_undef64(vcpu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* kvm_inject_vabt - inject an async abort / SError into the guest
|
||||||
|
* @vcpu: The VCPU to receive the exception
|
||||||
|
*
|
||||||
|
* It is assumed that this code is called from the VCPU thread and that the
|
||||||
|
* VCPU therefore is not currently executing guest code.
|
||||||
|
*/
|
||||||
|
void kvm_inject_vabt(struct kvm_vcpu *vcpu)
|
||||||
|
{
|
||||||
|
vcpu_set_hcr(vcpu, vcpu_get_hcr(vcpu) | HCR_VSE);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue