aboutsummaryrefslogtreecommitdiff
path: root/target/ppc
diff options
context:
space:
mode:
authorEmilio G. Cota <cota@braap.org>2018-11-27 20:14:34 -0500
committerAlex Bennée <alex.bennee@linaro.org>2019-10-28 15:12:38 +0000
commit23f42b6053442bf3596ed0f0b4105374d7b4628b (patch)
tree4aca0b43efae67e3c71425fa883fcded97026d04 /target/ppc
parentae82adc8e29bc73f799a0263b9729e5eb3f0cf79 (diff)
downloadqemu-23f42b6053442bf3596ed0f0b4105374d7b4628b.zip
qemu-23f42b6053442bf3596ed0f0b4105374d7b4628b.tar.gz
qemu-23f42b6053442bf3596ed0f0b4105374d7b4628b.tar.bz2
target/ppc: fetch code with translator_ld
Signed-off-by: Emilio G. Cota <cota@braap.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Acked-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Diffstat (limited to 'target/ppc')
-rw-r--r--target/ppc/translate.c8
1 files changed, 3 insertions, 5 deletions
diff --git a/target/ppc/translate.c b/target/ppc/translate.c
index adb8fd5..f5fe5d0 100644
--- a/target/ppc/translate.c
+++ b/target/ppc/translate.c
@@ -7853,11 +7853,9 @@ static void ppc_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)
LOG_DISAS("nip=" TARGET_FMT_lx " super=%d ir=%d\n",
ctx->base.pc_next, ctx->mem_idx, (int)msr_ir);
- if (unlikely(need_byteswap(ctx))) {
- ctx->opcode = bswap32(cpu_ldl_code(env, ctx->base.pc_next));
- } else {
- ctx->opcode = cpu_ldl_code(env, ctx->base.pc_next);
- }
+ ctx->opcode = translator_ldl_swap(env, ctx->base.pc_next,
+ need_byteswap(ctx));
+
LOG_DISAS("translate opcode %08x (%02x %02x %02x %02x) (%s)\n",
ctx->opcode, opc1(ctx->opcode), opc2(ctx->opcode),
opc3(ctx->opcode), opc4(ctx->opcode),