|
@@ -38,7 +38,7 @@ static int handle_hvc(struct kvm_vcpu *vcpu, struct kvm_run *run)
|
|
|
|
|
|
ret = kvm_psci_call(vcpu);
|
|
|
if (ret < 0) {
|
|
|
- kvm_inject_undefined(vcpu);
|
|
|
+ vcpu_set_reg(vcpu, 0, ~0UL);
|
|
|
return 1;
|
|
|
}
|
|
|
|
|
@@ -47,7 +47,16 @@ static int handle_hvc(struct kvm_vcpu *vcpu, struct kvm_run *run)
|
|
|
|
|
|
static int handle_smc(struct kvm_vcpu *vcpu, struct kvm_run *run)
|
|
|
{
|
|
|
- kvm_inject_undefined(vcpu);
|
|
|
+ /*
|
|
|
+ * "If an SMC instruction executed at Non-secure EL1 is
|
|
|
+ * trapped to EL2 because HCR_EL2.TSC is 1, the exception is a
|
|
|
+ * Trap exception, not a Secure Monitor Call exception [...]"
|
|
|
+ *
|
|
|
+ * We need to advance the PC after the trap, as it would
|
|
|
+ * otherwise return to the same address...
|
|
|
+ */
|
|
|
+ vcpu_set_reg(vcpu, 0, ~0UL);
|
|
|
+ kvm_skip_instr(vcpu, kvm_vcpu_trap_il_is32bit(vcpu));
|
|
|
return 1;
|
|
|
}
|
|
|
|