diff options
author | Mark Rutland <mark.rutland@arm.com> | 2018-11-09 18:07:10 +0300 |
---|---|---|
committer | Marc Zyngier <marc.zyngier@arm.com> | 2018-12-18 17:10:36 +0300 |
commit | 0d640732dbebed0f10f18526de21652931f0b2f2 (patch) | |
tree | aa9c116f560d604190b904d0a0b966cdae8e6519 /virt/lib/irqbypass.c | |
parent | 2e6e902d185027f8e3cb8b7305238f7e35d6a436 (diff) | |
download | linux-0d640732dbebed0f10f18526de21652931f0b2f2.tar.xz |
arm64: KVM: Skip MMIO insn after emulation
When we emulate an MMIO instruction, we advance the CPU state within
decode_hsr(), before emulating the instruction effects.
Having this logic in decode_hsr() is opaque, and advancing the state
before emulation is problematic. It gets in the way of applying
consistent single-step logic, and it prevents us from being able to fail
an MMIO instruction with a synchronous exception.
Clean this up by only advancing the CPU state *after* the effects of the
instruction are emulated.
Cc: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Christoffer Dall <christoffer.dall@arm.com>
Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Diffstat (limited to 'virt/lib/irqbypass.c')
0 files changed, 0 insertions, 0 deletions