[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v5 10/16] target/microblaze: Consider endianness while translatin
From: |
Philippe Mathieu-Daudé |
Subject: |
[PATCH v5 10/16] target/microblaze: Consider endianness while translating code |
Date: |
Thu, 6 Feb 2025 14:10:46 +0100 |
Consider the CPU ENDI bit, swap instructions when the CPU
endianness doesn't match the binary one.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
target/microblaze/cpu.h | 7 +++++++
target/microblaze/translate.c | 5 +++--
2 files changed, 10 insertions(+), 2 deletions(-)
diff --git a/target/microblaze/cpu.h b/target/microblaze/cpu.h
index f6879eee352..e44ddd53078 100644
--- a/target/microblaze/cpu.h
+++ b/target/microblaze/cpu.h
@@ -414,6 +414,13 @@ void mb_translate_code(CPUState *cs, TranslationBlock *tb,
/* Ensure there is no overlap between the two masks. */
QEMU_BUILD_BUG_ON(MSR_TB_MASK & IFLAGS_TB_MASK);
+static inline bool mb_cpu_is_big_endian(CPUState *cs)
+{
+ MicroBlazeCPU *cpu = MICROBLAZE_CPU(cs);
+
+ return !cpu->cfg.endi;
+}
+
static inline void cpu_get_tb_cpu_state(CPUMBState *env, vaddr *pc,
uint64_t *cs_base, uint32_t *flags)
{
diff --git a/target/microblaze/translate.c b/target/microblaze/translate.c
index b5389d65b2e..b54e5ac4b2f 100644
--- a/target/microblaze/translate.c
+++ b/target/microblaze/translate.c
@@ -710,7 +710,7 @@ static void record_unaligned_ess(DisasContext *dc, int rd,
static inline MemOp mo_endian(DisasContext *dc)
{
- return MO_TE;
+ return dc->cfg->endi ? MO_LE : MO_BE;
}
static bool do_load(DisasContext *dc, int rd, TCGv addr, MemOp mop,
@@ -1647,7 +1647,8 @@ static void mb_tr_translate_insn(DisasContextBase *dcb,
CPUState *cs)
dc->tb_flags_to_set = 0;
- ir = translator_ldl(cpu_env(cs), &dc->base, dc->base.pc_next);
+ ir = translator_ldl_swap(cpu_env(cs), &dc->base, dc->base.pc_next,
+ mb_cpu_is_big_endian(cs) != TARGET_BIG_ENDIAN);
if (!decode(dc, ir)) {
trap_illegal(dc, true);
}
--
2.47.1
- [PATCH v5 02/16] hw/net/xilinx_ethlite: Make device endianness configurable, (continued)
- [PATCH v5 02/16] hw/net/xilinx_ethlite: Make device endianness configurable, Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 03/16] hw/timer/xilinx_timer: Make device endianness configurable, Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 04/16] hw/char/xilinx_uartlite: Make device endianness configurable, Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 05/16] hw/ssi/xilinx_spi: Make device endianness configurable, Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 06/16] hw/arm/xlnx-zynqmp: Use &error_abort for programming errors, Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 07/16] target/microblaze: Explode MO_TExx -> MO_TE | MO_xx, Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 08/16] target/microblaze: Set MO_TE once in do_load() / do_store(), Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 09/16] target/microblaze: Introduce mo_endian() helper, Philippe Mathieu-Daudé, 2025/02/06
- [PATCH v5 10/16] target/microblaze: Consider endianness while translating code,
Philippe Mathieu-Daudé <=
- [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Philippe Mathieu-Daudé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Daniel P . Berrangé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Philippe Mathieu-Daudé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Daniel P . Berrangé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Philippe Mathieu-Daudé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Thomas Huth, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Daniel P . Berrangé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Philippe Mathieu-Daudé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Daniel P . Berrangé, 2025/02/06
- Re: [PATCH v5 11/16] hw/microblaze: Support various endianness for s3adsp1800 machines, Philippe Mathieu-Daudé, 2025/02/06