Hi, this line almost ruined my afternoon: diff --git a/qemu/qemu-kvm-x86.c b/qemu/qemu-kvm-x86.c index 01748ed..4ad386b 100644 --- a/qemu/qemu-kvm-x86.c +++ b/qemu/qemu-kvm-x86.c @@ -429,7 +429,6 @@ void kvm_arch_save_regs(CPUState *env) env->cc_src = env->eflags & (CC_O | CC_S | CC_Z | CC_A | CC_P | CC_C); env->df = 1 - (2 * ((env->eflags >> 10) & 1)); env->cc_op = CC_OP_EFLAGS; - env->eflags &= ~(DF_MASK | CC_O | CC_S | CC_Z | CC_A | CC_P | CC_C); /* msrs */ n = 0; The guest flags reported via gdb or monitor were garbage and I first didn't realized this... git logs revealed that commit 6eecdc3eea74ead3c11b8b43d825d2cabe7a2456 once introduced it mid of 2006, but maybe under different boundary conditions. At least today it appears to be plain wrong, eflags must always contain to full state, cc_src, df & cc_op are just supplementary states. Please correct me if I'm wrong, otherwise I will send out a proper patch, also upstream as QEMU's kvm suffers from the same issue. Jan -- Siemens AG, Corporate Technology, CT SE 2 Corporate Competence Center Embedded Linux -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html