]> Git Repo - qemu.git/commitdiff
tcg-mips: Adjust load/store functions for mips64
authorJin Guojie <[email protected]>
Thu, 5 Jan 2017 04:57:51 +0000 (12:57 +0800)
committerRichard Henderson <[email protected]>
Fri, 6 Jan 2017 18:03:54 +0000 (10:03 -0800)
tcg_out_ldst: using a generic ALIAS_PADD to avoid ifdefs
tcg_out_ld: generates LD or LW
tcg_out_st: generates SD or SW

Tested-by: Aurelien Jarno <[email protected]>
Tested-by: James Hogan <[email protected]>
Tested-by: YunQiang Su <[email protected]>
Signed-off-by: Richard Henderson <[email protected]>
Signed-off-by: Jin Guojie <[email protected]>
Message-Id: <1483592275[email protected]>

tcg/mips/tcg-target.inc.c

index 18368f0b61aa7bec3ff4f37dcab78f8e18045f09..5cc8df3ca14cf433d3ad431b210f9b1360eb68b4 100644 (file)
@@ -697,7 +697,7 @@ static void tcg_out_ldst(TCGContext *s, MIPSInsn opc, TCGReg data,
     if (ofs != lo) {
         tcg_out_movi(s, TCG_TYPE_PTR, TCG_TMP0, ofs - lo);
         if (addr != TCG_REG_ZERO) {
-            tcg_out_opc_reg(s, OPC_ADDU, TCG_TMP0, TCG_TMP0, addr);
+            tcg_out_opc_reg(s, ALIAS_PADD, TCG_TMP0, TCG_TMP0, addr);
         }
         addr = TCG_TMP0;
     }
@@ -707,13 +707,21 @@ static void tcg_out_ldst(TCGContext *s, MIPSInsn opc, TCGReg data,
 static inline void tcg_out_ld(TCGContext *s, TCGType type, TCGReg arg,
                               TCGReg arg1, intptr_t arg2)
 {
-    tcg_out_ldst(s, OPC_LW, arg, arg1, arg2);
+    MIPSInsn opc = OPC_LD;
+    if (TCG_TARGET_REG_BITS == 32 || type == TCG_TYPE_I32) {
+        opc = OPC_LW;
+    }
+    tcg_out_ldst(s, opc, arg, arg1, arg2);
 }
 
 static inline void tcg_out_st(TCGContext *s, TCGType type, TCGReg arg,
                               TCGReg arg1, intptr_t arg2)
 {
-    tcg_out_ldst(s, OPC_SW, arg, arg1, arg2);
+    MIPSInsn opc = OPC_SD;
+    if (TCG_TARGET_REG_BITS == 32 || type == TCG_TYPE_I32) {
+        opc = OPC_SW;
+    }
+    tcg_out_ldst(s, opc, arg, arg1, arg2);
 }
 
 static inline bool tcg_out_sti(TCGContext *s, TCGType type, TCGArg val,
This page took 0.026801 seconds and 4 git commands to generate.