KVM: x86: Do not update EFLAGS on faulting emulation
If the emulation ends in fault, eflags should not be updated. However, several instruction emulations (actually all the fastops) currently update eflags, if the fault was detected afterwards (e.g., #PF during writeback). Signed-off-by: Nadav Amit <namit@cs.technion.ac.il> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
		
							parent
							
								
									9d88fca71a
								
							
						
					
					
						commit
						38827dbd3f
					
				| @ -5360,7 +5360,9 @@ restart: | ||||
| 		kvm_rip_write(vcpu, ctxt->eip); | ||||
| 		if (r == EMULATE_DONE) | ||||
| 			kvm_vcpu_check_singlestep(vcpu, rflags, &r); | ||||
| 		__kvm_set_rflags(vcpu, ctxt->eflags); | ||||
| 		if (!ctxt->have_exception || | ||||
| 		    exception_type(ctxt->exception.vector) == EXCPT_TRAP) | ||||
| 			__kvm_set_rflags(vcpu, ctxt->eflags); | ||||
| 
 | ||||
| 		/*
 | ||||
| 		 * For STI, interrupts are shadowed; so KVM_REQ_EVENT will | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user