Use Octeon decodetree to call gen_lx() for the LX instructions.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
---
target/mips/tcg/octeon.decode | 8 ++++++++
target/mips/tcg/octeon_translate.c | 12 ++++++++++++
target/mips/tcg/translate.c | 4 +---
3 files changed, 21 insertions(+), 3 deletions(-)
diff --git a/target/mips/tcg/octeon.decode b/target/mips/tcg/octeon.decode
index 0c787cb498..102a05860d 100644
--- a/target/mips/tcg/octeon.decode
+++ b/target/mips/tcg/octeon.decode
@@ -1,6 +1,7 @@
# Octeon Architecture Module instruction set
#
# Copyright (C) 2022 Pavel Dovgalyuk
+# Copyright (C) 2024 Philippe Mathieu-Daudé
#
# SPDX-License-Identifier: LGPL-2.1-or-later
#
@@ -39,3 +40,10 @@ CINS 011100 ..... ..... ..... ..... 11001 . @bitfield
POP 011100 rs:5 00000 rd:5 00000 10110 dw:1
SEQNE 011100 rs:5 rt:5 rd:5 00000 10101 ne:1
SEQNEI 011100 rs:5 rt:5 imm:s10 10111 ne:1
+
+&lx base index rd
+@lx ...... base:5 index:5 rd:5 ...... ..... &lx
+LWX 011111 ..... ..... ..... 00000 001010 @lx
+LHX 011111 ..... ..... ..... 00100 001010 @lx
+LBUX 011111 ..... ..... ..... 00110 001010 @lx
+LDX 011111 ..... ..... ..... 01000 001010 @lx
diff --git a/target/mips/tcg/octeon_translate.c b/target/mips/tcg/octeon_translate.c
index e25c4cbaa0..0e0b00303a 100644
--- a/target/mips/tcg/octeon_translate.c
+++ b/target/mips/tcg/octeon_translate.c
@@ -174,3 +174,15 @@ static bool trans_SEQNEI(DisasContext *ctx, arg_SEQNEI *a)
}
return true;
}
+
+static bool trans_lx(DisasContext *ctx, arg_lx *a, MemOp mop)
+{
+ gen_lx(ctx, a->rd, a->base, a->index, mop);
+
+ return true;
+}
+
+TRANS(LBUX, trans_lx, MO_UB);
+TRANS(LHX, trans_lx, MO_SW);
+TRANS(LWX, trans_lx, MO_SL);
+TRANS(LDX, trans_lx, MO_UQ);
diff --git a/target/mips/tcg/translate.c b/target/mips/tcg/translate.c
index acadd3d891..6fd5462a24 100644
--- a/target/mips/tcg/translate.c
+++ b/target/mips/tcg/translate.c
@@ -13583,9 +13583,7 @@ static void decode_opc_special3_legacy(CPUMIPSState *env, DisasContext *ctx)
}
break;
case OPC_LX_DSP:
- if (!(ctx->insn_flags & INSN_OCTEON)) {
- check_dsp(ctx);
- }
+ check_dsp(ctx);
op2 = MASK_LX(ctx->opcode);
switch (op2) {
#if defined(TARGET_MIPS64)
--
2.45.2
Reviewed-by: Pavel Dovgalyuk <Pavel.Dovgalyuk@ispras.ru> On 12.11.2024 01:29, Philippe Mathieu-Daudé wrote: > Use Octeon decodetree to call gen_lx() for the LX instructions. > > Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> > --- > target/mips/tcg/octeon.decode | 8 ++++++++ > target/mips/tcg/octeon_translate.c | 12 ++++++++++++ > target/mips/tcg/translate.c | 4 +--- > 3 files changed, 21 insertions(+), 3 deletions(-) > > diff --git a/target/mips/tcg/octeon.decode b/target/mips/tcg/octeon.decode > index 0c787cb498..102a05860d 100644 > --- a/target/mips/tcg/octeon.decode > +++ b/target/mips/tcg/octeon.decode > @@ -1,6 +1,7 @@ > # Octeon Architecture Module instruction set > # > # Copyright (C) 2022 Pavel Dovgalyuk > +# Copyright (C) 2024 Philippe Mathieu-Daudé > # > # SPDX-License-Identifier: LGPL-2.1-or-later > # > @@ -39,3 +40,10 @@ CINS 011100 ..... ..... ..... ..... 11001 . @bitfield > POP 011100 rs:5 00000 rd:5 00000 10110 dw:1 > SEQNE 011100 rs:5 rt:5 rd:5 00000 10101 ne:1 > SEQNEI 011100 rs:5 rt:5 imm:s10 10111 ne:1 > + > +&lx base index rd > +@lx ...... base:5 index:5 rd:5 ...... ..... &lx > +LWX 011111 ..... ..... ..... 00000 001010 @lx > +LHX 011111 ..... ..... ..... 00100 001010 @lx > +LBUX 011111 ..... ..... ..... 00110 001010 @lx > +LDX 011111 ..... ..... ..... 01000 001010 @lx > diff --git a/target/mips/tcg/octeon_translate.c b/target/mips/tcg/octeon_translate.c > index e25c4cbaa0..0e0b00303a 100644 > --- a/target/mips/tcg/octeon_translate.c > +++ b/target/mips/tcg/octeon_translate.c > @@ -174,3 +174,15 @@ static bool trans_SEQNEI(DisasContext *ctx, arg_SEQNEI *a) > } > return true; > } > + > +static bool trans_lx(DisasContext *ctx, arg_lx *a, MemOp mop) > +{ > + gen_lx(ctx, a->rd, a->base, a->index, mop); > + > + return true; > +} > + > +TRANS(LBUX, trans_lx, MO_UB); > +TRANS(LHX, trans_lx, MO_SW); > +TRANS(LWX, trans_lx, MO_SL); > +TRANS(LDX, trans_lx, MO_UQ); > diff --git a/target/mips/tcg/translate.c b/target/mips/tcg/translate.c > index acadd3d891..6fd5462a24 100644 > --- a/target/mips/tcg/translate.c > +++ b/target/mips/tcg/translate.c > @@ -13583,9 +13583,7 @@ static void decode_opc_special3_legacy(CPUMIPSState *env, DisasContext *ctx) > } > break; > case OPC_LX_DSP: > - if (!(ctx->insn_flags & INSN_OCTEON)) { > - check_dsp(ctx); > - } > + check_dsp(ctx); > op2 = MASK_LX(ctx->opcode); > switch (op2) { > #if defined(TARGET_MIPS64)
© 2016 - 2024 Red Hat, Inc.