diff options
author | Stefan Markovic <smarkovic@wavecomp.com> | 2019-01-22 16:06:21 +0100 |
---|---|---|
committer | Aleksandar Markovic <amarkovic@wavecomp.com> | 2019-01-24 17:48:33 +0100 |
commit | 697b7b6bc570c0fe4e32d079930fea6cd4cace6b (patch) | |
tree | bb295cb019d0b7d793132fe8c64cdaa81a6bb9fa /target/mips | |
parent | fc95c2412ecfb0decb30d70eabd9d73c2e6dd946 (diff) | |
download | qemu-697b7b6bc570c0fe4e32d079930fea6cd4cace6b.zip qemu-697b7b6bc570c0fe4e32d079930fea6cd4cace6b.tar.gz qemu-697b7b6bc570c0fe4e32d079930fea6cd4cace6b.tar.bz2 |
target/mips: nanoMIPS: Fix branch handling
Fix nanoMIPS branch handling.
Reviewed-by: Aleksandar Rikalo <arikalo@wavecomp.com>
Signed-off-by: Stefan Markovic <smarkovic@wavecomp.com>
Signed-off-by: Aleksandar Markovic <amarkovic@wavecomp.com>
Diffstat (limited to 'target/mips')
-rw-r--r-- | target/mips/translate.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/target/mips/translate.c b/target/mips/translate.c index aaf7dff..e9b5d1d 100644 --- a/target/mips/translate.c +++ b/target/mips/translate.c @@ -19758,6 +19758,10 @@ static void gen_compute_imm_branch(DisasContext *ctx, uint32_t opc, goto out; } + /* branch completion */ + clear_branch_hflags(ctx); + ctx->base.is_jmp = DISAS_NORETURN; + if (bcond_compute == 0) { /* Uncoditional compact branch */ gen_goto_tb(ctx, 0, ctx->btarget); @@ -19798,6 +19802,10 @@ static void gen_compute_nanomips_pbalrsc_branch(DisasContext *ctx, int rs, tcg_gen_movi_tl(t1, ctx->base.pc_next + 4); gen_op_addr_add(ctx, btarget, t1, t0); + /* branch completion */ + clear_branch_hflags(ctx); + ctx->base.is_jmp = DISAS_NORETURN; + /* unconditional branch to register */ tcg_gen_mov_tl(cpu_PC, btarget); tcg_gen_lookup_and_goto_ptr(); @@ -19936,6 +19944,10 @@ static void gen_compute_compact_branch_nm(DisasContext *ctx, uint32_t opc, goto out; } + /* branch completion */ + clear_branch_hflags(ctx); + ctx->base.is_jmp = DISAS_NORETURN; + /* Generating branch here as compact branches don't have delay slot */ gen_goto_tb(ctx, 1, ctx->btarget); gen_set_label(fs); |