mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-08 18:23:57 -06:00
tcg: Convert st to TCGOutOpStore
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
e996804d40
commit
4a686aa9d9
11 changed files with 341 additions and 312 deletions
|
@ -2342,12 +2342,38 @@ static const TCGOutOpLoad outop_ld32s = {
|
|||
};
|
||||
#endif
|
||||
|
||||
static void tgen_st8_r(TCGContext *s, TCGType type, TCGReg data,
|
||||
TCGReg base, ptrdiff_t offset)
|
||||
{
|
||||
tcg_out_ldst(s, OPC_SB, data, base, offset);
|
||||
}
|
||||
|
||||
static const TCGOutOpStore outop_st8 = {
|
||||
.base.static_constraint = C_O0_I2(rz, r),
|
||||
.out_r = tgen_st8_r,
|
||||
};
|
||||
|
||||
static void tgen_st16_r(TCGContext *s, TCGType type, TCGReg data,
|
||||
TCGReg base, ptrdiff_t offset)
|
||||
{
|
||||
tcg_out_ldst(s, OPC_SH, data, base, offset);
|
||||
}
|
||||
|
||||
static const TCGOutOpStore outop_st16 = {
|
||||
.base.static_constraint = C_O0_I2(rz, r),
|
||||
.out_r = tgen_st16_r,
|
||||
};
|
||||
|
||||
static const TCGOutOpStore outop_st = {
|
||||
.base.static_constraint = C_O0_I2(rz, r),
|
||||
.out_r = tcg_out_st,
|
||||
};
|
||||
|
||||
|
||||
static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
||||
const TCGArg args[TCG_MAX_OP_ARGS],
|
||||
const int const_args[TCG_MAX_OP_ARGS])
|
||||
{
|
||||
MIPSInsn i1;
|
||||
TCGArg a0, a1, a2;
|
||||
|
||||
a0 = args[0];
|
||||
|
@ -2355,24 +2381,6 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
|||
a2 = args[2];
|
||||
|
||||
switch (opc) {
|
||||
case INDEX_op_st8_i32:
|
||||
case INDEX_op_st8_i64:
|
||||
i1 = OPC_SB;
|
||||
goto do_ldst;
|
||||
case INDEX_op_st16_i32:
|
||||
case INDEX_op_st16_i64:
|
||||
i1 = OPC_SH;
|
||||
goto do_ldst;
|
||||
case INDEX_op_st_i32:
|
||||
case INDEX_op_st32_i64:
|
||||
i1 = OPC_SW;
|
||||
goto do_ldst;
|
||||
case INDEX_op_st_i64:
|
||||
i1 = OPC_SD;
|
||||
do_ldst:
|
||||
tcg_out_ldst(s, i1, a0, a1, a2);
|
||||
break;
|
||||
|
||||
case INDEX_op_qemu_ld_i32:
|
||||
tcg_out_qemu_ld(s, a0, 0, a1, a2, TCG_TYPE_I32);
|
||||
break;
|
||||
|
@ -2407,15 +2415,6 @@ static TCGConstraintSetIndex
|
|||
tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
||||
{
|
||||
switch (op) {
|
||||
case INDEX_op_st8_i32:
|
||||
case INDEX_op_st16_i32:
|
||||
case INDEX_op_st_i32:
|
||||
case INDEX_op_st8_i64:
|
||||
case INDEX_op_st16_i64:
|
||||
case INDEX_op_st32_i64:
|
||||
case INDEX_op_st_i64:
|
||||
return C_O0_I2(rz, r);
|
||||
|
||||
case INDEX_op_qemu_ld_i32:
|
||||
return C_O1_I1(r, r);
|
||||
case INDEX_op_qemu_st_i32:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue