diff options
author | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-05-17 19:05:28 +0000 |
---|---|---|
committer | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-05-17 19:05:28 +0000 |
commit | bbf662ee31cbd2dcd4fa7f469ad7e16f78e1acfa (patch) | |
tree | fe9fcecb73e601d315258975feefd05a04bf7f22 /target-i386/translate.c | |
parent | 7d03f82f81e0e6c106ca0d2445a0fc49dc9ddc7b (diff) | |
download | qemu-bbf662ee31cbd2dcd4fa7f469ad7e16f78e1acfa.zip qemu-bbf662ee31cbd2dcd4fa7f469ad7e16f78e1acfa.tar.gz qemu-bbf662ee31cbd2dcd4fa7f469ad7e16f78e1acfa.tar.bz2 |
MONITOR insn address generation fix - converted XLAT to TCG
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4479 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'target-i386/translate.c')
-rw-r--r-- | target-i386/translate.c | 36 |
1 files changed, 20 insertions, 16 deletions
diff --git a/target-i386/translate.c b/target-i386/translate.c index 485ba71..4ce1038 100644 --- a/target-i386/translate.c +++ b/target-i386/translate.c @@ -2352,12 +2352,12 @@ static void gen_push_T0(DisasContext *s) gen_op_addl_A0_im(-4); if (s->ss32) { if (s->addseg) { - gen_op_movl_T1_A0(); + tcg_gen_mov_tl(cpu_T[1], cpu_A0); gen_op_addl_A0_seg(R_SS); } } else { gen_op_andl_A0_ffff(); - gen_op_movl_T1_A0(); + tcg_gen_mov_tl(cpu_T[1], cpu_A0); gen_op_addl_A0_seg(R_SS); } gen_op_st_T0_A0(s->dflag + 1 + s->mem_index); @@ -2447,7 +2447,7 @@ static void gen_stack_A0(DisasContext *s) gen_op_movl_A0_reg(R_ESP); if (!s->ss32) gen_op_andl_A0_ffff(); - gen_op_movl_T1_A0(); + tcg_gen_mov_tl(cpu_T[1], cpu_A0); if (s->addseg) gen_op_addl_A0_seg(R_SS); } @@ -2460,7 +2460,7 @@ static void gen_pusha(DisasContext *s) gen_op_addl_A0_im(-16 << s->dflag); if (!s->ss32) gen_op_andl_A0_ffff(); - gen_op_movl_T1_A0(); + tcg_gen_mov_tl(cpu_T[1], cpu_A0); if (s->addseg) gen_op_addl_A0_seg(R_SS); for(i = 0;i < 8; i++) { @@ -2478,8 +2478,8 @@ static void gen_popa(DisasContext *s) gen_op_movl_A0_reg(R_ESP); if (!s->ss32) gen_op_andl_A0_ffff(); - gen_op_movl_T1_A0(); - gen_op_addl_T1_im(16 << s->dflag); + tcg_gen_mov_tl(cpu_T[1], cpu_A0); + tcg_gen_addi_tl(cpu_T[1], cpu_T[1], 16 << s->dflag); if (s->addseg) gen_op_addl_A0_seg(R_SS); for(i = 0;i < 8; i++) { @@ -2505,7 +2505,7 @@ static void gen_enter(DisasContext *s, int esp_addend, int level) gen_op_movl_A0_reg(R_ESP); gen_op_addq_A0_im(-opsize); - gen_op_movl_T1_A0(); + tcg_gen_mov_tl(cpu_T[1], cpu_A0); /* push bp */ gen_op_mov_TN_reg(OT_LONG, 0, R_EBP); @@ -2518,7 +2518,7 @@ static void gen_enter(DisasContext *s, int esp_addend, int level) cpu_T[1]); } gen_op_mov_reg_T1(ot, R_EBP); - gen_op_addl_T1_im( -esp_addend + (-opsize * level) ); + tcg_gen_addi_tl(cpu_T[1], cpu_T[1], -esp_addend + (-opsize * level)); gen_op_mov_reg_T1(OT_QUAD, R_ESP); } else #endif @@ -2530,7 +2530,7 @@ static void gen_enter(DisasContext *s, int esp_addend, int level) gen_op_addl_A0_im(-opsize); if (!s->ss32) gen_op_andl_A0_ffff(); - gen_op_movl_T1_A0(); + tcg_gen_mov_tl(cpu_T[1], cpu_A0); if (s->addseg) gen_op_addl_A0_seg(R_SS); /* push bp */ @@ -2544,7 +2544,7 @@ static void gen_enter(DisasContext *s, int esp_addend, int level) cpu_T[1]); } gen_op_mov_reg_T1(ot, R_EBP); - gen_op_addl_T1_im( -esp_addend + (-opsize * level) ); + tcg_gen_addi_tl(cpu_T[1], cpu_T[1], -esp_addend + (-opsize * level)); gen_op_mov_reg_T1(OT_WORD + s->ss32, R_ESP); } } @@ -4561,14 +4561,20 @@ static target_ulong disas_insn(DisasContext *s, target_ulong pc_start) #ifdef TARGET_X86_64 if (s->aflag == 2) { gen_op_movq_A0_reg(R_EBX); - gen_op_addq_A0_AL(); + gen_op_mov_TN_reg(OT_QUAD, 0, R_EAX); + tcg_gen_andi_tl(cpu_T[0], cpu_T[0], 0xff); + tcg_gen_add_tl(cpu_A0, cpu_A0, cpu_T[0]); } else #endif { gen_op_movl_A0_reg(R_EBX); - gen_op_addl_A0_AL(); + gen_op_mov_TN_reg(OT_LONG, 0, R_EAX); + tcg_gen_andi_tl(cpu_T[0], cpu_T[0], 0xff); + tcg_gen_add_tl(cpu_A0, cpu_A0, cpu_T[0]); if (s->aflag == 0) gen_op_andl_A0_ffff(); + else + tcg_gen_andi_tl(cpu_A0, cpu_A0, 0xffffffff); } gen_add_A0_ds_seg(s); gen_op_ldu_T0_A0(OT_BYTE + s->mem_index); @@ -6285,13 +6291,11 @@ static target_ulong disas_insn(DisasContext *s, target_ulong pc_start) gen_jmp_im(pc_start - s->cs_base); #ifdef TARGET_X86_64 if (s->aflag == 2) { - gen_op_movq_A0_reg(R_EBX); - gen_op_addq_A0_AL(); + gen_op_movq_A0_reg(R_EAX); } else #endif { - gen_op_movl_A0_reg(R_EBX); - gen_op_addl_A0_AL(); + gen_op_movl_A0_reg(R_EAX); if (s->aflag == 0) gen_op_andl_A0_ffff(); } |