mirror of
https://git.proxmox.com/git/qemu
synced 2025-08-07 22:13:08 +00:00
target-xtensa: implement LSCX and LSCI groups
These are load/store instructions for FP registers with immediate or register index and optional base post-update. See ISA, 4.3.10 for more details. Signed-off-by: Max Filippov <jcmvbkbc@gmail.com> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
dd519cbec6
commit
9ed7ae12af
@ -1843,8 +1843,33 @@ static void disas_xtensa_insn(DisasContext *dc)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 8: /*LSCXp*/
|
case 8: /*LSCXp*/
|
||||||
HAS_OPTION(XTENSA_OPTION_COPROCESSOR);
|
switch (OP2) {
|
||||||
TBD();
|
case 0: /*LSXf*/
|
||||||
|
case 1: /*LSXUf*/
|
||||||
|
case 4: /*SSXf*/
|
||||||
|
case 5: /*SSXUf*/
|
||||||
|
HAS_OPTION(XTENSA_OPTION_FP_COPROCESSOR);
|
||||||
|
gen_window_check2(dc, RRR_S, RRR_T);
|
||||||
|
{
|
||||||
|
TCGv_i32 addr = tcg_temp_new_i32();
|
||||||
|
tcg_gen_add_i32(addr, cpu_R[RRR_S], cpu_R[RRR_T]);
|
||||||
|
gen_load_store_alignment(dc, 2, addr, false);
|
||||||
|
if (OP2 & 0x4) {
|
||||||
|
tcg_gen_qemu_st32(cpu_FR[RRR_R], addr, dc->cring);
|
||||||
|
} else {
|
||||||
|
tcg_gen_qemu_ld32u(cpu_FR[RRR_R], addr, dc->cring);
|
||||||
|
}
|
||||||
|
if (OP2 & 0x1) {
|
||||||
|
tcg_gen_mov_i32(cpu_R[RRR_S], addr);
|
||||||
|
}
|
||||||
|
tcg_temp_free(addr);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default: /*reserved*/
|
||||||
|
RESERVED();
|
||||||
|
break;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 9: /*LSC4*/
|
case 9: /*LSC4*/
|
||||||
@ -2118,8 +2143,33 @@ static void disas_xtensa_insn(DisasContext *dc)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 3: /*LSCIp*/
|
case 3: /*LSCIp*/
|
||||||
HAS_OPTION(XTENSA_OPTION_COPROCESSOR);
|
switch (RRI8_R) {
|
||||||
TBD();
|
case 0: /*LSIf*/
|
||||||
|
case 4: /*SSIf*/
|
||||||
|
case 8: /*LSIUf*/
|
||||||
|
case 12: /*SSIUf*/
|
||||||
|
HAS_OPTION(XTENSA_OPTION_FP_COPROCESSOR);
|
||||||
|
gen_window_check1(dc, RRI8_S);
|
||||||
|
{
|
||||||
|
TCGv_i32 addr = tcg_temp_new_i32();
|
||||||
|
tcg_gen_addi_i32(addr, cpu_R[RRI8_S], RRI8_IMM8 << 2);
|
||||||
|
gen_load_store_alignment(dc, 2, addr, false);
|
||||||
|
if (RRI8_R & 0x4) {
|
||||||
|
tcg_gen_qemu_st32(cpu_FR[RRI8_T], addr, dc->cring);
|
||||||
|
} else {
|
||||||
|
tcg_gen_qemu_ld32u(cpu_FR[RRI8_T], addr, dc->cring);
|
||||||
|
}
|
||||||
|
if (RRI8_R & 0x8) {
|
||||||
|
tcg_gen_mov_i32(cpu_R[RRI8_S], addr);
|
||||||
|
}
|
||||||
|
tcg_temp_free(addr);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default: /*reserved*/
|
||||||
|
RESERVED();
|
||||||
|
break;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4: /*MAC16d*/
|
case 4: /*MAC16d*/
|
||||||
|
Loading…
Reference in New Issue
Block a user