mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-27 20:11:00 +00:00
target/arm: Convert T16 one low register and immediate
Backports commit 6c6d237a865041972ec5b226657398f3b3018561 from qemu
This commit is contained in:
parent
d9184b16a9
commit
c690f562c4
|
@ -133,3 +133,14 @@ SUB_rrri 0001101 ... ... ... @addsub_3
|
||||||
|
|
||||||
ADD_rri 0001 110 ... ... ... @addsub_2i
|
ADD_rri 0001 110 ... ... ... @addsub_2i
|
||||||
SUB_rri 0001 111 ... ... ... @addsub_2i
|
SUB_rri 0001 111 ... ... ... @addsub_2i
|
||||||
|
|
||||||
|
# Add, subtract, compare, move (one low register and immediate)
|
||||||
|
|
||||||
|
%reg_8 8:3
|
||||||
|
@arith_1i ..... rd:3 imm:8 \
|
||||||
|
&s_rri_rot rot=0 rn=%reg_8
|
||||||
|
|
||||||
|
MOV_rxi 00100 ... ........ @arith_1i %s
|
||||||
|
CMP_xri 00101 ... ........ @arith_1i s=1
|
||||||
|
ADD_rri 00110 ... ........ @arith_1i %s
|
||||||
|
SUB_rri 00111 ... ........ @arith_1i %s
|
||||||
|
|
|
@ -11057,48 +11057,8 @@ static void disas_thumb_insn(DisasContext *s, uint32_t insn)
|
||||||
store_reg(s, rd, tmp);
|
store_reg(s, rd, tmp);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 2: case 3:
|
case 2: case 3: /* add, sub, cmp, mov (reg, imm), in decodetree */
|
||||||
/*
|
goto illegal_op;
|
||||||
* 0b001x_xxxx_xxxx_xxxx
|
|
||||||
* - Add, subtract, compare, move (one low register and immediate)
|
|
||||||
*/
|
|
||||||
op = (insn >> 11) & 3;
|
|
||||||
rd = (insn >> 8) & 0x7;
|
|
||||||
if (op == 0) { /* mov */
|
|
||||||
tmp = tcg_temp_new_i32(tcg_ctx);
|
|
||||||
tcg_gen_movi_i32(tcg_ctx, tmp, insn & 0xff);
|
|
||||||
if (!s->condexec_mask)
|
|
||||||
gen_logic_CC(s, tmp);
|
|
||||||
store_reg(s, rd, tmp);
|
|
||||||
} else {
|
|
||||||
tmp = load_reg(s, rd);
|
|
||||||
tmp2 = tcg_temp_new_i32(tcg_ctx);
|
|
||||||
tcg_gen_movi_i32(tcg_ctx, tmp2, insn & 0xff);
|
|
||||||
switch (op) {
|
|
||||||
case 1: /* cmp */
|
|
||||||
gen_sub_CC(s, tmp, tmp, tmp2);
|
|
||||||
tcg_temp_free_i32(tcg_ctx, tmp);
|
|
||||||
tcg_temp_free_i32(tcg_ctx, tmp2);
|
|
||||||
break;
|
|
||||||
case 2: /* add */
|
|
||||||
if (s->condexec_mask)
|
|
||||||
tcg_gen_add_i32(tcg_ctx, tmp, tmp, tmp2);
|
|
||||||
else
|
|
||||||
gen_add_CC(s, tmp, tmp, tmp2);
|
|
||||||
tcg_temp_free_i32(tcg_ctx, tmp2);
|
|
||||||
store_reg(s, rd, tmp);
|
|
||||||
break;
|
|
||||||
case 3: /* sub */
|
|
||||||
if (s->condexec_mask)
|
|
||||||
tcg_gen_sub_i32(tcg_ctx, tmp, tmp, tmp2);
|
|
||||||
else
|
|
||||||
gen_sub_CC(s, tmp, tmp, tmp2);
|
|
||||||
tcg_temp_free_i32(tcg_ctx, tmp2);
|
|
||||||
store_reg(s, rd, tmp);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 4:
|
case 4:
|
||||||
if (insn & (1 << 11)) {
|
if (insn & (1 << 11)) {
|
||||||
rd = (insn >> 8) & 7;
|
rd = (insn >> 8) & 7;
|
||||||
|
|
Loading…
Reference in a new issue