From 035b2398264d4b8838d66a8360ca6091f1a107e9 Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Thu, 6 Mar 2014 16:06:24 -0800 Subject: [PATCH] tcg-sparc: Fix small 32-bit movi We tested imm13 before discarding garbage high bits. Signed-off-by: Richard Henderson --- tcg/sparc/tcg-target.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/tcg/sparc/tcg-target.c b/tcg/sparc/tcg-target.c index a977c57d2b..1526f2c2e7 100644 --- a/tcg/sparc/tcg-target.c +++ b/tcg/sparc/tcg-target.c @@ -432,6 +432,11 @@ static void tcg_out_movi(TCGContext *s, TCGType type, { tcg_target_long hi, lo = (int32_t)arg; + /* Make sure we test 32-bit constants for imm13 properly. */ + if (type == TCG_TYPE_I32) { + arg = lo; + } + /* A 13-bit constant sign-extended to 64-bits. */ if (check_fit_tl(arg, 13)) { tcg_out_movi_imm13(s, ret, arg);