diff options
author | Xiao Guangrong <xiaoguangrong@linux.vnet.ibm.com> | 2012-08-21 10:57:42 +0800 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2012-08-22 15:08:49 +0300 |
commit | 8e3d9d061b5d132217629e7b5635ff0c02488e65 (patch) | |
tree | 5af8ab12b3a61d46157d665ad0898b1ad0fc135e /virt/kvm | |
parent | 8fbe6a541f50eeec5e3e49bd92db23ade9496673 (diff) | |
download | linux-8e3d9d061b5d132217629e7b5635ff0c02488e65.tar.gz linux-8e3d9d061b5d132217629e7b5635ff0c02488e65.tar.bz2 linux-8e3d9d061b5d132217629e7b5635ff0c02488e65.zip |
KVM: x86: fix possible infinite loop caused by reexecute_instruction
Currently, we reexecute all unhandleable instructions if they do not
access on the mmio, however, it can not work if host map the readonly
memory to guest. If the instruction try to write this kind of memory,
it will fault again when guest retry it, then we will goto a infinite
loop: retry instruction -> write #PF -> emulation fail ->
retry instruction -> ...
Fix it by retrying the instruction only when it faults on the writable
memory
Signed-off-by: Xiao Guangrong <xiaoguangrong@linux.vnet.ibm.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'virt/kvm')
0 files changed, 0 insertions, 0 deletions