提交 6a57f3eb 编写于 作者: W Will Newton 提交者: Peter Maydell

target-arm: Move call to disas_vfp_insn out of disas_coproc_insn.

Floating point is an extension to the instruction set rather than
a coprocessor, so call it directly from the ARM and Thumb decode
functions.
Signed-off-by: NWill Newton <will.newton@linaro.org>
Reviewed-by: NPeter Maydell <peter.maydell@linaro.org>
Message-id: 1386158099-9239-2-git-send-email-will.newton@linaro.org
Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
上级 8202aa53
...@@ -2636,6 +2636,14 @@ static int disas_vfp_insn(CPUARMState * env, DisasContext *s, uint32_t insn) ...@@ -2636,6 +2636,14 @@ static int disas_vfp_insn(CPUARMState * env, DisasContext *s, uint32_t insn)
&& rn != ARM_VFP_MVFR1 && rn != ARM_VFP_MVFR0) && rn != ARM_VFP_MVFR1 && rn != ARM_VFP_MVFR0)
return 1; return 1;
} }
if (extract32(insn, 28, 4) == 0xf) {
/* Encodings with T=1 (Thumb) or unconditional (ARM):
* only used in v8 and above.
*/
return 1;
}
dp = ((insn & 0xf00) == 0xb00); dp = ((insn & 0xf00) == 0xb00);
switch ((insn >> 24) & 0xf) { switch ((insn >> 24) & 0xf) {
case 0xe: case 0xe:
...@@ -6296,9 +6304,6 @@ static int disas_coproc_insn(CPUARMState * env, DisasContext *s, uint32_t insn) ...@@ -6296,9 +6304,6 @@ static int disas_coproc_insn(CPUARMState * env, DisasContext *s, uint32_t insn)
return disas_dsp_insn(env, s, insn); return disas_dsp_insn(env, s, insn);
} }
return 1; return 1;
case 10:
case 11:
return disas_vfp_insn (env, s, insn);
default: default:
break; break;
} }
...@@ -6753,6 +6758,13 @@ static void disas_arm_insn(CPUARMState * env, DisasContext *s) ...@@ -6753,6 +6758,13 @@ static void disas_arm_insn(CPUARMState * env, DisasContext *s)
goto illegal_op; goto illegal_op;
return; return;
} }
if ((insn & 0x0f000e10) == 0x0e000a00) {
/* VFP. */
if (disas_vfp_insn(env, s, insn)) {
goto illegal_op;
}
return;
}
if (((insn & 0x0f30f000) == 0x0510f000) || if (((insn & 0x0f30f000) == 0x0510f000) ||
((insn & 0x0f30f010) == 0x0710f000)) { ((insn & 0x0f30f010) == 0x0710f000)) {
if ((insn & (1 << 22)) == 0) { if ((insn & (1 << 22)) == 0) {
...@@ -8033,9 +8045,15 @@ static void disas_arm_insn(CPUARMState * env, DisasContext *s) ...@@ -8033,9 +8045,15 @@ static void disas_arm_insn(CPUARMState * env, DisasContext *s)
case 0xc: case 0xc:
case 0xd: case 0xd:
case 0xe: case 0xe:
/* Coprocessor. */ if (((insn >> 8) & 0xe) == 10) {
if (disas_coproc_insn(env, s, insn)) /* VFP. */
if (disas_vfp_insn(env, s, insn)) {
goto illegal_op;
}
} else if (disas_coproc_insn(env, s, insn)) {
/* Coprocessor. */
goto illegal_op; goto illegal_op;
}
break; break;
case 0xf: case 0xf:
/* swi */ /* swi */
...@@ -8765,6 +8783,10 @@ static int disas_thumb2_insn(CPUARMState *env, DisasContext *s, uint16_t insn_hw ...@@ -8765,6 +8783,10 @@ static int disas_thumb2_insn(CPUARMState *env, DisasContext *s, uint16_t insn_hw
insn = (insn & 0xe2ffffff) | ((insn & (1 << 28)) >> 4) | (1 << 28); insn = (insn & 0xe2ffffff) | ((insn & (1 << 28)) >> 4) | (1 << 28);
if (disas_neon_data_insn(env, s, insn)) if (disas_neon_data_insn(env, s, insn))
goto illegal_op; goto illegal_op;
} else if (((insn >> 8) & 0xe) == 10) {
if (disas_vfp_insn(env, s, insn)) {
goto illegal_op;
}
} else { } else {
if (insn & (1 << 28)) if (insn & (1 << 28))
goto illegal_op; goto illegal_op;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册