aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpbrook <pbrook@c046a42c-6fe2-441c-8c8c-71466251a162>2007-06-11 18:59:35 +0000
committerpbrook <pbrook@c046a42c-6fe2-441c-8c8c-71466251a162>2007-06-11 18:59:35 +0000
commit39524770b2a71f394b7e121def846608fc3e8f54 (patch)
tree2c4dc530b5fa23f5f324476c11f749f0b76ef093
parent2f2ecb83d7a52cc7239b33f3f9adc4a299dbeebe (diff)
Fix "blx lr" (Lauro Venancio).
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2979 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r--target-arm/translate.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/target-arm/translate.c b/target-arm/translate.c
index 246839d1f3..3ce93f89b1 100644
--- a/target-arm/translate.c
+++ b/target-arm/translate.c
@@ -2325,9 +2325,9 @@ static void disas_arm_insn(CPUState * env, DisasContext *s)
/* branch link/exchange thumb (blx) */
val = (uint32_t)s->pc;
- gen_op_movl_T0_im(val);
- gen_movl_reg_T0(s, 14);
+ gen_op_movl_T1_im(val);
gen_movl_T0_reg(s, rm);
+ gen_movl_reg_T1(s, 14);
gen_bx(s);
break;
case 0x5: /* saturating add/subtract */