tcg/loongarch64: Lower rotli_vec to vrotri
Signed-off-by: Jiajie Chen <c@jia.je> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20230908022302.180442-16-c@jia.je> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
0765cce114
commit
561b001aef
@ -1902,6 +1902,26 @@ static void tcg_out_vec_op(TCGContext *s, TCGOpcode opc,
|
|||||||
tcg_out32(s, encode_vdvjvk_insn(rotrv_vec_insn[vece], a0, a1,
|
tcg_out32(s, encode_vdvjvk_insn(rotrv_vec_insn[vece], a0, a1,
|
||||||
temp_vec));
|
temp_vec));
|
||||||
break;
|
break;
|
||||||
|
case INDEX_op_rotli_vec:
|
||||||
|
/* rotli_vec a1, a2 = rotri_vec a1, -a2 */
|
||||||
|
a2 = extract32(-a2, 0, 3 + vece);
|
||||||
|
switch (vece) {
|
||||||
|
case MO_8:
|
||||||
|
tcg_out_opc_vrotri_b(s, a0, a1, a2);
|
||||||
|
break;
|
||||||
|
case MO_16:
|
||||||
|
tcg_out_opc_vrotri_h(s, a0, a1, a2);
|
||||||
|
break;
|
||||||
|
case MO_32:
|
||||||
|
tcg_out_opc_vrotri_w(s, a0, a1, a2);
|
||||||
|
break;
|
||||||
|
case MO_64:
|
||||||
|
tcg_out_opc_vrotri_d(s, a0, a1, a2);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
g_assert_not_reached();
|
||||||
|
}
|
||||||
|
break;
|
||||||
case INDEX_op_bitsel_vec:
|
case INDEX_op_bitsel_vec:
|
||||||
/* vbitsel vd, vj, vk, va = bitsel_vec vd, va, vk, vj */
|
/* vbitsel vd, vj, vk, va = bitsel_vec vd, va, vk, vj */
|
||||||
tcg_out_opc_vbitsel_v(s, a0, a3, a2, a1);
|
tcg_out_opc_vbitsel_v(s, a0, a3, a2, a1);
|
||||||
@ -2140,6 +2160,7 @@ static TCGConstraintSetIndex tcg_target_op_def(TCGOpcode op)
|
|||||||
case INDEX_op_shli_vec:
|
case INDEX_op_shli_vec:
|
||||||
case INDEX_op_shri_vec:
|
case INDEX_op_shri_vec:
|
||||||
case INDEX_op_sari_vec:
|
case INDEX_op_sari_vec:
|
||||||
|
case INDEX_op_rotli_vec:
|
||||||
return C_O1_I1(w, w);
|
return C_O1_I1(w, w);
|
||||||
|
|
||||||
case INDEX_op_bitsel_vec:
|
case INDEX_op_bitsel_vec:
|
||||||
|
@ -189,7 +189,7 @@ extern bool use_lsx_instructions;
|
|||||||
#define TCG_TARGET_HAS_shi_vec 1
|
#define TCG_TARGET_HAS_shi_vec 1
|
||||||
#define TCG_TARGET_HAS_shs_vec 0
|
#define TCG_TARGET_HAS_shs_vec 0
|
||||||
#define TCG_TARGET_HAS_shv_vec 1
|
#define TCG_TARGET_HAS_shv_vec 1
|
||||||
#define TCG_TARGET_HAS_roti_vec 0
|
#define TCG_TARGET_HAS_roti_vec 1
|
||||||
#define TCG_TARGET_HAS_rots_vec 0
|
#define TCG_TARGET_HAS_rots_vec 0
|
||||||
#define TCG_TARGET_HAS_rotv_vec 1
|
#define TCG_TARGET_HAS_rotv_vec 1
|
||||||
#define TCG_TARGET_HAS_sat_vec 1
|
#define TCG_TARGET_HAS_sat_vec 1
|
||||||
|
Loading…
Reference in New Issue
Block a user