target-tricore: fix OPC2_32_RR_DVINIT_HU having write before use on the result
authorBastian Koppelmann <kbastian@mail.uni-paderborn.de>
Fri, 22 May 2015 10:15:56 +0000 (12:15 +0200)
committerBastian Koppelmann <kbastian@mail.uni-paderborn.de>
Sat, 30 May 2015 14:49:14 +0000 (16:49 +0200)
If the argument r1 was the same as the extended result register r3+1, we would
overwrite r1 and then use it.

Signed-off-by: Bastian Koppelmann <kbastian@mail.uni-paderborn.de>
Message-Id: <1432289758-6250-2-git-send-email-kbastian@mail.uni-paderborn.de>

target-tricore/translate.c

index 5f8eff0..6c14843 100644 (file)
@@ -6451,8 +6451,8 @@ static void decode_rr_divide(CPUTriCoreState *env, DisasContext *ctx)
         /* sv */
         tcg_gen_or_tl(cpu_PSW_SV, cpu_PSW_SV, cpu_PSW_V);
         /* write result */
-        tcg_gen_mov_tl(cpu_gpr_d[r3+1], temp3);
         tcg_gen_shli_tl(cpu_gpr_d[r3], cpu_gpr_d[r1], 16);
+        tcg_gen_mov_tl(cpu_gpr_d[r3+1], temp3);
         tcg_temp_free(temp);
         tcg_temp_free(temp2);
         tcg_temp_free(temp3);