mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 00:33:55 -06:00
tcg: Convert eqv to TCGOutOpBinary
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
46c68d7506
commit
18bc920916
27 changed files with 89 additions and 106 deletions
|
@ -19,7 +19,6 @@
|
|||
#define TCG_TARGET_HAS_bswap32_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_rot_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 1
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_nor_i32 0
|
||||
#define TCG_TARGET_HAS_clz_i32 1
|
||||
|
@ -43,7 +42,6 @@
|
|||
#define TCG_TARGET_HAS_bswap64_i64 1
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_rot_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 1
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_nor_i64 0
|
||||
#define TCG_TARGET_HAS_clz_i64 1
|
||||
|
|
|
@ -2157,6 +2157,17 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static void tgen_eqv(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
tcg_out_insn(s, 3510, EON, type, a0, a1, a2);
|
||||
}
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_O1_I2(r, r, r),
|
||||
.out_rrr = tgen_eqv,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
@ -2285,17 +2296,6 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType ext,
|
|||
tcg_out_insn(s, 3502, SUB, ext, a0, TCG_REG_XZR, a1);
|
||||
break;
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
a2 = (int32_t)a2;
|
||||
/* FALLTHRU */
|
||||
case INDEX_op_eqv_i64:
|
||||
if (c2) {
|
||||
tcg_out_logicali(s, I3404_EORI, ext, a0, a1, ~a2);
|
||||
} else {
|
||||
tcg_out_insn(s, 3510, EON, ext, a0, a1, a2);
|
||||
}
|
||||
break;
|
||||
|
||||
case INDEX_op_not_i64:
|
||||
case INDEX_op_not_i32:
|
||||
tcg_out_insn(s, 3510, ORN, ext, a0, TCG_REG_XZR, a1);
|
||||
|
@ -3030,10 +3030,6 @@ tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
|||
case INDEX_op_mulsh_i64:
|
||||
return C_O1_I2(r, r, r);
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
case INDEX_op_eqv_i64:
|
||||
return C_O1_I2(r, r, rL);
|
||||
|
||||
case INDEX_op_shl_i32:
|
||||
case INDEX_op_shr_i32:
|
||||
case INDEX_op_sar_i32:
|
||||
|
|
|
@ -28,7 +28,6 @@ extern bool use_neon_instructions;
|
|||
#define TCG_TARGET_HAS_bswap32_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_rot_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 0
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_nor_i32 0
|
||||
#define TCG_TARGET_HAS_clz_i32 1
|
||||
|
|
|
@ -1881,6 +1881,10 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_NotImplemented,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
|
|
@ -31,7 +31,6 @@
|
|||
#define TCG_TARGET_HAS_bswap16_i32 1
|
||||
#define TCG_TARGET_HAS_bswap32_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 0
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_nor_i32 0
|
||||
#define TCG_TARGET_HAS_clz_i32 1
|
||||
|
@ -55,7 +54,6 @@
|
|||
#define TCG_TARGET_HAS_bswap32_i64 1
|
||||
#define TCG_TARGET_HAS_bswap64_i64 1
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 0
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_nor_i64 0
|
||||
#define TCG_TARGET_HAS_clz_i64 1
|
||||
|
|
|
@ -2633,6 +2633,10 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_NotImplemented,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
|
|
@ -25,7 +25,6 @@
|
|||
#define TCG_TARGET_HAS_bswap16_i32 1
|
||||
#define TCG_TARGET_HAS_bswap32_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 0
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_nor_i32 1
|
||||
#define TCG_TARGET_HAS_clz_i32 1
|
||||
|
@ -45,7 +44,6 @@
|
|||
#define TCG_TARGET_HAS_bswap32_i64 1
|
||||
#define TCG_TARGET_HAS_bswap64_i64 1
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 0
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_nor_i64 1
|
||||
#define TCG_TARGET_HAS_clz_i64 1
|
||||
|
|
|
@ -1328,6 +1328,10 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_NotImplemented,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
|
|
@ -43,7 +43,6 @@ extern bool use_mips32r2_instructions;
|
|||
#define TCG_TARGET_HAS_rem_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_nor_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 0
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_mulu2_i32 (!use_mips32r6_instructions)
|
||||
#define TCG_TARGET_HAS_muls2_i32 (!use_mips32r6_instructions)
|
||||
|
@ -61,7 +60,6 @@ extern bool use_mips32r2_instructions;
|
|||
#define TCG_TARGET_HAS_rem_i64 1
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_nor_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 0
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_add2_i64 0
|
||||
#define TCG_TARGET_HAS_sub2_i64 0
|
||||
|
|
|
@ -1712,6 +1712,10 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.base.static_constraint = C_NotImplemented,
|
||||
};
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_NotImplemented,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
|
|
@ -23,7 +23,6 @@
|
|||
#define TCG_TARGET_HAS_bswap16_i32 1
|
||||
#define TCG_TARGET_HAS_bswap32_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 1
|
||||
#define TCG_TARGET_HAS_nand_i32 1
|
||||
#define TCG_TARGET_HAS_nor_i32 1
|
||||
#define TCG_TARGET_HAS_clz_i32 1
|
||||
|
@ -48,7 +47,6 @@
|
|||
#define TCG_TARGET_HAS_bswap32_i64 1
|
||||
#define TCG_TARGET_HAS_bswap64_i64 1
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 1
|
||||
#define TCG_TARGET_HAS_nand_i64 1
|
||||
#define TCG_TARGET_HAS_nor_i64 1
|
||||
#define TCG_TARGET_HAS_clz_i64 1
|
||||
|
|
|
@ -2954,6 +2954,17 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static void tgen_eqv(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
tcg_out32(s, EQV | SAB(a1, a0, a2));
|
||||
}
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_O1_I2(r, r, r),
|
||||
.out_rrr = tgen_eqv,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
@ -3086,15 +3097,6 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
|||
}
|
||||
break;
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
if (const_args[2]) {
|
||||
tcg_out_xori32(s, args[0], args[1], ~args[2]);
|
||||
break;
|
||||
}
|
||||
/* FALLTHRU */
|
||||
case INDEX_op_eqv_i64:
|
||||
tcg_out32(s, EQV | SAB(args[1], args[0], args[2]));
|
||||
break;
|
||||
case INDEX_op_nand_i32:
|
||||
case INDEX_op_nand_i64:
|
||||
tcg_out32(s, NAND | SAB(args[1], args[0], args[2]));
|
||||
|
@ -4150,7 +4152,6 @@ tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
|||
case INDEX_op_st_i64:
|
||||
return C_O0_I2(r, r);
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
case INDEX_op_shl_i32:
|
||||
case INDEX_op_shr_i32:
|
||||
case INDEX_op_sar_i32:
|
||||
|
@ -4175,7 +4176,6 @@ tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
|||
case INDEX_op_nor_i32:
|
||||
case INDEX_op_muluh_i32:
|
||||
case INDEX_op_mulsh_i32:
|
||||
case INDEX_op_eqv_i64:
|
||||
case INDEX_op_nand_i64:
|
||||
case INDEX_op_nor_i64:
|
||||
case INDEX_op_div_i64:
|
||||
|
|
|
@ -16,7 +16,6 @@ C_O1_I1(r, r)
|
|||
C_O1_I2(r, r, r)
|
||||
C_O1_I2(r, r, ri)
|
||||
C_O1_I2(r, r, rI)
|
||||
C_O1_I2(r, r, rJ)
|
||||
C_O1_I2(r, rz, rN)
|
||||
C_O1_I2(r, rz, rz)
|
||||
C_N1_I2(r, r, rM)
|
||||
|
|
|
@ -16,7 +16,6 @@ REGS('v', ALL_VECTOR_REGS)
|
|||
* CONST(letter, TCG_CT_CONST_* bit set)
|
||||
*/
|
||||
CONST('I', TCG_CT_CONST_S12)
|
||||
CONST('J', TCG_CT_CONST_J12)
|
||||
CONST('K', TCG_CT_CONST_S5)
|
||||
CONST('L', TCG_CT_CONST_CMP_VI)
|
||||
CONST('N', TCG_CT_CONST_N12)
|
||||
|
|
|
@ -25,7 +25,6 @@
|
|||
#define TCG_TARGET_HAS_bswap16_i32 (cpuinfo & CPUINFO_ZBB)
|
||||
#define TCG_TARGET_HAS_bswap32_i32 (cpuinfo & CPUINFO_ZBB)
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 (cpuinfo & CPUINFO_ZBB)
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_nor_i32 0
|
||||
#define TCG_TARGET_HAS_clz_i32 (cpuinfo & CPUINFO_ZBB)
|
||||
|
@ -44,7 +43,6 @@
|
|||
#define TCG_TARGET_HAS_bswap32_i64 (cpuinfo & CPUINFO_ZBB)
|
||||
#define TCG_TARGET_HAS_bswap64_i64 (cpuinfo & CPUINFO_ZBB)
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 (cpuinfo & CPUINFO_ZBB)
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_nor_i64 0
|
||||
#define TCG_TARGET_HAS_clz_i64 (cpuinfo & CPUINFO_ZBB)
|
||||
|
|
|
@ -115,9 +115,8 @@ static TCGReg tcg_target_call_oarg_reg(TCGCallReturnKind kind, int slot)
|
|||
#define TCG_CT_CONST_S12 0x100
|
||||
#define TCG_CT_CONST_N12 0x200
|
||||
#define TCG_CT_CONST_M12 0x400
|
||||
#define TCG_CT_CONST_J12 0x800
|
||||
#define TCG_CT_CONST_S5 0x1000
|
||||
#define TCG_CT_CONST_CMP_VI 0x2000
|
||||
#define TCG_CT_CONST_S5 0x800
|
||||
#define TCG_CT_CONST_CMP_VI 0x1000
|
||||
|
||||
#define ALL_GENERAL_REGS MAKE_64BIT_MASK(0, 32)
|
||||
#define ALL_VECTOR_REGS MAKE_64BIT_MASK(32, 32)
|
||||
|
@ -416,13 +415,6 @@ static bool tcg_target_const_match(int64_t val, int ct,
|
|||
if ((ct & TCG_CT_CONST_M12) && val >= -0x7ff && val <= 0x7ff) {
|
||||
return 1;
|
||||
}
|
||||
/*
|
||||
* Inverse of sign extended from 12 bits: ~[-0x800, 0x7ff].
|
||||
* Used to map ANDN back to ANDI, etc.
|
||||
*/
|
||||
if ((ct & TCG_CT_CONST_J12) && ~val >= -0x800 && ~val <= 0x7ff) {
|
||||
return 1;
|
||||
}
|
||||
/*
|
||||
* Sign extended from 5 bits: [-0x10, 0x0f].
|
||||
* Used for vector-immediate.
|
||||
|
@ -2013,6 +2005,18 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static void tgen_eqv(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
tcg_out_opc_reg(s, OPC_XNOR, a0, a1, a2);
|
||||
}
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_Dynamic,
|
||||
.base.dynamic_constraint = cset_zbb_rrr,
|
||||
.out_rrr = tgen_eqv,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
@ -2139,15 +2143,6 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
|||
}
|
||||
break;
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
case INDEX_op_eqv_i64:
|
||||
if (c2) {
|
||||
tcg_out_opc_imm(s, OPC_XORI, a0, a1, ~a2);
|
||||
} else {
|
||||
tcg_out_opc_reg(s, OPC_XNOR, a0, a1, a2);
|
||||
}
|
||||
break;
|
||||
|
||||
case INDEX_op_not_i32:
|
||||
case INDEX_op_not_i64:
|
||||
tcg_out_opc_imm(s, OPC_XORI, a0, a1, -1);
|
||||
|
@ -2710,10 +2705,6 @@ tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
|||
case INDEX_op_negsetcond_i64:
|
||||
return C_O1_I2(r, r, rI);
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
case INDEX_op_eqv_i64:
|
||||
return C_O1_I2(r, r, rJ);
|
||||
|
||||
case INDEX_op_sub_i32:
|
||||
case INDEX_op_sub_i64:
|
||||
return C_O1_I2(r, rz, rN);
|
||||
|
|
|
@ -31,7 +31,6 @@ C_O1_I2(r, r, rC)
|
|||
C_O1_I2(r, r, rI)
|
||||
C_O1_I2(r, r, rJ)
|
||||
C_O1_I2(r, r, rK)
|
||||
C_O1_I2(r, r, rNK)
|
||||
C_O1_I2(r, r, rNKR)
|
||||
C_O1_I2(r, rZ, r)
|
||||
C_O1_I2(v, v, r)
|
||||
|
|
|
@ -34,7 +34,6 @@ extern uint64_t s390_facilities[3];
|
|||
#define TCG_TARGET_HAS_bswap16_i32 1
|
||||
#define TCG_TARGET_HAS_bswap32_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_eqv_i32 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_nand_i32 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_nor_i32 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_clz_i32 0
|
||||
|
@ -57,7 +56,6 @@ extern uint64_t s390_facilities[3];
|
|||
#define TCG_TARGET_HAS_bswap32_i64 1
|
||||
#define TCG_TARGET_HAS_bswap64_i64 1
|
||||
#define TCG_TARGET_HAS_not_i64 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_eqv_i64 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_nand_i64 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_nor_i64 HAVE_FACILITY(MISC_INSN_EXT3)
|
||||
#define TCG_TARGET_HAS_clz_i64 1
|
||||
|
|
|
@ -2242,6 +2242,22 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static void tgen_eqv(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
if (type == TCG_TYPE_I32) {
|
||||
tcg_out_insn(s, RRFa, NXRK, a0, a1, a2);
|
||||
} else {
|
||||
tcg_out_insn(s, RRFa, NXGRK, a0, a1, a2);
|
||||
}
|
||||
}
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_Dynamic,
|
||||
.base.dynamic_constraint = cset_misc3_rrr,
|
||||
.out_rrr = tgen_eqv,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
@ -2376,15 +2392,6 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
|||
}
|
||||
break;
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
a0 = args[0], a1 = args[1], a2 = (uint32_t)args[2];
|
||||
if (const_args[2]) {
|
||||
tcg_out_mov(s, TCG_TYPE_I32, a0, a1);
|
||||
tcg_out_insn(s, RIL, XILF, a0, ~a2);
|
||||
} else {
|
||||
tcg_out_insn(s, RRFa, NXRK, a0, a1, a2);
|
||||
}
|
||||
break;
|
||||
case INDEX_op_nand_i32:
|
||||
tcg_out_insn(s, RRFa, NNRK, args[0], args[1], args[2]);
|
||||
break;
|
||||
|
@ -2595,15 +2602,6 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
|||
}
|
||||
break;
|
||||
|
||||
case INDEX_op_eqv_i64:
|
||||
a0 = args[0], a1 = args[1], a2 = args[2];
|
||||
if (const_args[2]) {
|
||||
tcg_out_mov(s, TCG_TYPE_I64, a0, a1);
|
||||
tgen_xori(s, a0, ~a2);
|
||||
} else {
|
||||
tcg_out_insn(s, RRFa, NXGRK, a0, a1, a2);
|
||||
}
|
||||
break;
|
||||
case INDEX_op_nand_i64:
|
||||
tcg_out_insn(s, RRFa, NNGRK, args[0], args[1], args[2]);
|
||||
break;
|
||||
|
@ -3290,11 +3288,6 @@ tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
|||
case INDEX_op_sub_i64:
|
||||
return C_O1_I2(r, r, ri);
|
||||
|
||||
case INDEX_op_eqv_i32:
|
||||
return C_O1_I2(r, r, ri);
|
||||
case INDEX_op_eqv_i64:
|
||||
return C_O1_I2(r, r, rNK);
|
||||
|
||||
case INDEX_op_nand_i32:
|
||||
case INDEX_op_nand_i64:
|
||||
case INDEX_op_nor_i32:
|
||||
|
|
|
@ -20,7 +20,6 @@ extern bool use_vis3_instructions;
|
|||
#define TCG_TARGET_HAS_bswap16_i32 0
|
||||
#define TCG_TARGET_HAS_bswap32_i32 0
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 0
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_nor_i32 0
|
||||
#define TCG_TARGET_HAS_clz_i32 0
|
||||
|
@ -44,7 +43,6 @@ extern bool use_vis3_instructions;
|
|||
#define TCG_TARGET_HAS_bswap32_i64 0
|
||||
#define TCG_TARGET_HAS_bswap64_i64 0
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 0
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_nor_i64 0
|
||||
#define TCG_TARGET_HAS_clz_i64 0
|
||||
|
|
|
@ -1333,6 +1333,10 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_NotImplemented,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
|
|
@ -20,7 +20,6 @@
|
|||
#define TCG_TARGET_HAS_bswap32_i64 0
|
||||
#define TCG_TARGET_HAS_bswap64_i64 0
|
||||
#define TCG_TARGET_HAS_not_i64 0
|
||||
#define TCG_TARGET_HAS_eqv_i64 0
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_nor_i64 0
|
||||
#define TCG_TARGET_HAS_clz_i64 0
|
||||
|
|
|
@ -680,7 +680,7 @@ void tcg_gen_andc_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2)
|
|||
|
||||
void tcg_gen_eqv_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2)
|
||||
{
|
||||
if (TCG_TARGET_HAS_eqv_i32) {
|
||||
if (tcg_op_supported(INDEX_op_eqv_i32, TCG_TYPE_I32, 0)) {
|
||||
tcg_gen_op3_i32(INDEX_op_eqv_i32, ret, arg1, arg2);
|
||||
} else {
|
||||
tcg_gen_xor_i32(ret, arg1, arg2);
|
||||
|
@ -2279,7 +2279,7 @@ void tcg_gen_eqv_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2)
|
|||
if (TCG_TARGET_REG_BITS == 32) {
|
||||
tcg_gen_eqv_i32(TCGV_LOW(ret), TCGV_LOW(arg1), TCGV_LOW(arg2));
|
||||
tcg_gen_eqv_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), TCGV_HIGH(arg2));
|
||||
} else if (TCG_TARGET_HAS_eqv_i64) {
|
||||
} else if (tcg_op_supported(INDEX_op_eqv_i64, TCG_TYPE_I64, 0)) {
|
||||
tcg_gen_op3_i64(INDEX_op_eqv_i64, ret, arg1, arg2);
|
||||
} else {
|
||||
tcg_gen_xor_i64(ret, arg1, arg2);
|
||||
|
|
|
@ -1007,6 +1007,8 @@ static const TCGOutOp * const all_outop[NB_OPS] = {
|
|||
OUTOP(INDEX_op_add, TCGOutOpBinary, outop_add),
|
||||
OUTOP(INDEX_op_and, TCGOutOpBinary, outop_and),
|
||||
OUTOP(INDEX_op_andc, TCGOutOpBinary, outop_andc),
|
||||
OUTOP(INDEX_op_eqv_i32, TCGOutOpBinary, outop_eqv),
|
||||
OUTOP(INDEX_op_eqv_i64, TCGOutOpBinary, outop_eqv),
|
||||
OUTOP(INDEX_op_or, TCGOutOpBinary, outop_or),
|
||||
OUTOP(INDEX_op_orc, TCGOutOpBinary, outop_orc),
|
||||
OUTOP(INDEX_op_xor, TCGOutOpBinary, outop_xor),
|
||||
|
@ -2273,8 +2275,6 @@ bool tcg_op_supported(TCGOpcode op, TCGType type, unsigned flags)
|
|||
return TCG_TARGET_HAS_bswap32_i32;
|
||||
case INDEX_op_not_i32:
|
||||
return TCG_TARGET_HAS_not_i32;
|
||||
case INDEX_op_eqv_i32:
|
||||
return TCG_TARGET_HAS_eqv_i32;
|
||||
case INDEX_op_nand_i32:
|
||||
return TCG_TARGET_HAS_nand_i32;
|
||||
case INDEX_op_nor_i32:
|
||||
|
@ -2344,8 +2344,6 @@ bool tcg_op_supported(TCGOpcode op, TCGType type, unsigned flags)
|
|||
return TCG_TARGET_HAS_bswap64_i64;
|
||||
case INDEX_op_not_i64:
|
||||
return TCG_TARGET_HAS_not_i64;
|
||||
case INDEX_op_eqv_i64:
|
||||
return TCG_TARGET_HAS_eqv_i64;
|
||||
case INDEX_op_nand_i64:
|
||||
return TCG_TARGET_HAS_nand_i64;
|
||||
case INDEX_op_nor_i64:
|
||||
|
@ -5438,6 +5436,8 @@ static void tcg_reg_alloc_op(TCGContext *s, const TCGOp *op)
|
|||
case INDEX_op_add:
|
||||
case INDEX_op_and:
|
||||
case INDEX_op_andc:
|
||||
case INDEX_op_eqv_i32:
|
||||
case INDEX_op_eqv_i64:
|
||||
case INDEX_op_or:
|
||||
case INDEX_op_orc:
|
||||
case INDEX_op_xor:
|
||||
|
|
|
@ -555,12 +555,10 @@ uintptr_t QEMU_DISABLE_CFI tcg_qemu_tb_exec(CPUArchState *env,
|
|||
tci_args_rrr(insn, &r0, &r1, &r2);
|
||||
regs[r0] = regs[r1] | ~regs[r2];
|
||||
break;
|
||||
#if TCG_TARGET_HAS_eqv_i32 || TCG_TARGET_HAS_eqv_i64
|
||||
CASE_32_64(eqv)
|
||||
tci_args_rrr(insn, &r0, &r1, &r2);
|
||||
regs[r0] = ~(regs[r1] ^ regs[r2]);
|
||||
break;
|
||||
#endif
|
||||
#if TCG_TARGET_HAS_nand_i32 || TCG_TARGET_HAS_nand_i64
|
||||
CASE_32_64(nand)
|
||||
tci_args_rrr(insn, &r0, &r1, &r2);
|
||||
|
|
|
@ -12,7 +12,6 @@
|
|||
#define TCG_TARGET_HAS_div_i32 1
|
||||
#define TCG_TARGET_HAS_rem_i32 1
|
||||
#define TCG_TARGET_HAS_extract2_i32 0
|
||||
#define TCG_TARGET_HAS_eqv_i32 1
|
||||
#define TCG_TARGET_HAS_nand_i32 1
|
||||
#define TCG_TARGET_HAS_nor_i32 1
|
||||
#define TCG_TARGET_HAS_clz_i32 1
|
||||
|
@ -34,7 +33,6 @@
|
|||
#define TCG_TARGET_HAS_extract2_i64 0
|
||||
#define TCG_TARGET_HAS_div_i64 1
|
||||
#define TCG_TARGET_HAS_rem_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 1
|
||||
#define TCG_TARGET_HAS_nand_i64 1
|
||||
#define TCG_TARGET_HAS_nor_i64 1
|
||||
#define TCG_TARGET_HAS_clz_i64 1
|
||||
|
|
|
@ -95,8 +95,6 @@ tcg_target_op_def(TCGOpcode op, TCGType type, unsigned flags)
|
|||
case INDEX_op_sub_i64:
|
||||
case INDEX_op_mul_i32:
|
||||
case INDEX_op_mul_i64:
|
||||
case INDEX_op_eqv_i32:
|
||||
case INDEX_op_eqv_i64:
|
||||
case INDEX_op_nand_i32:
|
||||
case INDEX_op_nand_i64:
|
||||
case INDEX_op_nor_i32:
|
||||
|
@ -662,6 +660,17 @@ static const TCGOutOpBinary outop_andc = {
|
|||
.out_rrr = tgen_andc,
|
||||
};
|
||||
|
||||
static void tgen_eqv(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
tcg_out_op_rrr(s, glue(INDEX_op_eqv_i,TCG_TARGET_REG_BITS), a0, a1, a2);
|
||||
}
|
||||
|
||||
static const TCGOutOpBinary outop_eqv = {
|
||||
.base.static_constraint = C_O1_I2(r, r, r),
|
||||
.out_rrr = tgen_eqv,
|
||||
};
|
||||
|
||||
static void tgen_or(TCGContext *s, TCGType type,
|
||||
TCGReg a0, TCGReg a1, TCGReg a2)
|
||||
{
|
||||
|
@ -739,7 +748,6 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, TCGType type,
|
|||
|
||||
CASE_32_64(sub)
|
||||
CASE_32_64(mul)
|
||||
CASE_32_64(eqv) /* Optional (TCG_TARGET_HAS_eqv_*). */
|
||||
CASE_32_64(nand) /* Optional (TCG_TARGET_HAS_nand_*). */
|
||||
CASE_32_64(nor) /* Optional (TCG_TARGET_HAS_nor_*). */
|
||||
CASE_32_64(shl)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue