arm: KVM: Treat CP15 accessors returning false as successful
authorMarc Zyngier <marc.zyngier@arm.com>
Mon, 27 Mar 2017 16:03:45 +0000 (17:03 +0100)
committerChristoffer Dall <cdall@linaro.org>
Sun, 9 Apr 2017 14:49:17 +0000 (07:49 -0700)
Instead of considering that a CP15 accessor has failed when
returning false, let's consider that it is *always* successful
(after all, we won't stand for an incomplete emulation).

The return value now simply indicates whether we should skip
the instruction (because it has now been emulated), or if we
should leave the PC alone if the emulation has injected an
exception.

Reviewed-by: Christoffer Dall <cdall@linaro.org>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
arch/arm/kvm/coproc.c

index 519aac12b3651f572317aabf4ebd96d6a6e6eeea..2c14b69511e981816861e16b31ed18dce0f2360f 100644 (file)
@@ -520,15 +520,15 @@ static int emulate_cp15(struct kvm_vcpu *vcpu,
                if (likely(r->access(vcpu, params, r))) {
                        /* Skip instruction, since it was emulated */
                        kvm_skip_instr(vcpu, kvm_vcpu_trap_il_is32bit(vcpu));
-                       return 1;
                }
-               /* If access function fails, it should complain. */
        } else {
+               /* If access function fails, it should complain. */
                kvm_err("Unsupported guest CP15 access at: %08lx\n",
                        *vcpu_pc(vcpu));
                print_cp_instr(params);
+               kvm_inject_undefined(vcpu);
        }
-       kvm_inject_undefined(vcpu);
+
        return 1;
 }