diff --git a/target-arm/translate.c b/target-arm/translate.c index 15c2015d90c9b6f9c21a4c74b8b09e72eff4902b..f47e5ea48716b041e7bac450afa2d4ce6bb95fba 100644 --- a/target-arm/translate.c +++ b/target-arm/translate.c @@ -5514,6 +5514,10 @@ static int disas_neon_data_insn(CPUState * env, DisasContext *s, uint32_t insn) if (imm > 7 && !q) return 1; + if (q && ((rd | rn | rm) & 1)) { + return 1; + } + if (imm == 0) { neon_load_reg64(cpu_V0, rn); if (q) {