]> git.proxmox.com Git - mirror_qemu.git/commitdiff
target-ppc: Fix rlwimi, rlwinm, rlwnm again
authorRichard Henderson <rth@twiddle.net>
Mon, 20 Jun 2016 01:03:37 +0000 (11:03 +1000)
committerDavid Gibson <david@gibson.dropbear.id.au>
Wed, 22 Jun 2016 01:12:17 +0000 (11:12 +1000)
In 63ae0915f8ec, I arranged to use a 32-bit rotate, without
considering the effect of a mask value that wraps around to
the high bits of the word.

[dwg: In 2e11b15 this was partially fixed, but an edge case was still
incorrect, which this fixes]

Signed-off-by: Richard Henderson <rth@twiddle.net>
[dwg: Folded with a revert of 2e11b15, an earlier buggy version of
 this patch which already went upstream]
Tested-by: Anton Blanchard <anton@samba.org>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
target-ppc/translate.c

index 72b67e42cf2509a0dcd616f91063c661a37f19fb..395b885f5b9eea31de0106c5f9c73b61d80e60c5 100644 (file)
@@ -1696,9 +1696,7 @@ static void gen_rlwinm(DisasContext *ctx)
 #endif
         mask = MASK(mb, me);
 
-        if (sh == 0) {
-            tcg_gen_andi_tl(t_ra, t_rs, mask);
-        } else if (mask <= 0xffffffffu) {
+        if (mask <= 0xffffffffu) {
             TCGv_i32 t0 = tcg_temp_new_i32();
             tcg_gen_trunc_tl_i32(t0, t_rs);
             tcg_gen_rotli_i32(t0, t0, sh);