]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
target-i386: Fix CC_OP_CLR vs PF
authorRichard Henderson <rth@twiddle.net>
Fri, 10 Jan 2014 20:38:40 +0000 (12:38 -0800)
committerMichael Roth <mdroth@linux.vnet.ibm.com>
Wed, 25 Jun 2014 16:25:09 +0000 (11:25 -0500)
Parity should be set for a zero result.

Cc: qemu-stable@nongnu.org
Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
Signed-off-by: Richard Henderson <rth@twiddle.net>
(cherry picked from commit d2fe51bda8adf33d07c21e034fdc13a1e1fa4e19)
Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
target-i386/cc_helper.c
target-i386/translate.c

index ee04092b4e5d03edf7e8f466e64a086acd86b086..05dd12b5a771e088432d5d3d8721f0192c3a6600 100644 (file)
@@ -103,7 +103,7 @@ target_ulong helper_cc_compute_all(target_ulong dst, target_ulong src1,
     case CC_OP_EFLAGS:
         return src1;
     case CC_OP_CLR:
-        return CC_Z;
+        return CC_Z | CC_P;
 
     case CC_OP_MULB:
         return compute_all_mulb(dst, src1);
index 7916e5b1f6fd95d0f1a27e51055bd80980f6fa81..b19ea144587b533be0804374a28e1a3c370d3174 100644 (file)
@@ -915,7 +915,7 @@ static void gen_compute_eflags(DisasContext *s)
         return;
     }
     if (s->cc_op == CC_OP_CLR) {
-        tcg_gen_movi_tl(cpu_cc_src, CC_Z);
+        tcg_gen_movi_tl(cpu_cc_src, CC_Z | CC_P);
         set_cc_op(s, CC_OP_EFLAGS);
         return;
     }