diff mbox series

[01/19] target/hppa: Use DisasContextBase.is_jmp

Message ID 20180217203132.31780-2-richard.henderson@linaro.org
State Superseded
Headers show
Series target/hppa: Convert to decodetree.py | expand

Commit Message

Richard Henderson Feb. 17, 2018, 8:31 p.m. UTC
Instead of returning DisasJumpType, immediately store it.

Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

---
 target/hppa/translate.c | 971 ++++++++++++++++++++++++------------------------
 1 file changed, 487 insertions(+), 484 deletions(-)

-- 
2.14.3

Comments

Philippe Mathieu-Daudé Feb. 26, 2018, 9:30 a.m. UTC | #1
On 02/17/2018 05:31 PM, Richard Henderson wrote:
> Instead of returning DisasJumpType, immediately store it.


neat!

> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>


Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>


> ---

>  target/hppa/translate.c | 971 ++++++++++++++++++++++++------------------------

>  1 file changed, 487 insertions(+), 484 deletions(-)

> 

> diff --git a/target/hppa/translate.c b/target/hppa/translate.c

> index 6499b392f9..f72bc84873 100644

> --- a/target/hppa/translate.c

> +++ b/target/hppa/translate.c

> @@ -290,10 +290,6 @@ typedef struct DisasContext {

>      bool psw_n_nonzero;

>  } DisasContext;

>  

> -/* Target-specific return values from translate_one, indicating the

> -   state of the TB.  Note that DISAS_NEXT indicates that we are not

> -   exiting the TB.  */

> -

>  /* We are not using a goto_tb (for whatever reason), but have updated

>     the iaq (for whatever reason), so don't do it again on exit.  */

>  #define DISAS_IAQ_N_UPDATED  DISAS_TARGET_0

> @@ -308,8 +304,8 @@ typedef struct DisasContext {

>  

>  typedef struct DisasInsn {

>      uint32_t insn, mask;

> -    DisasJumpType (*trans)(DisasContext *ctx, uint32_t insn,

> -                           const struct DisasInsn *f);

> +    void (*trans)(DisasContext *ctx, uint32_t insn,

> +                  const struct DisasInsn *f);

>      union {

>          void (*ttt)(TCGv_reg, TCGv_reg, TCGv_reg);

>          void (*weww)(TCGv_i32, TCGv_env, TCGv_i32, TCGv_i32);

> @@ -678,9 +674,10 @@ static void nullify_set(DisasContext *ctx, bool x)

>  

>  /* Mark the end of an instruction that may have been nullified.

>     This is the pair to nullify_over.  */

> -static DisasJumpType nullify_end(DisasContext *ctx, DisasJumpType status)

> +static void nullify_end(DisasContext *ctx)

>  {

>      TCGLabel *null_lab = ctx->null_lab;

> +    DisasJumpType status = ctx->base.is_jmp;

>  

>      /* For NEXT, NORETURN, STALE, we can easily continue (or exit).

>         For UPDATED, we cannot update on the nullified path.  */

> @@ -690,7 +687,7 @@ static DisasJumpType nullify_end(DisasContext *ctx, DisasJumpType status)

>          /* The current insn wasn't conditional or handled the condition

>             applied to it without a branch, so the (new) setting of

>             NULL_COND can be applied directly to the next insn.  */

> -        return status;

> +        return;

>      }

>      ctx->null_lab = NULL;

>  

> @@ -708,9 +705,8 @@ static DisasJumpType nullify_end(DisasContext *ctx, DisasJumpType status)

>          ctx->null_cond = cond_make_n();

>      }

>      if (status == DISAS_NORETURN) {

> -        status = DISAS_NEXT;

> +        ctx->base.is_jmp = DISAS_NEXT;

>      }

> -    return status;

>  }

>  

>  static void copy_iaoq_entry(TCGv_reg dest, target_ureg ival, TCGv_reg vval)

> @@ -734,41 +730,45 @@ static void gen_excp_1(int exception)

>      tcg_temp_free_i32(t);

>  }

>  

> -static DisasJumpType gen_excp(DisasContext *ctx, int exception)

> +static void gen_excp(DisasContext *ctx, int exception)

>  {

>      copy_iaoq_entry(cpu_iaoq_f, ctx->iaoq_f, cpu_iaoq_f);

>      copy_iaoq_entry(cpu_iaoq_b, ctx->iaoq_b, cpu_iaoq_b);

>      nullify_save(ctx);

>      gen_excp_1(exception);

> -    return DISAS_NORETURN;

> +    ctx->base.is_jmp = DISAS_NORETURN;

>  }

>  

> -static DisasJumpType gen_excp_iir(DisasContext *ctx, int exc)

> +static void gen_excp_iir(DisasContext *ctx, int exc)

>  {

>      TCGv_reg tmp = tcg_const_reg(ctx->insn);

>      tcg_gen_st_reg(tmp, cpu_env, offsetof(CPUHPPAState, cr[CR_IIR]));

>      tcg_temp_free(tmp);

> -    return gen_excp(ctx, exc);

> +    gen_excp(ctx, exc);

>  }

>  

> -static DisasJumpType gen_illegal(DisasContext *ctx)

> +static void gen_illegal(DisasContext *ctx)

>  {

>      nullify_over(ctx);

> -    return nullify_end(ctx, gen_excp_iir(ctx, EXCP_ILL));

> +    gen_excp_iir(ctx, EXCP_ILL);

> +    nullify_end(ctx);

>  }

>  

> -#define CHECK_MOST_PRIVILEGED(EXCP)                               \

> -    do {                                                          \

> -        if (ctx->privilege != 0) {                                \

> -            nullify_over(ctx);                                    \

> -            return nullify_end(ctx, gen_excp_iir(ctx, EXCP));     \

> -        }                                                         \

> +#define CHECK_MOST_PRIVILEGED(EXCP)      \

> +    do {                                 \

> +        if (ctx->privilege != 0) {       \

> +            nullify_over(ctx);           \

> +            gen_excp_iir(ctx, EXCP);     \

> +            nullify_end(ctx);            \

> +            return;                      \

> +        }                                \

>      } while (0)

>  

>  static bool use_goto_tb(DisasContext *ctx, target_ureg dest)

>  {

>      /* Suppress goto_tb in the case of single-steping and IO.  */

> -    if ((tb_cflags(ctx->base.tb) & CF_LAST_IO) || ctx->base.singlestep_enabled) {

> +    if ((tb_cflags(ctx->base.tb) & CF_LAST_IO)

> +        || ctx->base.singlestep_enabled) {

>          return false;

>      }

>      return true;

> @@ -1131,9 +1131,9 @@ static TCGv_reg do_sub_sv(DisasContext *ctx, TCGv_reg res,

>      return sv;

>  }

>  

> -static DisasJumpType do_add(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> -                            TCGv_reg in2, unsigned shift, bool is_l,

> -                            bool is_tsv, bool is_tc, bool is_c, unsigned cf)

> +static void do_add(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> +                   TCGv_reg in2, unsigned shift, bool is_l,

> +                   bool is_tsv, bool is_tc, bool is_c, unsigned cf)

>  {

>      TCGv_reg dest, cb, cb_msb, sv, tmp;

>      unsigned c = cf >> 1;

> @@ -1200,12 +1200,11 @@ static DisasJumpType do_add(DisasContext *ctx, unsigned rt, TCGv_reg in1,

>      /* Install the new nullification.  */

>      cond_free(&ctx->null_cond);

>      ctx->null_cond = cond;

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType do_sub(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> -                            TCGv_reg in2, bool is_tsv, bool is_b,

> -                            bool is_tc, unsigned cf)

> +static void do_sub(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> +                   TCGv_reg in2, bool is_tsv, bool is_b,

> +                   bool is_tc, unsigned cf)

>  {

>      TCGv_reg dest, sv, cb, cb_msb, zero, tmp;

>      unsigned c = cf >> 1;

> @@ -1267,11 +1266,10 @@ static DisasJumpType do_sub(DisasContext *ctx, unsigned rt, TCGv_reg in1,

>      /* Install the new nullification.  */

>      cond_free(&ctx->null_cond);

>      ctx->null_cond = cond;

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType do_cmpclr(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> -                               TCGv_reg in2, unsigned cf)

> +static void do_cmpclr(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> +                      TCGv_reg in2, unsigned cf)

>  {

>      TCGv_reg dest, sv;

>      DisasCond cond;

> @@ -1296,12 +1294,11 @@ static DisasJumpType do_cmpclr(DisasContext *ctx, unsigned rt, TCGv_reg in1,

>      /* Install the new nullification.  */

>      cond_free(&ctx->null_cond);

>      ctx->null_cond = cond;

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType do_log(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> -                            TCGv_reg in2, unsigned cf,

> -                            void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))

> +static void do_log(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> +                   TCGv_reg in2, unsigned cf,

> +                   void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))

>  {

>      TCGv_reg dest = dest_gpr(ctx, rt);

>  

> @@ -1314,12 +1311,11 @@ static DisasJumpType do_log(DisasContext *ctx, unsigned rt, TCGv_reg in1,

>      if (cf) {

>          ctx->null_cond = do_log_cond(cf, dest);

>      }

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType do_unit(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> -                             TCGv_reg in2, unsigned cf, bool is_tc,

> -                             void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))

> +static void do_unit(DisasContext *ctx, unsigned rt, TCGv_reg in1,

> +                    TCGv_reg in2, unsigned cf, bool is_tc,

> +                    void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))

>  {

>      TCGv_reg dest;

>      DisasCond cond;

> @@ -1347,7 +1343,6 @@ static DisasJumpType do_unit(DisasContext *ctx, unsigned rt, TCGv_reg in1,

>          cond_free(&ctx->null_cond);

>          ctx->null_cond = cond;

>      }

> -    return DISAS_NEXT;

>  }

>  

>  #ifndef CONFIG_USER_ONLY

> @@ -1510,9 +1505,9 @@ static void do_store_64(DisasContext *ctx, TCGv_i64 src, unsigned rb,

>  #define do_store_reg  do_store_32

>  #endif

>  

> -static DisasJumpType do_load(DisasContext *ctx, unsigned rt, unsigned rb,

> -                             unsigned rx, int scale, target_sreg disp,

> -                             unsigned sp, int modify, TCGMemOp mop)

> +static void do_load(DisasContext *ctx, unsigned rt, unsigned rb,

> +                    unsigned rx, int scale, target_sreg disp,

> +                    unsigned sp, int modify, TCGMemOp mop)

>  {

>      TCGv_reg dest;

>  

> @@ -1528,12 +1523,12 @@ static DisasJumpType do_load(DisasContext *ctx, unsigned rt, unsigned rb,

>      do_load_reg(ctx, dest, rb, rx, scale, disp, sp, modify, mop);

>      save_gpr(ctx, rt, dest);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_floadw(DisasContext *ctx, unsigned rt, unsigned rb,

> -                               unsigned rx, int scale, target_sreg disp,

> -                               unsigned sp, int modify)

> +static void do_floadw(DisasContext *ctx, unsigned rt, unsigned rb,

> +                      unsigned rx, int scale, target_sreg disp,

> +                      unsigned sp, int modify)

>  {

>      TCGv_i32 tmp;

>  

> @@ -1548,12 +1543,12 @@ static DisasJumpType do_floadw(DisasContext *ctx, unsigned rt, unsigned rb,

>          gen_helper_loaded_fr0(cpu_env);

>      }

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_floadd(DisasContext *ctx, unsigned rt, unsigned rb,

> -                               unsigned rx, int scale, target_sreg disp,

> -                               unsigned sp, int modify)

> +static void do_floadd(DisasContext *ctx, unsigned rt, unsigned rb,

> +                      unsigned rx, int scale, target_sreg disp,

> +                      unsigned sp, int modify)

>  {

>      TCGv_i64 tmp;

>  

> @@ -1568,21 +1563,21 @@ static DisasJumpType do_floadd(DisasContext *ctx, unsigned rt, unsigned rb,

>          gen_helper_loaded_fr0(cpu_env);

>      }

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_store(DisasContext *ctx, unsigned rt, unsigned rb,

> -                              target_sreg disp, unsigned sp,

> -                              int modify, TCGMemOp mop)

> +static void do_store(DisasContext *ctx, unsigned rt, unsigned rb,

> +                     target_sreg disp, unsigned sp,

> +                     int modify, TCGMemOp mop)

>  {

>      nullify_over(ctx);

>      do_store_reg(ctx, load_gpr(ctx, rt), rb, 0, 0, disp, sp, modify, mop);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fstorew(DisasContext *ctx, unsigned rt, unsigned rb,

> -                                unsigned rx, int scale, target_sreg disp,

> -                                unsigned sp, int modify)

> +static void do_fstorew(DisasContext *ctx, unsigned rt, unsigned rb,

> +                       unsigned rx, int scale, target_sreg disp,

> +                       unsigned sp, int modify)

>  {

>      TCGv_i32 tmp;

>  

> @@ -1592,12 +1587,12 @@ static DisasJumpType do_fstorew(DisasContext *ctx, unsigned rt, unsigned rb,

>      do_store_32(ctx, tmp, rb, rx, scale, disp, sp, modify, MO_TEUL);

>      tcg_temp_free_i32(tmp);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fstored(DisasContext *ctx, unsigned rt, unsigned rb,

> -                                unsigned rx, int scale, target_sreg disp,

> -                                unsigned sp, int modify)

> +static void do_fstored(DisasContext *ctx, unsigned rt, unsigned rb,

> +                       unsigned rx, int scale, target_sreg disp,

> +                       unsigned sp, int modify)

>  {

>      TCGv_i64 tmp;

>  

> @@ -1607,11 +1602,11 @@ static DisasJumpType do_fstored(DisasContext *ctx, unsigned rt, unsigned rb,

>      do_store_64(ctx, tmp, rb, rx, scale, disp, sp, modify, MO_TEQ);

>      tcg_temp_free_i64(tmp);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fop_wew(DisasContext *ctx, unsigned rt, unsigned ra,

> -                                void (*func)(TCGv_i32, TCGv_env, TCGv_i32))

> +static void do_fop_wew(DisasContext *ctx, unsigned rt, unsigned ra,

> +                       void (*func)(TCGv_i32, TCGv_env, TCGv_i32))

>  {

>      TCGv_i32 tmp;

>  

> @@ -1622,11 +1617,11 @@ static DisasJumpType do_fop_wew(DisasContext *ctx, unsigned rt, unsigned ra,

>  

>      save_frw_i32(rt, tmp);

>      tcg_temp_free_i32(tmp);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fop_wed(DisasContext *ctx, unsigned rt, unsigned ra,

> -                                void (*func)(TCGv_i32, TCGv_env, TCGv_i64))

> +static void do_fop_wed(DisasContext *ctx, unsigned rt, unsigned ra,

> +                       void (*func)(TCGv_i32, TCGv_env, TCGv_i64))

>  {

>      TCGv_i32 dst;

>      TCGv_i64 src;

> @@ -1640,11 +1635,11 @@ static DisasJumpType do_fop_wed(DisasContext *ctx, unsigned rt, unsigned ra,

>      tcg_temp_free_i64(src);

>      save_frw_i32(rt, dst);

>      tcg_temp_free_i32(dst);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fop_ded(DisasContext *ctx, unsigned rt, unsigned ra,

> -                                void (*func)(TCGv_i64, TCGv_env, TCGv_i64))

> +static void do_fop_ded(DisasContext *ctx, unsigned rt, unsigned ra,

> +                       void (*func)(TCGv_i64, TCGv_env, TCGv_i64))

>  {

>      TCGv_i64 tmp;

>  

> @@ -1655,11 +1650,11 @@ static DisasJumpType do_fop_ded(DisasContext *ctx, unsigned rt, unsigned ra,

>  

>      save_frd(rt, tmp);

>      tcg_temp_free_i64(tmp);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fop_dew(DisasContext *ctx, unsigned rt, unsigned ra,

> -                                void (*func)(TCGv_i64, TCGv_env, TCGv_i32))

> +static void do_fop_dew(DisasContext *ctx, unsigned rt, unsigned ra,

> +                       void (*func)(TCGv_i64, TCGv_env, TCGv_i32))

>  {

>      TCGv_i32 src;

>      TCGv_i64 dst;

> @@ -1673,13 +1668,12 @@ static DisasJumpType do_fop_dew(DisasContext *ctx, unsigned rt, unsigned ra,

>      tcg_temp_free_i32(src);

>      save_frd(rt, dst);

>      tcg_temp_free_i64(dst);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fop_weww(DisasContext *ctx, unsigned rt,

> -                                 unsigned ra, unsigned rb,

> -                                 void (*func)(TCGv_i32, TCGv_env,

> -                                              TCGv_i32, TCGv_i32))

> +static void do_fop_weww(DisasContext *ctx, unsigned rt,

> +                        unsigned ra, unsigned rb,

> +                        void (*func)(TCGv_i32, TCGv_env, TCGv_i32, TCGv_i32))

>  {

>      TCGv_i32 a, b;

>  

> @@ -1692,13 +1686,12 @@ static DisasJumpType do_fop_weww(DisasContext *ctx, unsigned rt,

>      tcg_temp_free_i32(b);

>      save_frw_i32(rt, a);

>      tcg_temp_free_i32(a);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType do_fop_dedd(DisasContext *ctx, unsigned rt,

> -                                 unsigned ra, unsigned rb,

> -                                 void (*func)(TCGv_i64, TCGv_env,

> -                                              TCGv_i64, TCGv_i64))

> +static void do_fop_dedd(DisasContext *ctx, unsigned rt,

> +                        unsigned ra, unsigned rb,

> +                        void (*func)(TCGv_i64, TCGv_env, TCGv_i64, TCGv_i64))

>  {

>      TCGv_i64 a, b;

>  

> @@ -1711,13 +1704,13 @@ static DisasJumpType do_fop_dedd(DisasContext *ctx, unsigned rt,

>      tcg_temp_free_i64(b);

>      save_frd(rt, a);

>      tcg_temp_free_i64(a);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  /* Emit an unconditional branch to a direct target, which may or may not

>     have already had nullification handled.  */

> -static DisasJumpType do_dbranch(DisasContext *ctx, target_ureg dest,

> -                                unsigned link, bool is_n)

> +static void do_dbranch(DisasContext *ctx, target_ureg dest,

> +                       unsigned link, bool is_n)

>  {

>      if (ctx->null_cond.c == TCG_COND_NEVER && ctx->null_lab == NULL) {

>          if (link != 0) {

> @@ -1727,7 +1720,6 @@ static DisasJumpType do_dbranch(DisasContext *ctx, target_ureg dest,

>          if (is_n) {

>              ctx->null_cond.c = TCG_COND_ALWAYS;

>          }

> -        return DISAS_NEXT;

>      } else {

>          nullify_over(ctx);

>  

> @@ -1743,18 +1735,18 @@ static DisasJumpType do_dbranch(DisasContext *ctx, target_ureg dest,

>              gen_goto_tb(ctx, 0, ctx->iaoq_b, dest);

>          }

>  

> -        nullify_end(ctx, DISAS_NEXT);

> +        nullify_end(ctx);

>  

>          nullify_set(ctx, 0);

>          gen_goto_tb(ctx, 1, ctx->iaoq_b, ctx->iaoq_n);

> -        return DISAS_NORETURN;

> +        ctx->base.is_jmp = DISAS_NORETURN;

>      }

>  }

>  

>  /* Emit a conditional branch to a direct target.  If the branch itself

>     is nullified, we should have already used nullify_over.  */

> -static DisasJumpType do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,

> -                                DisasCond *cond)

> +static void do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,

> +                       DisasCond *cond)

>  {

>      target_ureg dest = iaoq_dest(ctx, disp);

>      TCGLabel *taken = NULL;

> @@ -1765,10 +1757,12 @@ static DisasJumpType do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,

>  

>      /* Handle TRUE and NEVER as direct branches.  */

>      if (c == TCG_COND_ALWAYS) {

> -        return do_dbranch(ctx, dest, 0, is_n && disp >= 0);

> +        do_dbranch(ctx, dest, 0, is_n && disp >= 0);

> +        return;

>      }

>      if (c == TCG_COND_NEVER) {

> -        return do_dbranch(ctx, ctx->iaoq_n, 0, is_n && disp < 0);

> +        do_dbranch(ctx, ctx->iaoq_n, 0, is_n && disp < 0);

> +        return;

>      }

>  

>      taken = gen_new_label();

> @@ -1811,16 +1805,16 @@ static DisasJumpType do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,

>      if (ctx->null_lab) {

>          gen_set_label(ctx->null_lab);

>          ctx->null_lab = NULL;

> -        return DISAS_IAQ_N_STALE;

> +        ctx->base.is_jmp = DISAS_IAQ_N_STALE;

>      } else {

> -        return DISAS_NORETURN;

> +        ctx->base.is_jmp = DISAS_NORETURN;

>      }

>  }

>  

>  /* Emit an unconditional branch to an indirect target.  This handles

>     nullification of the branch itself.  */

> -static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,

> -                                unsigned link, bool is_n)

> +static void do_ibranch(DisasContext *ctx, TCGv_reg dest,

> +                       unsigned link, bool is_n)

>  {

>      TCGv_reg a0, a1, next, tmp;

>      TCGCond c;

> @@ -1838,7 +1832,8 @@ static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,

>                  tcg_gen_mov_reg(cpu_iaoq_f, next);

>                  tcg_gen_addi_reg(cpu_iaoq_b, next, 4);

>                  nullify_set(ctx, 0);

> -                return DISAS_IAQ_N_UPDATED;

> +                ctx->base.is_jmp = DISAS_IAQ_N_UPDATED;

> +                return;

>              }

>              ctx->null_cond.c = TCG_COND_ALWAYS;

>          }

> @@ -1865,7 +1860,7 @@ static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,

>              tcg_gen_movi_reg(cpu_gr[link], ctx->iaoq_n);

>          }

>          tcg_gen_lookup_and_goto_ptr();

> -        return nullify_end(ctx, DISAS_NEXT);

> +        nullify_end(ctx);

>      } else {

>          cond_prep(&ctx->null_cond);

>          c = ctx->null_cond.c;

> @@ -1896,8 +1891,6 @@ static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,

>              cond_free(&ctx->null_cond);

>          }

>      }

> -

> -    return DISAS_NEXT;

>  }

>  

>  /* Implement

> @@ -1942,7 +1935,7 @@ static TCGv_reg do_ibranch_priv(DisasContext *ctx, TCGv_reg offset)

>     in than the "be disp(sr2,r0)" instruction that probably sent us

>     here, is the easiest way to handle the branch delay slot on the

>     aforementioned BE.  */

> -static DisasJumpType do_page_zero(DisasContext *ctx)

> +static void do_page_zero(DisasContext *ctx)

>  {

>      /* If by some means we get here with PSW[N]=1, that implies that

>         the B,GATE instruction would be skipped, and we'd fault on the

> @@ -1970,56 +1963,56 @@ static DisasJumpType do_page_zero(DisasContext *ctx)

>      switch (ctx->iaoq_f) {

>      case 0x00: /* Null pointer call */

>          gen_excp_1(EXCP_IMP);

> -        return DISAS_NORETURN;

> +        ctx->base.is_jmp = DISAS_NORETURN;

> +        break;

>  

>      case 0xb0: /* LWS */

>          gen_excp_1(EXCP_SYSCALL_LWS);

> -        return DISAS_NORETURN;

> +        ctx->base.is_jmp = DISAS_NORETURN;

> +        break;

>  

>      case 0xe0: /* SET_THREAD_POINTER */

>          tcg_gen_st_reg(cpu_gr[26], cpu_env, offsetof(CPUHPPAState, cr[27]));

>          tcg_gen_mov_reg(cpu_iaoq_f, cpu_gr[31]);

>          tcg_gen_addi_reg(cpu_iaoq_b, cpu_iaoq_f, 4);

> -        return DISAS_IAQ_N_UPDATED;

> +        ctx->base.is_jmp = DISAS_IAQ_N_UPDATED;

> +        break;

>  

>      case 0x100: /* SYSCALL */

>          gen_excp_1(EXCP_SYSCALL);

> -        return DISAS_NORETURN;

> +        ctx->base.is_jmp = DISAS_NORETURN;

> +        break;

>  

>      default:

>      do_sigill:

>          gen_excp_1(EXCP_ILL);

> -        return DISAS_NORETURN;

> +        ctx->base.is_jmp = DISAS_NORETURN;

> +        break;

>      }

>  }

>  #endif

>  

> -static DisasJumpType trans_nop(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_nop(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_break(DisasContext *ctx, uint32_t insn,

> -                                 const DisasInsn *di)

> +static void trans_break(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      nullify_over(ctx);

> -    return nullify_end(ctx, gen_excp_iir(ctx, EXCP_BREAK));

> +    gen_excp_iir(ctx, EXCP_BREAK);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_sync(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_sync(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      /* No point in nullifying the memory barrier.  */

>      tcg_gen_mb(TCG_BAR_SC | TCG_MO_ALL);

>  

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_mfia(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_mfia(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      TCGv_reg tmp = dest_gpr(ctx, rt);

> @@ -2027,11 +2020,9 @@ static DisasJumpType trans_mfia(DisasContext *ctx, uint32_t insn,

>      save_gpr(ctx, rt, tmp);

>  

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_mfsp(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_mfsp(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned rs = assemble_sr3(insn);

> @@ -2047,16 +2038,13 @@ static DisasJumpType trans_mfsp(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free_i64(t0);

>  

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,

> -                                 const DisasInsn *di)

> +static void trans_mfctl(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned ctl = extract32(insn, 21, 5);

>      TCGv_reg tmp;

> -    DisasJumpType ret;

>  

>      switch (ctl) {

>      case CR_SAR:

> @@ -2079,13 +2067,13 @@ static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,

>              gen_io_start();

>              gen_helper_read_interval_timer(tmp);

>              gen_io_end();

> -            ret = DISAS_IAQ_N_STALE;

> +            ctx->base.is_jmp = DISAS_IAQ_N_STALE;

>          } else {

>              gen_helper_read_interval_timer(tmp);

> -            ret = DISAS_NEXT;

>          }

>          save_gpr(ctx, rt, tmp);

> -        return nullify_end(ctx, ret);

> +        nullify_end(ctx);

> +        return;

>      case 26:

>      case 27:

>          break;

> @@ -2101,11 +2089,9 @@ static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,

>  

>   done:

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_mtsp(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_mtsp(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rr = extract32(insn, 16, 5);

>      unsigned rs = assemble_sr3(insn);

> @@ -2128,11 +2114,10 @@ static DisasJumpType trans_mtsp(DisasContext *ctx, uint32_t insn,

>      }

>      tcg_temp_free_i64(t64);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,

> -                                 const DisasInsn *di)

> +static void trans_mtctl(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rin = extract32(insn, 16, 5);

>      unsigned ctl = extract32(insn, 21, 5);

> @@ -2146,7 +2131,7 @@ static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,

>          tcg_temp_free(tmp);

>  

>          cond_free(&ctx->null_cond);

> -        return DISAS_NEXT;

> +        return;

>      }

>  

>      /* All other control registers are privileged or read-only.  */

> @@ -2155,8 +2140,6 @@ static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,

>  #ifdef CONFIG_USER_ONLY

>      g_assert_not_reached();

>  #else

> -    DisasJumpType ret = DISAS_NEXT;

> -

>      nullify_over(ctx);

>      switch (ctl) {

>      case CR_IT:

> @@ -2167,7 +2150,7 @@ static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,

>          break;

>      case CR_EIEM:

>          gen_helper_write_eiem(cpu_env, reg);

> -        ret = DISAS_IAQ_N_STALE_EXIT;

> +        ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;

>          break;

>  

>      case CR_IIASQ:

> @@ -2186,12 +2169,11 @@ static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,

>          tcg_gen_st_reg(reg, cpu_env, offsetof(CPUHPPAState, cr[ctl]));

>          break;

>      }

> -    return nullify_end(ctx, ret);

> +    nullify_end(ctx);

>  #endif

>  }

>  

> -static DisasJumpType trans_mtsarcm(DisasContext *ctx, uint32_t insn,

> -                                   const DisasInsn *di)

> +static void trans_mtsarcm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rin = extract32(insn, 16, 5);

>      TCGv_reg tmp = tcg_temp_new();

> @@ -2202,11 +2184,9 @@ static DisasJumpType trans_mtsarcm(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free(tmp);

>  

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_ldsid(DisasContext *ctx, uint32_t insn,

> -                                 const DisasInsn *di)

> +static void trans_ldsid(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      TCGv_reg dest = dest_gpr(ctx, rt);

> @@ -2228,7 +2208,6 @@ static DisasJumpType trans_ldsid(DisasContext *ctx, uint32_t insn,

>      save_gpr(ctx, rt, dest);

>  

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

>  #ifndef CONFIG_USER_ONLY

> @@ -2246,8 +2225,7 @@ static target_ureg extract_sm_imm(uint32_t insn)

>      return val;

>  }

>  

> -static DisasJumpType trans_rsm(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_rsm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      target_ureg sm = extract_sm_imm(insn);

> @@ -2263,11 +2241,11 @@ static DisasJumpType trans_rsm(DisasContext *ctx, uint32_t insn,

>      save_gpr(ctx, rt, tmp);

>  

>      /* Exit the TB to recognize new interrupts, e.g. PSW_M.  */

> -    return nullify_end(ctx, DISAS_IAQ_N_STALE_EXIT);

> +    ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_ssm(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_ssm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      target_ureg sm = extract_sm_imm(insn);

> @@ -2283,11 +2261,11 @@ static DisasJumpType trans_ssm(DisasContext *ctx, uint32_t insn,

>      save_gpr(ctx, rt, tmp);

>  

>      /* Exit the TB to recognize new interrupts, e.g. PSW_I.  */

> -    return nullify_end(ctx, DISAS_IAQ_N_STALE_EXIT);

> +    ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_mtsm(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_mtsm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rr = extract32(insn, 16, 5);

>      TCGv_reg tmp, reg;

> @@ -2300,11 +2278,11 @@ static DisasJumpType trans_mtsm(DisasContext *ctx, uint32_t insn,

>      gen_helper_swap_system_mask(tmp, cpu_env, reg);

>  

>      /* Exit the TB to recognize new interrupts.  */

> -    return nullify_end(ctx, DISAS_IAQ_N_STALE_EXIT);

> +    ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_rfi(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_rfi(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned comp = extract32(insn, 5, 4);

>  

> @@ -2316,17 +2294,18 @@ static DisasJumpType trans_rfi(DisasContext *ctx, uint32_t insn,

>      } else {

>          gen_helper_rfi(cpu_env);

>      }

> +    /* Exit the TB to recognize new interrupts.  */

>      if (ctx->base.singlestep_enabled) {

>          gen_excp_1(EXCP_DEBUG);

>      } else {

>          tcg_gen_exit_tb(0);

>      }

> +    ctx->base.is_jmp = DISAS_NORETURN;

>  

> -    /* Exit the TB to recognize new interrupts.  */

> -    return nullify_end(ctx, DISAS_NORETURN);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType gen_hlt(DisasContext *ctx, int reset)

> +static void gen_hlt(DisasContext *ctx, int reset)

>  {

>      CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);

>      nullify_over(ctx);

> @@ -2335,7 +2314,8 @@ static DisasJumpType gen_hlt(DisasContext *ctx, int reset)

>      } else {

>          gen_helper_halt(cpu_env);

>      }

> -    return nullify_end(ctx, DISAS_NORETURN);

> +    ctx->base.is_jmp = DISAS_NORETURN;

> +    nullify_end(ctx);

>  }

>  #endif /* !CONFIG_USER_ONLY */

>  

> @@ -2358,8 +2338,8 @@ static const DisasInsn table_system[] = {

>  #endif

>  };

>  

> -static DisasJumpType trans_base_idx_mod(DisasContext *ctx, uint32_t insn,

> -                                        const DisasInsn *di)

> +static void trans_base_idx_mod(DisasContext *ctx, uint32_t insn,

> +                               const DisasInsn *di)

>  {

>      unsigned rb = extract32(insn, 21, 5);

>      unsigned rx = extract32(insn, 16, 5);

> @@ -2372,11 +2352,9 @@ static DisasJumpType trans_base_idx_mod(DisasContext *ctx, uint32_t insn,

>      save_gpr(ctx, rb, dest);

>  

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_probe(DisasContext *ctx, uint32_t insn,

> -                                 const DisasInsn *di)

> +static void trans_probe(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned sp = extract32(insn, 14, 2);

> @@ -2408,12 +2386,11 @@ static DisasJumpType trans_probe(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free_i32(level);

>  

>      save_gpr(ctx, rt, dest);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  #ifndef CONFIG_USER_ONLY

> -static DisasJumpType trans_ixtlbx(DisasContext *ctx, uint32_t insn,

> -                                  const DisasInsn *di)

> +static void trans_ixtlbx(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned sp;

>      unsigned rr = extract32(insn, 16, 5);

> @@ -2442,12 +2419,13 @@ static DisasJumpType trans_ixtlbx(DisasContext *ctx, uint32_t insn,

>  

>      /* Exit TB for ITLB change if mmu is enabled.  This *should* not be

>         the case, since the OS TLB fill handler runs with mmu disabled.  */

> -    return nullify_end(ctx, !is_data && (ctx->tb_flags & PSW_C)

> -                       ? DISAS_IAQ_N_STALE : DISAS_NEXT);

> +    if (!is_data && (ctx->tb_flags & PSW_C)) {

> +        ctx->base.is_jmp = DISAS_IAQ_N_STALE;

> +    }

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_pxtlbx(DisasContext *ctx, uint32_t insn,

> -                                  const DisasInsn *di)

> +static void trans_pxtlbx(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned m = extract32(insn, 5, 1);

>      unsigned sp;

> @@ -2478,12 +2456,13 @@ static DisasJumpType trans_pxtlbx(DisasContext *ctx, uint32_t insn,

>      }

>  

>      /* Exit TB for TLB change if mmu is enabled.  */

> -    return nullify_end(ctx, !is_data && (ctx->tb_flags & PSW_C)

> -                       ? DISAS_IAQ_N_STALE : DISAS_NEXT);

> +    if (!is_data && (ctx->tb_flags & PSW_C)) {

> +        ctx->base.is_jmp = DISAS_IAQ_N_STALE;

> +    }

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_lpa(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_lpa(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -2508,11 +2487,10 @@ static DisasJumpType trans_lpa(DisasContext *ctx, uint32_t insn,

>      save_gpr(ctx, rt, paddr);

>      tcg_temp_free(paddr);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_lci(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_lci(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      TCGv_reg ci;

> @@ -2527,7 +2505,7 @@ static DisasJumpType trans_lci(DisasContext *ctx, uint32_t insn,

>      save_gpr(ctx, rt, ci);

>      tcg_temp_free(ci);

>  

> -    return DISAS_NEXT;

> +    cond_free(&ctx->null_cond);

>  }

>  #endif /* !CONFIG_USER_ONLY */

>  

> @@ -2561,8 +2539,7 @@ static const DisasInsn table_mem_mgmt[] = {

>  #endif

>  };

>  

> -static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_add(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned r1 = extract32(insn, 16, 5);

> @@ -2575,7 +2552,6 @@ static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,

>      bool is_l = false;

>      bool is_tc = false;

>      bool is_tsv = false;

> -    DisasJumpType ret;

>  

>      switch (ext) {

>      case 0x6: /* ADD, SHLADD */

> @@ -2593,7 +2569,8 @@ static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,

>          is_c = is_tsv = true;

>          break;

>      default:

> -        return gen_illegal(ctx);

> +        gen_illegal(ctx);

> +        return;

>      }

>  

>      if (cf) {

> @@ -2601,12 +2578,11 @@ static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,

>      }

>      tcg_r1 = load_gpr(ctx, r1);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_add(ctx, rt, tcg_r1, tcg_r2, shift, is_l, is_tsv, is_tc, is_c, cf);

> -    return nullify_end(ctx, ret);

> +    do_add(ctx, rt, tcg_r1, tcg_r2, shift, is_l, is_tsv, is_tc, is_c, cf);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_sub(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_sub(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned r1 = extract32(insn, 16, 5);

> @@ -2617,7 +2593,6 @@ static DisasJumpType trans_sub(DisasContext *ctx, uint32_t insn,

>      bool is_b = false;

>      bool is_tc = false;

>      bool is_tsv = false;

> -    DisasJumpType ret;

>  

>      switch (ext) {

>      case 0x10: /* SUB */

> @@ -2646,32 +2621,29 @@ static DisasJumpType trans_sub(DisasContext *ctx, uint32_t insn,

>      }

>      tcg_r1 = load_gpr(ctx, r1);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_sub(ctx, rt, tcg_r1, tcg_r2, is_tsv, is_b, is_tc, cf);

> -    return nullify_end(ctx, ret);

> +    do_sub(ctx, rt, tcg_r1, tcg_r2, is_tsv, is_b, is_tc, cf);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_log(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_log(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned r1 = extract32(insn, 16, 5);

>      unsigned cf = extract32(insn, 12, 4);

>      unsigned rt = extract32(insn,  0, 5);

>      TCGv_reg tcg_r1, tcg_r2;

> -    DisasJumpType ret;

>  

>      if (cf) {

>          nullify_over(ctx);

>      }

>      tcg_r1 = load_gpr(ctx, r1);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_log(ctx, rt, tcg_r1, tcg_r2, cf, di->f.ttt);

> -    return nullify_end(ctx, ret);

> +    do_log(ctx, rt, tcg_r1, tcg_r2, cf, di->f.ttt);

> +    nullify_end(ctx);

>  }

>  

>  /* OR r,0,t -> COPY (according to gas) */

> -static DisasJumpType trans_copy(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_copy(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r1 = extract32(insn, 16, 5);

>      unsigned rt = extract32(insn,  0, 5);

> @@ -2684,49 +2656,43 @@ static DisasJumpType trans_copy(DisasContext *ctx, uint32_t insn,

>          save_gpr(ctx, rt, cpu_gr[r1]);

>      }

>      cond_free(&ctx->null_cond);

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_cmpclr(DisasContext *ctx, uint32_t insn,

> -                                  const DisasInsn *di)

> +static void trans_cmpclr(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned r1 = extract32(insn, 16, 5);

>      unsigned cf = extract32(insn, 12, 4);

>      unsigned rt = extract32(insn,  0, 5);

>      TCGv_reg tcg_r1, tcg_r2;

> -    DisasJumpType ret;

>  

>      if (cf) {

>          nullify_over(ctx);

>      }

>      tcg_r1 = load_gpr(ctx, r1);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_cmpclr(ctx, rt, tcg_r1, tcg_r2, cf);

> -    return nullify_end(ctx, ret);

> +    do_cmpclr(ctx, rt, tcg_r1, tcg_r2, cf);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_uxor(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_uxor(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned r1 = extract32(insn, 16, 5);

>      unsigned cf = extract32(insn, 12, 4);

>      unsigned rt = extract32(insn,  0, 5);

>      TCGv_reg tcg_r1, tcg_r2;

> -    DisasJumpType ret;

>  

>      if (cf) {

>          nullify_over(ctx);

>      }

>      tcg_r1 = load_gpr(ctx, r1);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_unit(ctx, rt, tcg_r1, tcg_r2, cf, false, tcg_gen_xor_reg);

> -    return nullify_end(ctx, ret);

> +    do_unit(ctx, rt, tcg_r1, tcg_r2, cf, false, tcg_gen_xor_reg);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_uaddcm(DisasContext *ctx, uint32_t insn,

> -                                  const DisasInsn *di)

> +static void trans_uaddcm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned r1 = extract32(insn, 16, 5);

> @@ -2734,7 +2700,6 @@ static DisasJumpType trans_uaddcm(DisasContext *ctx, uint32_t insn,

>      unsigned is_tc = extract32(insn, 6, 1);

>      unsigned rt = extract32(insn,  0, 5);

>      TCGv_reg tcg_r1, tcg_r2, tmp;

> -    DisasJumpType ret;

>  

>      if (cf) {

>          nullify_over(ctx);

> @@ -2743,19 +2708,17 @@ static DisasJumpType trans_uaddcm(DisasContext *ctx, uint32_t insn,

>      tcg_r2 = load_gpr(ctx, r2);

>      tmp = get_temp(ctx);

>      tcg_gen_not_reg(tmp, tcg_r2);

> -    ret = do_unit(ctx, rt, tcg_r1, tmp, cf, is_tc, tcg_gen_add_reg);

> -    return nullify_end(ctx, ret);

> +    do_unit(ctx, rt, tcg_r1, tmp, cf, is_tc, tcg_gen_add_reg);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_dcor(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_dcor(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned cf = extract32(insn, 12, 4);

>      unsigned is_i = extract32(insn, 6, 1);

>      unsigned rt = extract32(insn,  0, 5);

>      TCGv_reg tmp;

> -    DisasJumpType ret;

>  

>      nullify_over(ctx);

>  

> @@ -2766,14 +2729,13 @@ static DisasJumpType trans_dcor(DisasContext *ctx, uint32_t insn,

>      }

>      tcg_gen_andi_reg(tmp, tmp, 0x11111111);

>      tcg_gen_muli_reg(tmp, tmp, 6);

> -    ret = do_unit(ctx, rt, tmp, load_gpr(ctx, r2), cf, false,

> -                  is_i ? tcg_gen_add_reg : tcg_gen_sub_reg);

> +    do_unit(ctx, rt, tmp, load_gpr(ctx, r2), cf, false,

> +            is_i ? tcg_gen_add_reg : tcg_gen_sub_reg);

>  

> -    return nullify_end(ctx, ret);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_ds(DisasContext *ctx, uint32_t insn,

> -                              const DisasInsn *di)

> +static void trans_ds(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned r1 = extract32(insn, 16, 5);

> @@ -2835,7 +2797,7 @@ static DisasJumpType trans_ds(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free(add2);

>      tcg_temp_free(dest);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  #ifndef CONFIG_USER_ONLY

> @@ -2845,8 +2807,7 @@ static DisasJumpType trans_ds(DisasContext *ctx, uint32_t insn,

>   * or %r31,%r31,%r31 -- death loop; offline cpu

>   *                      currently implemented as idle.

>   */

> -static DisasJumpType trans_pause(DisasContext *ctx, uint32_t insn,

> -                                 const DisasInsn *di)

> +static void trans_pause(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      TCGv_i32 tmp;

>  

> @@ -2865,8 +2826,9 @@ static DisasJumpType trans_pause(DisasContext *ctx, uint32_t insn,

>                                   offsetof(CPUState, halted));

>      tcg_temp_free_i32(tmp);

>      gen_excp_1(EXCP_HALTED);

> +    ctx->base.is_jmp = DISAS_NORETURN;

>  

> -    return nullify_end(ctx, DISAS_NORETURN);

> +    nullify_end(ctx);

>  }

>  #endif

>  

> @@ -2892,7 +2854,7 @@ static const DisasInsn table_arith_log[] = {

>      { 0x08000200u, 0xfc000320u, trans_add }, /* shladd */

>  };

>  

> -static DisasJumpType trans_addi(DisasContext *ctx, uint32_t insn)

> +static void trans_addi(DisasContext *ctx, uint32_t insn)

>  {

>      target_sreg im = low_sextract(insn, 0, 11);

>      unsigned e1 = extract32(insn, 11, 1);

> @@ -2901,7 +2863,6 @@ static DisasJumpType trans_addi(DisasContext *ctx, uint32_t insn)

>      unsigned r2 = extract32(insn, 21, 5);

>      unsigned o1 = extract32(insn, 26, 1);

>      TCGv_reg tcg_im, tcg_r2;

> -    DisasJumpType ret;

>  

>      if (cf) {

>          nullify_over(ctx);

> @@ -2909,12 +2870,12 @@ static DisasJumpType trans_addi(DisasContext *ctx, uint32_t insn)

>  

>      tcg_im = load_const(ctx, im);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_add(ctx, rt, tcg_im, tcg_r2, 0, false, e1, !o1, false, cf);

> +    do_add(ctx, rt, tcg_im, tcg_r2, 0, false, e1, !o1, false, cf);

>  

> -    return nullify_end(ctx, ret);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_subi(DisasContext *ctx, uint32_t insn)

> +static void trans_subi(DisasContext *ctx, uint32_t insn)

>  {

>      target_sreg im = low_sextract(insn, 0, 11);

>      unsigned e1 = extract32(insn, 11, 1);

> @@ -2922,7 +2883,6 @@ static DisasJumpType trans_subi(DisasContext *ctx, uint32_t insn)

>      unsigned rt = extract32(insn, 16, 5);

>      unsigned r2 = extract32(insn, 21, 5);

>      TCGv_reg tcg_im, tcg_r2;

> -    DisasJumpType ret;

>  

>      if (cf) {

>          nullify_over(ctx);

> @@ -2930,19 +2890,18 @@ static DisasJumpType trans_subi(DisasContext *ctx, uint32_t insn)

>  

>      tcg_im = load_const(ctx, im);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_sub(ctx, rt, tcg_im, tcg_r2, e1, false, false, cf);

> +    do_sub(ctx, rt, tcg_im, tcg_r2, e1, false, false, cf);

>  

> -    return nullify_end(ctx, ret);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_cmpiclr(DisasContext *ctx, uint32_t insn)

> +static void trans_cmpiclr(DisasContext *ctx, uint32_t insn)

>  {

>      target_sreg im = low_sextract(insn, 0, 11);

>      unsigned cf = extract32(insn, 12, 4);

>      unsigned rt = extract32(insn, 16, 5);

>      unsigned r2 = extract32(insn, 21, 5);

>      TCGv_reg tcg_im, tcg_r2;

> -    DisasJumpType ret;

>  

>      if (cf) {

>          nullify_over(ctx);

> @@ -2950,13 +2909,13 @@ static DisasJumpType trans_cmpiclr(DisasContext *ctx, uint32_t insn)

>  

>      tcg_im = load_const(ctx, im);

>      tcg_r2 = load_gpr(ctx, r2);

> -    ret = do_cmpclr(ctx, rt, tcg_im, tcg_r2, cf);

> +    do_cmpclr(ctx, rt, tcg_im, tcg_r2, cf);

>  

> -    return nullify_end(ctx, ret);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_ld_idx_i(DisasContext *ctx, uint32_t insn,

> -                                    const DisasInsn *di)

> +static void trans_ld_idx_i(DisasContext *ctx, uint32_t insn,

> +                           const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -2968,11 +2927,11 @@ static DisasJumpType trans_ld_idx_i(DisasContext *ctx, uint32_t insn,

>      int modify = (m ? (a ? -1 : 1) : 0);

>      TCGMemOp mop = MO_TE | sz;

>  

> -    return do_load(ctx, rt, rb, 0, 0, disp, sp, modify, mop);

> +    do_load(ctx, rt, rb, 0, 0, disp, sp, modify, mop);

>  }

>  

> -static DisasJumpType trans_ld_idx_x(DisasContext *ctx, uint32_t insn,

> -                                    const DisasInsn *di)

> +static void trans_ld_idx_x(DisasContext *ctx, uint32_t insn,

> +                           const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -2983,11 +2942,11 @@ static DisasJumpType trans_ld_idx_x(DisasContext *ctx, uint32_t insn,

>      unsigned rb = extract32(insn, 21, 5);

>      TCGMemOp mop = MO_TE | sz;

>  

> -    return do_load(ctx, rt, rb, rx, u ? sz : 0, 0, sp, m, mop);

> +    do_load(ctx, rt, rb, rx, u ? sz : 0, 0, sp, m, mop);

>  }

>  

> -static DisasJumpType trans_st_idx_i(DisasContext *ctx, uint32_t insn,

> -                                    const DisasInsn *di)

> +static void trans_st_idx_i(DisasContext *ctx, uint32_t insn,

> +                           const DisasInsn *di)

>  {

>      int disp = low_sextract(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -2999,11 +2958,10 @@ static DisasJumpType trans_st_idx_i(DisasContext *ctx, uint32_t insn,

>      int modify = (m ? (a ? -1 : 1) : 0);

>      TCGMemOp mop = MO_TE | sz;

>  

> -    return do_store(ctx, rr, rb, disp, sp, modify, mop);

> +    do_store(ctx, rr, rb, disp, sp, modify, mop);

>  }

>  

> -static DisasJumpType trans_ldcw(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_ldcw(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -3046,11 +3004,10 @@ static DisasJumpType trans_ldcw(DisasContext *ctx, uint32_t insn,

>      }

>      save_gpr(ctx, rt, dest);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_stby(DisasContext *ctx, uint32_t insn,

> -                                const DisasInsn *di)

> +static void trans_stby(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      target_sreg disp = low_sextract(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -3085,56 +3042,50 @@ static DisasJumpType trans_stby(DisasContext *ctx, uint32_t insn,

>          save_gpr(ctx, rb, ofs);

>      }

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  #ifndef CONFIG_USER_ONLY

> -static DisasJumpType trans_ldwa_idx_i(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_ldwa_idx_i(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      int hold_mmu_idx = ctx->mmu_idx;

> -    DisasJumpType ret;

>  

>      CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);

>  

>      /* ??? needs fixing for hppa64 -- ldda does not follow the same

>         format wrt the sub-opcode in bits 6:9.  */

>      ctx->mmu_idx = MMU_PHYS_IDX;

> -    ret = trans_ld_idx_i(ctx, insn, di);

> +    trans_ld_idx_i(ctx, insn, di);

>      ctx->mmu_idx = hold_mmu_idx;

> -    return ret;

>  }

>  

> -static DisasJumpType trans_ldwa_idx_x(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_ldwa_idx_x(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      int hold_mmu_idx = ctx->mmu_idx;

> -    DisasJumpType ret;

>  

>      CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);

>  

>      /* ??? needs fixing for hppa64 -- ldda does not follow the same

>         format wrt the sub-opcode in bits 6:9.  */

>      ctx->mmu_idx = MMU_PHYS_IDX;

> -    ret = trans_ld_idx_x(ctx, insn, di);

> +    trans_ld_idx_x(ctx, insn, di);

>      ctx->mmu_idx = hold_mmu_idx;

> -    return ret;

>  }

>  

> -static DisasJumpType trans_stwa_idx_i(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_stwa_idx_i(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      int hold_mmu_idx = ctx->mmu_idx;

> -    DisasJumpType ret;

>  

>      CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);

>  

>      /* ??? needs fixing for hppa64 -- ldda does not follow the same

>         format wrt the sub-opcode in bits 6:9.  */

>      ctx->mmu_idx = MMU_PHYS_IDX;

> -    ret = trans_st_idx_i(ctx, insn, di);

> +    trans_st_idx_i(ctx, insn, di);

>      ctx->mmu_idx = hold_mmu_idx;

> -    return ret;

>  }

>  #endif

>  

> @@ -3151,7 +3102,7 @@ static const DisasInsn table_index_mem[] = {

>  #endif

>  };

>  

> -static DisasJumpType trans_ldil(DisasContext *ctx, uint32_t insn)

> +static void trans_ldil(DisasContext *ctx, uint32_t insn)

>  {

>      unsigned rt = extract32(insn, 21, 5);

>      target_sreg i = assemble_21(insn);

> @@ -3160,11 +3111,9 @@ static DisasJumpType trans_ldil(DisasContext *ctx, uint32_t insn)

>      tcg_gen_movi_reg(tcg_rt, i);

>      save_gpr(ctx, rt, tcg_rt);

>      cond_free(&ctx->null_cond);

> -

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_addil(DisasContext *ctx, uint32_t insn)

> +static void trans_addil(DisasContext *ctx, uint32_t insn)

>  {

>      unsigned rt = extract32(insn, 21, 5);

>      target_sreg i = assemble_21(insn);

> @@ -3174,11 +3123,9 @@ static DisasJumpType trans_addil(DisasContext *ctx, uint32_t insn)

>      tcg_gen_addi_reg(tcg_r1, tcg_rt, i);

>      save_gpr(ctx, 1, tcg_r1);

>      cond_free(&ctx->null_cond);

> -

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_ldo(DisasContext *ctx, uint32_t insn)

> +static void trans_ldo(DisasContext *ctx, uint32_t insn)

>  {

>      unsigned rb = extract32(insn, 21, 5);

>      unsigned rt = extract32(insn, 16, 5);

> @@ -3194,23 +3141,20 @@ static DisasJumpType trans_ldo(DisasContext *ctx, uint32_t insn)

>      }

>      save_gpr(ctx, rt, tcg_rt);

>      cond_free(&ctx->null_cond);

> -

> -    return DISAS_NEXT;

>  }

>  

> -static DisasJumpType trans_load(DisasContext *ctx, uint32_t insn,

> -                                bool is_mod, TCGMemOp mop)

> +static void trans_load(DisasContext *ctx, uint32_t insn,

> +                       bool is_mod, TCGMemOp mop)

>  {

>      unsigned rb = extract32(insn, 21, 5);

>      unsigned rt = extract32(insn, 16, 5);

>      unsigned sp = extract32(insn, 14, 2);

>      target_sreg i = assemble_16(insn);

>  

> -    return do_load(ctx, rt, rb, 0, 0, i, sp,

> -                   is_mod ? (i < 0 ? -1 : 1) : 0, mop);

> +    do_load(ctx, rt, rb, 0, 0, i, sp, is_mod ? (i < 0 ? -1 : 1) : 0, mop);

>  }

>  

> -static DisasJumpType trans_load_w(DisasContext *ctx, uint32_t insn)

> +static void trans_load_w(DisasContext *ctx, uint32_t insn)

>  {

>      unsigned rb = extract32(insn, 21, 5);

>      unsigned rt = extract32(insn, 16, 5);

> @@ -3222,17 +3166,20 @@ static DisasJumpType trans_load_w(DisasContext *ctx, uint32_t insn)

>      case 0:

>      case 1:

>          /* FLDW without modification.  */

> -        return do_floadw(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);

> +        do_floadw(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);

> +        break;

>      case 2:

>          /* LDW with modification.  Note that the sign of I selects

>             post-dec vs pre-inc.  */

> -        return do_load(ctx, rt, rb, 0, 0, i, sp, (i < 0 ? 1 : -1), MO_TEUL);

> +        do_load(ctx, rt, rb, 0, 0, i, sp, (i < 0 ? 1 : -1), MO_TEUL);

> +        break;

>      default:

> -        return gen_illegal(ctx);

> +        gen_illegal(ctx);

> +        break;

>      }

>  }

>  

> -static DisasJumpType trans_fload_mod(DisasContext *ctx, uint32_t insn)

> +static void trans_fload_mod(DisasContext *ctx, uint32_t insn)

>  {

>      target_sreg i = assemble_16a(insn);

>      unsigned t1 = extract32(insn, 1, 1);

> @@ -3242,21 +3189,21 @@ static DisasJumpType trans_fload_mod(DisasContext *ctx, uint32_t insn)

>      unsigned rb = extract32(insn, 21, 5);

>  

>      /* FLDW with modification.  */

> -    return do_floadw(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));

> +    do_floadw(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));

>  }

>  

> -static DisasJumpType trans_store(DisasContext *ctx, uint32_t insn,

> -                                 bool is_mod, TCGMemOp mop)

> +static void trans_store(DisasContext *ctx, uint32_t insn,

> +                        bool is_mod, TCGMemOp mop)

>  {

>      unsigned rb = extract32(insn, 21, 5);

>      unsigned rt = extract32(insn, 16, 5);

>      unsigned sp = extract32(insn, 14, 2);

>      target_sreg i = assemble_16(insn);

>  

> -    return do_store(ctx, rt, rb, i, sp, is_mod ? (i < 0 ? -1 : 1) : 0, mop);

> +    do_store(ctx, rt, rb, i, sp, is_mod ? (i < 0 ? -1 : 1) : 0, mop);

>  }

>  

> -static DisasJumpType trans_store_w(DisasContext *ctx, uint32_t insn)

> +static void trans_store_w(DisasContext *ctx, uint32_t insn)

>  {

>      unsigned rb = extract32(insn, 21, 5);

>      unsigned rt = extract32(insn, 16, 5);

> @@ -3268,16 +3215,19 @@ static DisasJumpType trans_store_w(DisasContext *ctx, uint32_t insn)

>      case 0:

>      case 1:

>          /* FSTW without modification.  */

> -        return do_fstorew(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);

> +        do_fstorew(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);

> +        break;

>      case 2:

>          /* STW with modification.  */

> -        return do_store(ctx, rt, rb, i, sp, (i < 0 ? 1 : -1), MO_TEUL);

> +        do_store(ctx, rt, rb, i, sp, (i < 0 ? 1 : -1), MO_TEUL);

> +        break;

>      default:

> -        return gen_illegal(ctx);

> +        gen_illegal(ctx);

> +        break;

>      }

>  }

>  

> -static DisasJumpType trans_fstore_mod(DisasContext *ctx, uint32_t insn)

> +static void trans_fstore_mod(DisasContext *ctx, uint32_t insn)

>  {

>      target_sreg i = assemble_16a(insn);

>      unsigned t1 = extract32(insn, 1, 1);

> @@ -3287,10 +3237,10 @@ static DisasJumpType trans_fstore_mod(DisasContext *ctx, uint32_t insn)

>      unsigned rb = extract32(insn, 21, 5);

>  

>      /* FSTW with modification.  */

> -    return do_fstorew(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));

> +    do_fstorew(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));

>  }

>  

> -static DisasJumpType trans_copr_w(DisasContext *ctx, uint32_t insn)

> +static void trans_copr_w(DisasContext *ctx, uint32_t insn)

>  {

>      unsigned t0 = extract32(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -3319,14 +3269,18 @@ static DisasJumpType trans_copr_w(DisasContext *ctx, uint32_t insn)

>  

>      switch (ext3) {

>      case 0: /* FLDW */

> -        return do_floadw(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        do_floadw(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        break;

>      case 4: /* FSTW */

> -        return do_fstorew(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        do_fstorew(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        break;

> +    default:

> +        gen_illegal(ctx);

> +        break;

>      }

> -    return gen_illegal(ctx);

>  }

>  

> -static DisasJumpType trans_copr_dw(DisasContext *ctx, uint32_t insn)

> +static void trans_copr_dw(DisasContext *ctx, uint32_t insn)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned m = extract32(insn, 5, 1);

> @@ -3353,16 +3307,19 @@ static DisasJumpType trans_copr_dw(DisasContext *ctx, uint32_t insn)

>  

>      switch (ext4) {

>      case 0: /* FLDD */

> -        return do_floadd(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        do_floadd(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        break;

>      case 8: /* FSTD */

> -        return do_fstored(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        do_fstored(ctx, rt, rb, rx, scale, disp, sp, modify);

> +        break;

>      default:

> -        return gen_illegal(ctx);

> +        gen_illegal(ctx);

> +        break;

>      }

>  }

>  

> -static DisasJumpType trans_cmpb(DisasContext *ctx, uint32_t insn,

> -                                bool is_true, bool is_imm, bool is_dw)

> +static void trans_cmpb(DisasContext *ctx, uint32_t insn,

> +                       bool is_true, bool is_imm, bool is_dw)

>  {

>      target_sreg disp = assemble_12(insn) * 4;

>      unsigned n = extract32(insn, 1, 1);

> @@ -3390,11 +3347,11 @@ static DisasJumpType trans_cmpb(DisasContext *ctx, uint32_t insn,

>      }

>  

>      cond = do_sub_cond(cf, dest, in1, in2, sv);

> -    return do_cbranch(ctx, disp, n, &cond);

> +    do_cbranch(ctx, disp, n, &cond);

>  }

>  

> -static DisasJumpType trans_addb(DisasContext *ctx, uint32_t insn,

> -                                bool is_true, bool is_imm)

> +static void trans_addb(DisasContext *ctx, uint32_t insn,

> +                       bool is_true, bool is_imm)

>  {

>      target_sreg disp = assemble_12(insn) * 4;

>      unsigned n = extract32(insn, 1, 1);

> @@ -3432,10 +3389,10 @@ static DisasJumpType trans_addb(DisasContext *ctx, uint32_t insn,

>      }

>  

>      cond = do_cond(cf, dest, cb_msb, sv);

> -    return do_cbranch(ctx, disp, n, &cond);

> +    do_cbranch(ctx, disp, n, &cond);

>  }

>  

> -static DisasJumpType trans_bb(DisasContext *ctx, uint32_t insn)

> +static void trans_bb(DisasContext *ctx, uint32_t insn)

>  {

>      target_sreg disp = assemble_12(insn) * 4;

>      unsigned n = extract32(insn, 1, 1);

> @@ -3458,10 +3415,10 @@ static DisasJumpType trans_bb(DisasContext *ctx, uint32_t insn)

>  

>      cond = cond_make_0(c ? TCG_COND_GE : TCG_COND_LT, tmp);

>      tcg_temp_free(tmp);

> -    return do_cbranch(ctx, disp, n, &cond);

> +    do_cbranch(ctx, disp, n, &cond);

>  }

>  

> -static DisasJumpType trans_movb(DisasContext *ctx, uint32_t insn, bool is_imm)

> +static void trans_movb(DisasContext *ctx, uint32_t insn, bool is_imm)

>  {

>      target_sreg disp = assemble_12(insn) * 4;

>      unsigned n = extract32(insn, 1, 1);

> @@ -3483,11 +3440,11 @@ static DisasJumpType trans_movb(DisasContext *ctx, uint32_t insn, bool is_imm)

>      }

>  

>      cond = do_sed_cond(c, dest);

> -    return do_cbranch(ctx, disp, n, &cond);

> +    do_cbranch(ctx, disp, n, &cond);

>  }

>  

> -static DisasJumpType trans_shrpw_sar(DisasContext *ctx, uint32_t insn,

> -                                    const DisasInsn *di)

> +static void trans_shrpw_sar(DisasContext *ctx, uint32_t insn,

> +                            const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned c = extract32(insn, 13, 3);

> @@ -3528,11 +3485,11 @@ static DisasJumpType trans_shrpw_sar(DisasContext *ctx, uint32_t insn,

>      if (c) {

>          ctx->null_cond = do_sed_cond(c, dest);

>      }

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_shrpw_imm(DisasContext *ctx, uint32_t insn,

> -                                     const DisasInsn *di)

> +static void trans_shrpw_imm(DisasContext *ctx, uint32_t insn,

> +                            const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned cpos = extract32(insn, 5, 5);

> @@ -3569,11 +3526,11 @@ static DisasJumpType trans_shrpw_imm(DisasContext *ctx, uint32_t insn,

>      if (c) {

>          ctx->null_cond = do_sed_cond(c, dest);

>      }

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_extrw_sar(DisasContext *ctx, uint32_t insn,

> -                                     const DisasInsn *di)

> +static void trans_extrw_sar(DisasContext *ctx, uint32_t insn,

> +                            const DisasInsn *di)

>  {

>      unsigned clen = extract32(insn, 0, 5);

>      unsigned is_se = extract32(insn, 10, 1);

> @@ -3608,11 +3565,11 @@ static DisasJumpType trans_extrw_sar(DisasContext *ctx, uint32_t insn,

>      if (c) {

>          ctx->null_cond = do_sed_cond(c, dest);

>      }

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_extrw_imm(DisasContext *ctx, uint32_t insn,

> -                                     const DisasInsn *di)

> +static void trans_extrw_imm(DisasContext *ctx, uint32_t insn,

> +                            const DisasInsn *di)

>  {

>      unsigned clen = extract32(insn, 0, 5);

>      unsigned pos = extract32(insn, 5, 5);

> @@ -3642,7 +3599,7 @@ static DisasJumpType trans_extrw_imm(DisasContext *ctx, uint32_t insn,

>      if (c) {

>          ctx->null_cond = do_sed_cond(c, dest);

>      }

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  static const DisasInsn table_sh_ex[] = {

> @@ -3652,8 +3609,8 @@ static const DisasInsn table_sh_ex[] = {

>      { 0xd0001800u, 0xfc001800u, trans_extrw_imm },

>  };

>  

> -static DisasJumpType trans_depw_imm_c(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_depw_imm_c(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned clen = extract32(insn, 0, 5);

>      unsigned cpos = extract32(insn, 5, 5);

> @@ -3693,11 +3650,11 @@ static DisasJumpType trans_depw_imm_c(DisasContext *ctx, uint32_t insn,

>      if (c) {

>          ctx->null_cond = do_sed_cond(c, dest);

>      }

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_depw_imm(DisasContext *ctx, uint32_t insn,

> -                                    const DisasInsn *di)

> +static void trans_depw_imm(DisasContext *ctx, uint32_t insn,

> +                           const DisasInsn *di)

>  {

>      unsigned clen = extract32(insn, 0, 5);

>      unsigned cpos = extract32(insn, 5, 5);

> @@ -3730,11 +3687,11 @@ static DisasJumpType trans_depw_imm(DisasContext *ctx, uint32_t insn,

>      if (c) {

>          ctx->null_cond = do_sed_cond(c, dest);

>      }

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_depw_sar(DisasContext *ctx, uint32_t insn,

> -                                    const DisasInsn *di)

> +static void trans_depw_sar(DisasContext *ctx, uint32_t insn,

> +                           const DisasInsn *di)

>  {

>      unsigned clen = extract32(insn, 0, 5);

>      unsigned nz = extract32(insn, 10, 1);

> @@ -3782,7 +3739,7 @@ static DisasJumpType trans_depw_sar(DisasContext *ctx, uint32_t insn,

>      if (c) {

>          ctx->null_cond = do_sed_cond(c, dest);

>      }

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  static const DisasInsn table_depw[] = {

> @@ -3791,7 +3748,7 @@ static const DisasInsn table_depw[] = {

>      { 0xd4001800u, 0xfc001800u, trans_depw_imm_c },

>  };

>  

> -static DisasJumpType trans_be(DisasContext *ctx, uint32_t insn, bool is_l)

> +static void trans_be(DisasContext *ctx, uint32_t insn, bool is_l)

>  {

>      unsigned n = extract32(insn, 1, 1);

>      unsigned b = extract32(insn, 21, 5);

> @@ -3820,7 +3777,7 @@ static DisasJumpType trans_be(DisasContext *ctx, uint32_t insn, bool is_l)

>      tmp = do_ibranch_priv(ctx, tmp);

>  

>  #ifdef CONFIG_USER_ONLY

> -    return do_ibranch(ctx, tmp, is_l ? 31 : 0, n);

> +    do_ibranch(ctx, tmp, is_l ? 31 : 0, n);

>  #else

>      TCGv_i64 new_spc = tcg_temp_new_i64();

>  

> @@ -3845,22 +3802,21 @@ static DisasJumpType trans_be(DisasContext *ctx, uint32_t insn, bool is_l)

>      }

>      tcg_temp_free_i64(new_spc);

>      tcg_gen_lookup_and_goto_ptr();

> -    return nullify_end(ctx, DISAS_NORETURN);

> +    ctx->base.is_jmp = DISAS_NORETURN;

> +    nullify_end(ctx);

>  #endif

>  }

>  

> -static DisasJumpType trans_bl(DisasContext *ctx, uint32_t insn,

> -                              const DisasInsn *di)

> +static void trans_bl(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned n = extract32(insn, 1, 1);

>      unsigned link = extract32(insn, 21, 5);

>      target_sreg disp = assemble_17(insn);

>  

> -    return do_dbranch(ctx, iaoq_dest(ctx, disp), link, n);

> +    do_dbranch(ctx, iaoq_dest(ctx, disp), link, n);

>  }

>  

> -static DisasJumpType trans_b_gate(DisasContext *ctx, uint32_t insn,

> -                                  const DisasInsn *di)

> +static void trans_b_gate(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned n = extract32(insn, 1, 1);

>      unsigned link = extract32(insn, 21, 5);

> @@ -3879,7 +3835,8 @@ static DisasJumpType trans_b_gate(DisasContext *ctx, uint32_t insn,

>       * in which instructions at evil would run with increased privs.

>       */

>      if (ctx->iaoq_b == -1 || ctx->iaoq_b != ctx->iaoq_f + 4) {

> -        return gen_illegal(ctx);

> +        gen_illegal(ctx);

> +        return;

>      }

>  

>  #ifndef CONFIG_USER_ONLY

> @@ -3903,20 +3860,18 @@ static DisasJumpType trans_b_gate(DisasContext *ctx, uint32_t insn,

>      }

>  #endif

>  

> -    return do_dbranch(ctx, dest, link, n);

> +    do_dbranch(ctx, dest, link, n);

>  }

>  

> -static DisasJumpType trans_bl_long(DisasContext *ctx, uint32_t insn,

> -                                   const DisasInsn *di)

> +static void trans_bl_long(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned n = extract32(insn, 1, 1);

>      target_sreg disp = assemble_22(insn);

>  

> -    return do_dbranch(ctx, iaoq_dest(ctx, disp), 2, n);

> +    do_dbranch(ctx, iaoq_dest(ctx, disp), 2, n);

>  }

>  

> -static DisasJumpType trans_blr(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_blr(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned n = extract32(insn, 1, 1);

>      unsigned rx = extract32(insn, 16, 5);

> @@ -3926,11 +3881,10 @@ static DisasJumpType trans_blr(DisasContext *ctx, uint32_t insn,

>      tcg_gen_shli_reg(tmp, load_gpr(ctx, rx), 3);

>      tcg_gen_addi_reg(tmp, tmp, ctx->iaoq_f + 8);

>      /* The computation here never changes privilege level.  */

> -    return do_ibranch(ctx, tmp, link, n);

> +    do_ibranch(ctx, tmp, link, n);

>  }

>  

> -static DisasJumpType trans_bv(DisasContext *ctx, uint32_t insn,

> -                              const DisasInsn *di)

> +static void trans_bv(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned n = extract32(insn, 1, 1);

>      unsigned rx = extract32(insn, 16, 5);

> @@ -3945,11 +3899,10 @@ static DisasJumpType trans_bv(DisasContext *ctx, uint32_t insn,

>          tcg_gen_add_reg(dest, dest, load_gpr(ctx, rb));

>      }

>      dest = do_ibranch_priv(ctx, dest);

> -    return do_ibranch(ctx, dest, 0, n);

> +    do_ibranch(ctx, dest, 0, n);

>  }

>  

> -static DisasJumpType trans_bve(DisasContext *ctx, uint32_t insn,

> -                               const DisasInsn *di)

> +static void trans_bve(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned n = extract32(insn, 1, 1);

>      unsigned rb = extract32(insn, 21, 5);

> @@ -3958,7 +3911,7 @@ static DisasJumpType trans_bve(DisasContext *ctx, uint32_t insn,

>  

>  #ifdef CONFIG_USER_ONLY

>      dest = do_ibranch_priv(ctx, load_gpr(ctx, rb));

> -    return do_ibranch(ctx, dest, link, n);

> +    do_ibranch(ctx, dest, link, n);

>  #else

>      nullify_over(ctx);

>      dest = do_ibranch_priv(ctx, load_gpr(ctx, rb));

> @@ -3974,7 +3927,8 @@ static DisasJumpType trans_bve(DisasContext *ctx, uint32_t insn,

>      }

>      nullify_set(ctx, n);

>      tcg_gen_lookup_and_goto_ptr();

> -    return nullify_end(ctx, DISAS_NORETURN);

> +    ctx->base.is_jmp = DISAS_NORETURN;

> +    nullify_end(ctx);

>  #endif

>  }

>  

> @@ -3987,87 +3941,87 @@ static const DisasInsn table_branch[] = {

>      { 0xe8002000u, 0xfc00e000u, trans_b_gate },

>  };

>  

> -static DisasJumpType trans_fop_wew_0c(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fop_wew_0c(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fop_wew(ctx, rt, ra, di->f.wew);

> +    do_fop_wew(ctx, rt, ra, di->f.wew);

>  }

>  

> -static DisasJumpType trans_fop_wew_0e(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fop_wew_0e(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = assemble_rt64(insn);

>      unsigned ra = assemble_ra64(insn);

> -    return do_fop_wew(ctx, rt, ra, di->f.wew);

> +    do_fop_wew(ctx, rt, ra, di->f.wew);

>  }

>  

> -static DisasJumpType trans_fop_ded(DisasContext *ctx, uint32_t insn,

> -                                   const DisasInsn *di)

> +static void trans_fop_ded(DisasContext *ctx, uint32_t insn,

> +                          const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fop_ded(ctx, rt, ra, di->f.ded);

> +    do_fop_ded(ctx, rt, ra, di->f.ded);

>  }

>  

> -static DisasJumpType trans_fop_wed_0c(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fop_wed_0c(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fop_wed(ctx, rt, ra, di->f.wed);

> +    do_fop_wed(ctx, rt, ra, di->f.wed);

>  }

>  

> -static DisasJumpType trans_fop_wed_0e(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fop_wed_0e(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = assemble_rt64(insn);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fop_wed(ctx, rt, ra, di->f.wed);

> +    do_fop_wed(ctx, rt, ra, di->f.wed);

>  }

>  

> -static DisasJumpType trans_fop_dew_0c(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fop_dew_0c(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fop_dew(ctx, rt, ra, di->f.dew);

> +    do_fop_dew(ctx, rt, ra, di->f.dew);

>  }

>  

> -static DisasJumpType trans_fop_dew_0e(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fop_dew_0e(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned ra = assemble_ra64(insn);

> -    return do_fop_dew(ctx, rt, ra, di->f.dew);

> +    do_fop_dew(ctx, rt, ra, di->f.dew);

>  }

>  

> -static DisasJumpType trans_fop_weww_0c(DisasContext *ctx, uint32_t insn,

> -                                       const DisasInsn *di)

> +static void trans_fop_weww_0c(DisasContext *ctx, uint32_t insn,

> +                              const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned rb = extract32(insn, 16, 5);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fop_weww(ctx, rt, ra, rb, di->f.weww);

> +    do_fop_weww(ctx, rt, ra, rb, di->f.weww);

>  }

>  

> -static DisasJumpType trans_fop_weww_0e(DisasContext *ctx, uint32_t insn,

> -                                       const DisasInsn *di)

> +static void trans_fop_weww_0e(DisasContext *ctx, uint32_t insn,

> +                              const DisasInsn *di)

>  {

>      unsigned rt = assemble_rt64(insn);

>      unsigned rb = assemble_rb64(insn);

>      unsigned ra = assemble_ra64(insn);

> -    return do_fop_weww(ctx, rt, ra, rb, di->f.weww);

> +    do_fop_weww(ctx, rt, ra, rb, di->f.weww);

>  }

>  

> -static DisasJumpType trans_fop_dedd(DisasContext *ctx, uint32_t insn,

> -                                    const DisasInsn *di)

> +static void trans_fop_dedd(DisasContext *ctx, uint32_t insn,

> +                           const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned rb = extract32(insn, 16, 5);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fop_dedd(ctx, rt, ra, rb, di->f.dedd);

> +    do_fop_dedd(ctx, rt, ra, rb, di->f.dedd);

>  }

>  

>  static void gen_fcpy_s(TCGv_i32 dst, TCGv_env unused, TCGv_i32 src)

> @@ -4110,8 +4064,8 @@ static void gen_fnegabs_d(TCGv_i64 dst, TCGv_env unused, TCGv_i64 src)

>      tcg_gen_ori_i64(dst, src, INT64_MIN);

>  }

>  

> -static DisasJumpType do_fcmp_s(DisasContext *ctx, unsigned ra, unsigned rb,

> -                               unsigned y, unsigned c)

> +static void do_fcmp_s(DisasContext *ctx, unsigned ra, unsigned rb,

> +                      unsigned y, unsigned c)

>  {

>      TCGv_i32 ta, tb, tc, ty;

>  

> @@ -4129,31 +4083,30 @@ static DisasJumpType do_fcmp_s(DisasContext *ctx, unsigned ra, unsigned rb,

>      tcg_temp_free_i32(ty);

>      tcg_temp_free_i32(tc);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_fcmp_s_0c(DisasContext *ctx, uint32_t insn,

> -                                     const DisasInsn *di)

> +static void trans_fcmp_s_0c(DisasContext *ctx, uint32_t insn,

> +                            const DisasInsn *di)

>  {

>      unsigned c = extract32(insn, 0, 5);

>      unsigned y = extract32(insn, 13, 3);

>      unsigned rb = extract32(insn, 16, 5);

>      unsigned ra = extract32(insn, 21, 5);

> -    return do_fcmp_s(ctx, ra, rb, y, c);

> +    do_fcmp_s(ctx, ra, rb, y, c);

>  }

>  

> -static DisasJumpType trans_fcmp_s_0e(DisasContext *ctx, uint32_t insn,

> -                                     const DisasInsn *di)

> +static void trans_fcmp_s_0e(DisasContext *ctx, uint32_t insn,

> +                            const DisasInsn *di)

>  {

>      unsigned c = extract32(insn, 0, 5);

>      unsigned y = extract32(insn, 13, 3);

>      unsigned rb = assemble_rb64(insn);

>      unsigned ra = assemble_ra64(insn);

> -    return do_fcmp_s(ctx, ra, rb, y, c);

> +    do_fcmp_s(ctx, ra, rb, y, c);

>  }

>  

> -static DisasJumpType trans_fcmp_d(DisasContext *ctx, uint32_t insn,

> -                                  const DisasInsn *di)

> +static void trans_fcmp_d(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned c = extract32(insn, 0, 5);

>      unsigned y = extract32(insn, 13, 3);

> @@ -4176,11 +4129,11 @@ static DisasJumpType trans_fcmp_d(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free_i32(ty);

>      tcg_temp_free_i32(tc);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_ftest_t(DisasContext *ctx, uint32_t insn,

> -                                   const DisasInsn *di)

> +static void trans_ftest_t(DisasContext *ctx, uint32_t insn,

> +                          const DisasInsn *di)

>  {

>      unsigned y = extract32(insn, 13, 3);

>      unsigned cbit = (y ^ 1) - 1;

> @@ -4194,11 +4147,11 @@ static DisasJumpType trans_ftest_t(DisasContext *ctx, uint32_t insn,

>      ctx->null_cond = cond_make_0(TCG_COND_NE, t);

>      tcg_temp_free(t);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_ftest_q(DisasContext *ctx, uint32_t insn,

> -                                   const DisasInsn *di)

> +static void trans_ftest_q(DisasContext *ctx, uint32_t insn,

> +                          const DisasInsn *di)

>  {

>      unsigned c = extract32(insn, 0, 5);

>      int mask;

> @@ -4237,7 +4190,8 @@ static DisasJumpType trans_ftest_q(DisasContext *ctx, uint32_t insn,

>          mask = 0x4200000;

>          break;

>      default:

> -        return gen_illegal(ctx);

> +        gen_illegal(ctx);

> +        return;

>      }

>      if (inv) {

>          TCGv_reg c = load_const(ctx, mask);

> @@ -4248,11 +4202,10 @@ static DisasJumpType trans_ftest_q(DisasContext *ctx, uint32_t insn,

>          ctx->null_cond = cond_make_0(TCG_COND_EQ, t);

>      }

>   done:

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_xmpyu(DisasContext *ctx, uint32_t insn,

> -                                 const DisasInsn *di)

> +static void trans_xmpyu(DisasContext *ctx, uint32_t insn, const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned rb = assemble_rb64(insn);

> @@ -4268,7 +4221,7 @@ static DisasJumpType trans_xmpyu(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free_i64(a);

>      tcg_temp_free_i64(b);

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  #define FOP_DED  trans_fop_ded, .f.ded

> @@ -4443,8 +4396,7 @@ static inline int fmpyadd_s_reg(unsigned r)

>      return (r & 16) * 2 + 16 + (r & 15);

>  }

>  

> -static DisasJumpType trans_fmpyadd(DisasContext *ctx,

> -                                   uint32_t insn, bool is_sub)

> +static void trans_fmpyadd(DisasContext *ctx, uint32_t insn, bool is_sub)

>  {

>      unsigned tm = extract32(insn, 0, 5);

>      unsigned f = extract32(insn, 5, 1);

> @@ -4472,11 +4424,11 @@ static DisasJumpType trans_fmpyadd(DisasContext *ctx,

>                      is_sub ? gen_helper_fsub_d : gen_helper_fadd_d);

>      }

>  

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_fmpyfadd_s(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fmpyfadd_s(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = assemble_rt64(insn);

>      unsigned neg = extract32(insn, 5, 1);

> @@ -4500,11 +4452,11 @@ static DisasJumpType trans_fmpyfadd_s(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free_i32(c);

>      save_frw_i32(rt, a);

>      tcg_temp_free_i32(a);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

> -static DisasJumpType trans_fmpyfadd_d(DisasContext *ctx, uint32_t insn,

> -                                      const DisasInsn *di)

> +static void trans_fmpyfadd_d(DisasContext *ctx, uint32_t insn,

> +                             const DisasInsn *di)

>  {

>      unsigned rt = extract32(insn, 0, 5);

>      unsigned neg = extract32(insn, 5, 1);

> @@ -4528,7 +4480,7 @@ static DisasJumpType trans_fmpyfadd_d(DisasContext *ctx, uint32_t insn,

>      tcg_temp_free_i64(c);

>      save_frd(rt, a);

>      tcg_temp_free_i64(a);

> -    return nullify_end(ctx, DISAS_NEXT);

> +    nullify_end(ctx);

>  }

>  

>  static const DisasInsn table_fp_fused[] = {

> @@ -4536,127 +4488,175 @@ static const DisasInsn table_fp_fused[] = {

>      { 0xb8000800u, 0xfc0019c0u, trans_fmpyfadd_d }

>  };

>  

> -static DisasJumpType translate_table_int(DisasContext *ctx, uint32_t insn,

> -                                         const DisasInsn table[], size_t n)

> +static void translate_table_int(DisasContext *ctx, uint32_t insn,

> +                                const DisasInsn table[], size_t n)

>  {

>      size_t i;

>      for (i = 0; i < n; ++i) {

>          if ((insn & table[i].mask) == table[i].insn) {

> -            return table[i].trans(ctx, insn, &table[i]);

> +            table[i].trans(ctx, insn, &table[i]);

> +            return;

>          }

>      }

>      qemu_log_mask(LOG_UNIMP, "UNIMP insn %08x @ " TARGET_FMT_lx "\n",

>                    insn, ctx->base.pc_next);

> -    return gen_illegal(ctx);

> +    gen_illegal(ctx);

>  }

>  

>  #define translate_table(ctx, insn, table) \

>      translate_table_int(ctx, insn, table, ARRAY_SIZE(table))

>  

> -static DisasJumpType translate_one(DisasContext *ctx, uint32_t insn)

> +static void translate_one(DisasContext *ctx, uint32_t insn)

>  {

>      uint32_t opc = extract32(insn, 26, 6);

>  

>      switch (opc) {

>      case 0x00: /* system op */

> -        return translate_table(ctx, insn, table_system);

> +        translate_table(ctx, insn, table_system);

> +        return;

>      case 0x01:

> -        return translate_table(ctx, insn, table_mem_mgmt);

> +        translate_table(ctx, insn, table_mem_mgmt);

> +        return;

>      case 0x02:

> -        return translate_table(ctx, insn, table_arith_log);

> +        translate_table(ctx, insn, table_arith_log);

> +        return;

>      case 0x03:

> -        return translate_table(ctx, insn, table_index_mem);

> +        translate_table(ctx, insn, table_index_mem);

> +        return;

>      case 0x06:

> -        return trans_fmpyadd(ctx, insn, false);

> +        trans_fmpyadd(ctx, insn, false);

> +        return;

>      case 0x08:

> -        return trans_ldil(ctx, insn);

> +        trans_ldil(ctx, insn);

> +        return;

>      case 0x09:

> -        return trans_copr_w(ctx, insn);

> +        trans_copr_w(ctx, insn);

> +        return;

>      case 0x0A:

> -        return trans_addil(ctx, insn);

> +        trans_addil(ctx, insn);

> +        return;

>      case 0x0B:

> -        return trans_copr_dw(ctx, insn);

> +        trans_copr_dw(ctx, insn);

> +        return;

>      case 0x0C:

> -        return translate_table(ctx, insn, table_float_0c);

> +        translate_table(ctx, insn, table_float_0c);

> +        return;

>      case 0x0D:

> -        return trans_ldo(ctx, insn);

> +        trans_ldo(ctx, insn);

> +        return;

>      case 0x0E:

> -        return translate_table(ctx, insn, table_float_0e);

> +        translate_table(ctx, insn, table_float_0e);

> +        return;

>  

>      case 0x10:

> -        return trans_load(ctx, insn, false, MO_UB);

> +        trans_load(ctx, insn, false, MO_UB);

> +        return;

>      case 0x11:

> -        return trans_load(ctx, insn, false, MO_TEUW);

> +        trans_load(ctx, insn, false, MO_TEUW);

> +        return;

>      case 0x12:

> -        return trans_load(ctx, insn, false, MO_TEUL);

> +        trans_load(ctx, insn, false, MO_TEUL);

> +        return;

>      case 0x13:

> -        return trans_load(ctx, insn, true, MO_TEUL);

> +        trans_load(ctx, insn, true, MO_TEUL);

> +        return;

>      case 0x16:

> -        return trans_fload_mod(ctx, insn);

> +        trans_fload_mod(ctx, insn);

> +        return;

>      case 0x17:

> -        return trans_load_w(ctx, insn);

> +        trans_load_w(ctx, insn);

> +        return;

>      case 0x18:

> -        return trans_store(ctx, insn, false, MO_UB);

> +        trans_store(ctx, insn, false, MO_UB);

> +        return;

>      case 0x19:

> -        return trans_store(ctx, insn, false, MO_TEUW);

> +        trans_store(ctx, insn, false, MO_TEUW);

> +        return;

>      case 0x1A:

> -        return trans_store(ctx, insn, false, MO_TEUL);

> +        trans_store(ctx, insn, false, MO_TEUL);

> +        return;

>      case 0x1B:

> -        return trans_store(ctx, insn, true, MO_TEUL);

> +        trans_store(ctx, insn, true, MO_TEUL);

> +        return;

>      case 0x1E:

> -        return trans_fstore_mod(ctx, insn);

> +        trans_fstore_mod(ctx, insn);

> +        return;

>      case 0x1F:

> -        return trans_store_w(ctx, insn);

> +        trans_store_w(ctx, insn);

> +        return;

>  

>      case 0x20:

> -        return trans_cmpb(ctx, insn, true, false, false);

> +        trans_cmpb(ctx, insn, true, false, false);

> +        return;

>      case 0x21:

> -        return trans_cmpb(ctx, insn, true, true, false);

> +        trans_cmpb(ctx, insn, true, true, false);

> +        return;

>      case 0x22:

> -        return trans_cmpb(ctx, insn, false, false, false);

> +        trans_cmpb(ctx, insn, false, false, false);

> +        return;

>      case 0x23:

> -        return trans_cmpb(ctx, insn, false, true, false);

> +        trans_cmpb(ctx, insn, false, true, false);

> +        return;

>      case 0x24:

> -        return trans_cmpiclr(ctx, insn);

> +        trans_cmpiclr(ctx, insn);

> +        return;

>      case 0x25:

> -        return trans_subi(ctx, insn);

> +        trans_subi(ctx, insn);

> +        return;

>      case 0x26:

> -        return trans_fmpyadd(ctx, insn, true);

> +        trans_fmpyadd(ctx, insn, true);

> +        return;

>      case 0x27:

> -        return trans_cmpb(ctx, insn, true, false, true);

> +        trans_cmpb(ctx, insn, true, false, true);

> +        return;

>      case 0x28:

> -        return trans_addb(ctx, insn, true, false);

> +        trans_addb(ctx, insn, true, false);

> +        return;

>      case 0x29:

> -        return trans_addb(ctx, insn, true, true);

> +        trans_addb(ctx, insn, true, true);

> +        return;

>      case 0x2A:

> -        return trans_addb(ctx, insn, false, false);

> +        trans_addb(ctx, insn, false, false);

> +        return;

>      case 0x2B:

> -        return trans_addb(ctx, insn, false, true);

> +        trans_addb(ctx, insn, false, true);

> +        return;

>      case 0x2C:

>      case 0x2D:

> -        return trans_addi(ctx, insn);

> +        trans_addi(ctx, insn);

> +        return;

>      case 0x2E:

> -        return translate_table(ctx, insn, table_fp_fused);

> +        translate_table(ctx, insn, table_fp_fused);

> +        return;

>      case 0x2F:

> -        return trans_cmpb(ctx, insn, false, false, true);

> +        trans_cmpb(ctx, insn, false, false, true);

> +        return;

>  

>      case 0x30:

>      case 0x31:

> -        return trans_bb(ctx, insn);

> +        trans_bb(ctx, insn);

> +        return;

>      case 0x32:

> -        return trans_movb(ctx, insn, false);

> +        trans_movb(ctx, insn, false);

> +        return;

>      case 0x33:

> -        return trans_movb(ctx, insn, true);

> +        trans_movb(ctx, insn, true);

> +        return;

>      case 0x34:

> -        return translate_table(ctx, insn, table_sh_ex);

> +        translate_table(ctx, insn, table_sh_ex);

> +        return;

>      case 0x35:

> -        return translate_table(ctx, insn, table_depw);

> +        translate_table(ctx, insn, table_depw);

> +        return;

>      case 0x38:

> -        return trans_be(ctx, insn, false);

> +        trans_be(ctx, insn, false);

> +        return;

>      case 0x39:

> -        return trans_be(ctx, insn, true);

> +        trans_be(ctx, insn, true);

> +        return;

>      case 0x3A:

> -        return translate_table(ctx, insn, table_branch);

> +        translate_table(ctx, insn, table_branch);

> +        return;

>  

>      case 0x04: /* spopn */

>      case 0x05: /* diag */

> @@ -4672,17 +4672,19 @@ static DisasJumpType translate_one(DisasContext *ctx, uint32_t insn)

>  #ifndef CONFIG_USER_ONLY

>          /* Unassigned, but use as system-halt.  */

>          if (insn == 0xfffdead0) {

> -            return gen_hlt(ctx, 0); /* halt system */

> +            gen_hlt(ctx, 0); /* halt system */

> +            return;

>          }

>          if (insn == 0xfffdead1) {

> -            return gen_hlt(ctx, 1); /* reset system */

> +            gen_hlt(ctx, 1); /* reset system */

> +            return;

>          }

>  #endif

>          break;

>      default:

>          break;

>      }

> -    return gen_illegal(ctx);

> +    gen_illegal(ctx);

>  }

>  

>  static int hppa_tr_init_disas_context(DisasContextBase *dcbase,

> @@ -4752,7 +4754,7 @@ static bool hppa_tr_breakpoint_check(DisasContextBase *dcbase, CPUState *cs,

>  {

>      DisasContext *ctx = container_of(dcbase, DisasContext, base);

>  

> -    ctx->base.is_jmp = gen_excp(ctx, EXCP_DEBUG);

> +    gen_excp(ctx, EXCP_DEBUG);

>      ctx->base.pc_next += 4;

>      return true;

>  }

> @@ -4767,7 +4769,8 @@ static void hppa_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)

>      /* Execute one insn.  */

>  #ifdef CONFIG_USER_ONLY

>      if (ctx->base.pc_next < TARGET_PAGE_SIZE) {

> -        ret = do_page_zero(ctx);

> +        do_page_zero(ctx);

> +        ret = ctx->base.is_jmp;

>          assert(ret != DISAS_NEXT);

>      } else

>  #endif

> @@ -4792,7 +4795,8 @@ static void hppa_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)

>              ret = DISAS_NEXT;

>          } else {

>              ctx->insn = insn;

> -            ret = translate_one(ctx, insn);

> +            translate_one(ctx, insn);

> +            ret = ctx->base.is_jmp;

>              assert(ctx->null_lab == NULL);

>          }

>      }

> @@ -4818,14 +4822,13 @@ static void hppa_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)

>                  || ctx->null_cond.c == TCG_COND_ALWAYS)) {

>              nullify_set(ctx, ctx->null_cond.c == TCG_COND_ALWAYS);

>              gen_goto_tb(ctx, 0, ctx->iaoq_b, ctx->iaoq_n);

> -            ret = DISAS_NORETURN;

> +            ctx->base.is_jmp = ret = DISAS_NORETURN;

>          } else {

> -            ret = DISAS_IAQ_N_STALE;

> +            ctx->base.is_jmp = ret = DISAS_IAQ_N_STALE;

>          }

>      }

>      ctx->iaoq_f = ctx->iaoq_b;

>      ctx->iaoq_b = ctx->iaoq_n;

> -    ctx->base.is_jmp = ret;

>      ctx->base.pc_next += 4;

>  

>      if (ret == DISAS_NORETURN || ret == DISAS_IAQ_N_UPDATED) {

>
diff mbox series

Patch

diff --git a/target/hppa/translate.c b/target/hppa/translate.c
index 6499b392f9..f72bc84873 100644
--- a/target/hppa/translate.c
+++ b/target/hppa/translate.c
@@ -290,10 +290,6 @@  typedef struct DisasContext {
     bool psw_n_nonzero;
 } DisasContext;
 
-/* Target-specific return values from translate_one, indicating the
-   state of the TB.  Note that DISAS_NEXT indicates that we are not
-   exiting the TB.  */
-
 /* We are not using a goto_tb (for whatever reason), but have updated
    the iaq (for whatever reason), so don't do it again on exit.  */
 #define DISAS_IAQ_N_UPDATED  DISAS_TARGET_0
@@ -308,8 +304,8 @@  typedef struct DisasContext {
 
 typedef struct DisasInsn {
     uint32_t insn, mask;
-    DisasJumpType (*trans)(DisasContext *ctx, uint32_t insn,
-                           const struct DisasInsn *f);
+    void (*trans)(DisasContext *ctx, uint32_t insn,
+                  const struct DisasInsn *f);
     union {
         void (*ttt)(TCGv_reg, TCGv_reg, TCGv_reg);
         void (*weww)(TCGv_i32, TCGv_env, TCGv_i32, TCGv_i32);
@@ -678,9 +674,10 @@  static void nullify_set(DisasContext *ctx, bool x)
 
 /* Mark the end of an instruction that may have been nullified.
    This is the pair to nullify_over.  */
-static DisasJumpType nullify_end(DisasContext *ctx, DisasJumpType status)
+static void nullify_end(DisasContext *ctx)
 {
     TCGLabel *null_lab = ctx->null_lab;
+    DisasJumpType status = ctx->base.is_jmp;
 
     /* For NEXT, NORETURN, STALE, we can easily continue (or exit).
        For UPDATED, we cannot update on the nullified path.  */
@@ -690,7 +687,7 @@  static DisasJumpType nullify_end(DisasContext *ctx, DisasJumpType status)
         /* The current insn wasn't conditional or handled the condition
            applied to it without a branch, so the (new) setting of
            NULL_COND can be applied directly to the next insn.  */
-        return status;
+        return;
     }
     ctx->null_lab = NULL;
 
@@ -708,9 +705,8 @@  static DisasJumpType nullify_end(DisasContext *ctx, DisasJumpType status)
         ctx->null_cond = cond_make_n();
     }
     if (status == DISAS_NORETURN) {
-        status = DISAS_NEXT;
+        ctx->base.is_jmp = DISAS_NEXT;
     }
-    return status;
 }
 
 static void copy_iaoq_entry(TCGv_reg dest, target_ureg ival, TCGv_reg vval)
@@ -734,41 +730,45 @@  static void gen_excp_1(int exception)
     tcg_temp_free_i32(t);
 }
 
-static DisasJumpType gen_excp(DisasContext *ctx, int exception)
+static void gen_excp(DisasContext *ctx, int exception)
 {
     copy_iaoq_entry(cpu_iaoq_f, ctx->iaoq_f, cpu_iaoq_f);
     copy_iaoq_entry(cpu_iaoq_b, ctx->iaoq_b, cpu_iaoq_b);
     nullify_save(ctx);
     gen_excp_1(exception);
-    return DISAS_NORETURN;
+    ctx->base.is_jmp = DISAS_NORETURN;
 }
 
-static DisasJumpType gen_excp_iir(DisasContext *ctx, int exc)
+static void gen_excp_iir(DisasContext *ctx, int exc)
 {
     TCGv_reg tmp = tcg_const_reg(ctx->insn);
     tcg_gen_st_reg(tmp, cpu_env, offsetof(CPUHPPAState, cr[CR_IIR]));
     tcg_temp_free(tmp);
-    return gen_excp(ctx, exc);
+    gen_excp(ctx, exc);
 }
 
-static DisasJumpType gen_illegal(DisasContext *ctx)
+static void gen_illegal(DisasContext *ctx)
 {
     nullify_over(ctx);
-    return nullify_end(ctx, gen_excp_iir(ctx, EXCP_ILL));
+    gen_excp_iir(ctx, EXCP_ILL);
+    nullify_end(ctx);
 }
 
-#define CHECK_MOST_PRIVILEGED(EXCP)                               \
-    do {                                                          \
-        if (ctx->privilege != 0) {                                \
-            nullify_over(ctx);                                    \
-            return nullify_end(ctx, gen_excp_iir(ctx, EXCP));     \
-        }                                                         \
+#define CHECK_MOST_PRIVILEGED(EXCP)      \
+    do {                                 \
+        if (ctx->privilege != 0) {       \
+            nullify_over(ctx);           \
+            gen_excp_iir(ctx, EXCP);     \
+            nullify_end(ctx);            \
+            return;                      \
+        }                                \
     } while (0)
 
 static bool use_goto_tb(DisasContext *ctx, target_ureg dest)
 {
     /* Suppress goto_tb in the case of single-steping and IO.  */
-    if ((tb_cflags(ctx->base.tb) & CF_LAST_IO) || ctx->base.singlestep_enabled) {
+    if ((tb_cflags(ctx->base.tb) & CF_LAST_IO)
+        || ctx->base.singlestep_enabled) {
         return false;
     }
     return true;
@@ -1131,9 +1131,9 @@  static TCGv_reg do_sub_sv(DisasContext *ctx, TCGv_reg res,
     return sv;
 }
 
-static DisasJumpType do_add(DisasContext *ctx, unsigned rt, TCGv_reg in1,
-                            TCGv_reg in2, unsigned shift, bool is_l,
-                            bool is_tsv, bool is_tc, bool is_c, unsigned cf)
+static void do_add(DisasContext *ctx, unsigned rt, TCGv_reg in1,
+                   TCGv_reg in2, unsigned shift, bool is_l,
+                   bool is_tsv, bool is_tc, bool is_c, unsigned cf)
 {
     TCGv_reg dest, cb, cb_msb, sv, tmp;
     unsigned c = cf >> 1;
@@ -1200,12 +1200,11 @@  static DisasJumpType do_add(DisasContext *ctx, unsigned rt, TCGv_reg in1,
     /* Install the new nullification.  */
     cond_free(&ctx->null_cond);
     ctx->null_cond = cond;
-    return DISAS_NEXT;
 }
 
-static DisasJumpType do_sub(DisasContext *ctx, unsigned rt, TCGv_reg in1,
-                            TCGv_reg in2, bool is_tsv, bool is_b,
-                            bool is_tc, unsigned cf)
+static void do_sub(DisasContext *ctx, unsigned rt, TCGv_reg in1,
+                   TCGv_reg in2, bool is_tsv, bool is_b,
+                   bool is_tc, unsigned cf)
 {
     TCGv_reg dest, sv, cb, cb_msb, zero, tmp;
     unsigned c = cf >> 1;
@@ -1267,11 +1266,10 @@  static DisasJumpType do_sub(DisasContext *ctx, unsigned rt, TCGv_reg in1,
     /* Install the new nullification.  */
     cond_free(&ctx->null_cond);
     ctx->null_cond = cond;
-    return DISAS_NEXT;
 }
 
-static DisasJumpType do_cmpclr(DisasContext *ctx, unsigned rt, TCGv_reg in1,
-                               TCGv_reg in2, unsigned cf)
+static void do_cmpclr(DisasContext *ctx, unsigned rt, TCGv_reg in1,
+                      TCGv_reg in2, unsigned cf)
 {
     TCGv_reg dest, sv;
     DisasCond cond;
@@ -1296,12 +1294,11 @@  static DisasJumpType do_cmpclr(DisasContext *ctx, unsigned rt, TCGv_reg in1,
     /* Install the new nullification.  */
     cond_free(&ctx->null_cond);
     ctx->null_cond = cond;
-    return DISAS_NEXT;
 }
 
-static DisasJumpType do_log(DisasContext *ctx, unsigned rt, TCGv_reg in1,
-                            TCGv_reg in2, unsigned cf,
-                            void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))
+static void do_log(DisasContext *ctx, unsigned rt, TCGv_reg in1,
+                   TCGv_reg in2, unsigned cf,
+                   void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))
 {
     TCGv_reg dest = dest_gpr(ctx, rt);
 
@@ -1314,12 +1311,11 @@  static DisasJumpType do_log(DisasContext *ctx, unsigned rt, TCGv_reg in1,
     if (cf) {
         ctx->null_cond = do_log_cond(cf, dest);
     }
-    return DISAS_NEXT;
 }
 
-static DisasJumpType do_unit(DisasContext *ctx, unsigned rt, TCGv_reg in1,
-                             TCGv_reg in2, unsigned cf, bool is_tc,
-                             void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))
+static void do_unit(DisasContext *ctx, unsigned rt, TCGv_reg in1,
+                    TCGv_reg in2, unsigned cf, bool is_tc,
+                    void (*fn)(TCGv_reg, TCGv_reg, TCGv_reg))
 {
     TCGv_reg dest;
     DisasCond cond;
@@ -1347,7 +1343,6 @@  static DisasJumpType do_unit(DisasContext *ctx, unsigned rt, TCGv_reg in1,
         cond_free(&ctx->null_cond);
         ctx->null_cond = cond;
     }
-    return DISAS_NEXT;
 }
 
 #ifndef CONFIG_USER_ONLY
@@ -1510,9 +1505,9 @@  static void do_store_64(DisasContext *ctx, TCGv_i64 src, unsigned rb,
 #define do_store_reg  do_store_32
 #endif
 
-static DisasJumpType do_load(DisasContext *ctx, unsigned rt, unsigned rb,
-                             unsigned rx, int scale, target_sreg disp,
-                             unsigned sp, int modify, TCGMemOp mop)
+static void do_load(DisasContext *ctx, unsigned rt, unsigned rb,
+                    unsigned rx, int scale, target_sreg disp,
+                    unsigned sp, int modify, TCGMemOp mop)
 {
     TCGv_reg dest;
 
@@ -1528,12 +1523,12 @@  static DisasJumpType do_load(DisasContext *ctx, unsigned rt, unsigned rb,
     do_load_reg(ctx, dest, rb, rx, scale, disp, sp, modify, mop);
     save_gpr(ctx, rt, dest);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_floadw(DisasContext *ctx, unsigned rt, unsigned rb,
-                               unsigned rx, int scale, target_sreg disp,
-                               unsigned sp, int modify)
+static void do_floadw(DisasContext *ctx, unsigned rt, unsigned rb,
+                      unsigned rx, int scale, target_sreg disp,
+                      unsigned sp, int modify)
 {
     TCGv_i32 tmp;
 
@@ -1548,12 +1543,12 @@  static DisasJumpType do_floadw(DisasContext *ctx, unsigned rt, unsigned rb,
         gen_helper_loaded_fr0(cpu_env);
     }
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_floadd(DisasContext *ctx, unsigned rt, unsigned rb,
-                               unsigned rx, int scale, target_sreg disp,
-                               unsigned sp, int modify)
+static void do_floadd(DisasContext *ctx, unsigned rt, unsigned rb,
+                      unsigned rx, int scale, target_sreg disp,
+                      unsigned sp, int modify)
 {
     TCGv_i64 tmp;
 
@@ -1568,21 +1563,21 @@  static DisasJumpType do_floadd(DisasContext *ctx, unsigned rt, unsigned rb,
         gen_helper_loaded_fr0(cpu_env);
     }
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_store(DisasContext *ctx, unsigned rt, unsigned rb,
-                              target_sreg disp, unsigned sp,
-                              int modify, TCGMemOp mop)
+static void do_store(DisasContext *ctx, unsigned rt, unsigned rb,
+                     target_sreg disp, unsigned sp,
+                     int modify, TCGMemOp mop)
 {
     nullify_over(ctx);
     do_store_reg(ctx, load_gpr(ctx, rt), rb, 0, 0, disp, sp, modify, mop);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fstorew(DisasContext *ctx, unsigned rt, unsigned rb,
-                                unsigned rx, int scale, target_sreg disp,
-                                unsigned sp, int modify)
+static void do_fstorew(DisasContext *ctx, unsigned rt, unsigned rb,
+                       unsigned rx, int scale, target_sreg disp,
+                       unsigned sp, int modify)
 {
     TCGv_i32 tmp;
 
@@ -1592,12 +1587,12 @@  static DisasJumpType do_fstorew(DisasContext *ctx, unsigned rt, unsigned rb,
     do_store_32(ctx, tmp, rb, rx, scale, disp, sp, modify, MO_TEUL);
     tcg_temp_free_i32(tmp);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fstored(DisasContext *ctx, unsigned rt, unsigned rb,
-                                unsigned rx, int scale, target_sreg disp,
-                                unsigned sp, int modify)
+static void do_fstored(DisasContext *ctx, unsigned rt, unsigned rb,
+                       unsigned rx, int scale, target_sreg disp,
+                       unsigned sp, int modify)
 {
     TCGv_i64 tmp;
 
@@ -1607,11 +1602,11 @@  static DisasJumpType do_fstored(DisasContext *ctx, unsigned rt, unsigned rb,
     do_store_64(ctx, tmp, rb, rx, scale, disp, sp, modify, MO_TEQ);
     tcg_temp_free_i64(tmp);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fop_wew(DisasContext *ctx, unsigned rt, unsigned ra,
-                                void (*func)(TCGv_i32, TCGv_env, TCGv_i32))
+static void do_fop_wew(DisasContext *ctx, unsigned rt, unsigned ra,
+                       void (*func)(TCGv_i32, TCGv_env, TCGv_i32))
 {
     TCGv_i32 tmp;
 
@@ -1622,11 +1617,11 @@  static DisasJumpType do_fop_wew(DisasContext *ctx, unsigned rt, unsigned ra,
 
     save_frw_i32(rt, tmp);
     tcg_temp_free_i32(tmp);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fop_wed(DisasContext *ctx, unsigned rt, unsigned ra,
-                                void (*func)(TCGv_i32, TCGv_env, TCGv_i64))
+static void do_fop_wed(DisasContext *ctx, unsigned rt, unsigned ra,
+                       void (*func)(TCGv_i32, TCGv_env, TCGv_i64))
 {
     TCGv_i32 dst;
     TCGv_i64 src;
@@ -1640,11 +1635,11 @@  static DisasJumpType do_fop_wed(DisasContext *ctx, unsigned rt, unsigned ra,
     tcg_temp_free_i64(src);
     save_frw_i32(rt, dst);
     tcg_temp_free_i32(dst);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fop_ded(DisasContext *ctx, unsigned rt, unsigned ra,
-                                void (*func)(TCGv_i64, TCGv_env, TCGv_i64))
+static void do_fop_ded(DisasContext *ctx, unsigned rt, unsigned ra,
+                       void (*func)(TCGv_i64, TCGv_env, TCGv_i64))
 {
     TCGv_i64 tmp;
 
@@ -1655,11 +1650,11 @@  static DisasJumpType do_fop_ded(DisasContext *ctx, unsigned rt, unsigned ra,
 
     save_frd(rt, tmp);
     tcg_temp_free_i64(tmp);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fop_dew(DisasContext *ctx, unsigned rt, unsigned ra,
-                                void (*func)(TCGv_i64, TCGv_env, TCGv_i32))
+static void do_fop_dew(DisasContext *ctx, unsigned rt, unsigned ra,
+                       void (*func)(TCGv_i64, TCGv_env, TCGv_i32))
 {
     TCGv_i32 src;
     TCGv_i64 dst;
@@ -1673,13 +1668,12 @@  static DisasJumpType do_fop_dew(DisasContext *ctx, unsigned rt, unsigned ra,
     tcg_temp_free_i32(src);
     save_frd(rt, dst);
     tcg_temp_free_i64(dst);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fop_weww(DisasContext *ctx, unsigned rt,
-                                 unsigned ra, unsigned rb,
-                                 void (*func)(TCGv_i32, TCGv_env,
-                                              TCGv_i32, TCGv_i32))
+static void do_fop_weww(DisasContext *ctx, unsigned rt,
+                        unsigned ra, unsigned rb,
+                        void (*func)(TCGv_i32, TCGv_env, TCGv_i32, TCGv_i32))
 {
     TCGv_i32 a, b;
 
@@ -1692,13 +1686,12 @@  static DisasJumpType do_fop_weww(DisasContext *ctx, unsigned rt,
     tcg_temp_free_i32(b);
     save_frw_i32(rt, a);
     tcg_temp_free_i32(a);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType do_fop_dedd(DisasContext *ctx, unsigned rt,
-                                 unsigned ra, unsigned rb,
-                                 void (*func)(TCGv_i64, TCGv_env,
-                                              TCGv_i64, TCGv_i64))
+static void do_fop_dedd(DisasContext *ctx, unsigned rt,
+                        unsigned ra, unsigned rb,
+                        void (*func)(TCGv_i64, TCGv_env, TCGv_i64, TCGv_i64))
 {
     TCGv_i64 a, b;
 
@@ -1711,13 +1704,13 @@  static DisasJumpType do_fop_dedd(DisasContext *ctx, unsigned rt,
     tcg_temp_free_i64(b);
     save_frd(rt, a);
     tcg_temp_free_i64(a);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 /* Emit an unconditional branch to a direct target, which may or may not
    have already had nullification handled.  */
-static DisasJumpType do_dbranch(DisasContext *ctx, target_ureg dest,
-                                unsigned link, bool is_n)
+static void do_dbranch(DisasContext *ctx, target_ureg dest,
+                       unsigned link, bool is_n)
 {
     if (ctx->null_cond.c == TCG_COND_NEVER && ctx->null_lab == NULL) {
         if (link != 0) {
@@ -1727,7 +1720,6 @@  static DisasJumpType do_dbranch(DisasContext *ctx, target_ureg dest,
         if (is_n) {
             ctx->null_cond.c = TCG_COND_ALWAYS;
         }
-        return DISAS_NEXT;
     } else {
         nullify_over(ctx);
 
@@ -1743,18 +1735,18 @@  static DisasJumpType do_dbranch(DisasContext *ctx, target_ureg dest,
             gen_goto_tb(ctx, 0, ctx->iaoq_b, dest);
         }
 
-        nullify_end(ctx, DISAS_NEXT);
+        nullify_end(ctx);
 
         nullify_set(ctx, 0);
         gen_goto_tb(ctx, 1, ctx->iaoq_b, ctx->iaoq_n);
-        return DISAS_NORETURN;
+        ctx->base.is_jmp = DISAS_NORETURN;
     }
 }
 
 /* Emit a conditional branch to a direct target.  If the branch itself
    is nullified, we should have already used nullify_over.  */
-static DisasJumpType do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,
-                                DisasCond *cond)
+static void do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,
+                       DisasCond *cond)
 {
     target_ureg dest = iaoq_dest(ctx, disp);
     TCGLabel *taken = NULL;
@@ -1765,10 +1757,12 @@  static DisasJumpType do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,
 
     /* Handle TRUE and NEVER as direct branches.  */
     if (c == TCG_COND_ALWAYS) {
-        return do_dbranch(ctx, dest, 0, is_n && disp >= 0);
+        do_dbranch(ctx, dest, 0, is_n && disp >= 0);
+        return;
     }
     if (c == TCG_COND_NEVER) {
-        return do_dbranch(ctx, ctx->iaoq_n, 0, is_n && disp < 0);
+        do_dbranch(ctx, ctx->iaoq_n, 0, is_n && disp < 0);
+        return;
     }
 
     taken = gen_new_label();
@@ -1811,16 +1805,16 @@  static DisasJumpType do_cbranch(DisasContext *ctx, target_sreg disp, bool is_n,
     if (ctx->null_lab) {
         gen_set_label(ctx->null_lab);
         ctx->null_lab = NULL;
-        return DISAS_IAQ_N_STALE;
+        ctx->base.is_jmp = DISAS_IAQ_N_STALE;
     } else {
-        return DISAS_NORETURN;
+        ctx->base.is_jmp = DISAS_NORETURN;
     }
 }
 
 /* Emit an unconditional branch to an indirect target.  This handles
    nullification of the branch itself.  */
-static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,
-                                unsigned link, bool is_n)
+static void do_ibranch(DisasContext *ctx, TCGv_reg dest,
+                       unsigned link, bool is_n)
 {
     TCGv_reg a0, a1, next, tmp;
     TCGCond c;
@@ -1838,7 +1832,8 @@  static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,
                 tcg_gen_mov_reg(cpu_iaoq_f, next);
                 tcg_gen_addi_reg(cpu_iaoq_b, next, 4);
                 nullify_set(ctx, 0);
-                return DISAS_IAQ_N_UPDATED;
+                ctx->base.is_jmp = DISAS_IAQ_N_UPDATED;
+                return;
             }
             ctx->null_cond.c = TCG_COND_ALWAYS;
         }
@@ -1865,7 +1860,7 @@  static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,
             tcg_gen_movi_reg(cpu_gr[link], ctx->iaoq_n);
         }
         tcg_gen_lookup_and_goto_ptr();
-        return nullify_end(ctx, DISAS_NEXT);
+        nullify_end(ctx);
     } else {
         cond_prep(&ctx->null_cond);
         c = ctx->null_cond.c;
@@ -1896,8 +1891,6 @@  static DisasJumpType do_ibranch(DisasContext *ctx, TCGv_reg dest,
             cond_free(&ctx->null_cond);
         }
     }
-
-    return DISAS_NEXT;
 }
 
 /* Implement
@@ -1942,7 +1935,7 @@  static TCGv_reg do_ibranch_priv(DisasContext *ctx, TCGv_reg offset)
    in than the "be disp(sr2,r0)" instruction that probably sent us
    here, is the easiest way to handle the branch delay slot on the
    aforementioned BE.  */
-static DisasJumpType do_page_zero(DisasContext *ctx)
+static void do_page_zero(DisasContext *ctx)
 {
     /* If by some means we get here with PSW[N]=1, that implies that
        the B,GATE instruction would be skipped, and we'd fault on the
@@ -1970,56 +1963,56 @@  static DisasJumpType do_page_zero(DisasContext *ctx)
     switch (ctx->iaoq_f) {
     case 0x00: /* Null pointer call */
         gen_excp_1(EXCP_IMP);
-        return DISAS_NORETURN;
+        ctx->base.is_jmp = DISAS_NORETURN;
+        break;
 
     case 0xb0: /* LWS */
         gen_excp_1(EXCP_SYSCALL_LWS);
-        return DISAS_NORETURN;
+        ctx->base.is_jmp = DISAS_NORETURN;
+        break;
 
     case 0xe0: /* SET_THREAD_POINTER */
         tcg_gen_st_reg(cpu_gr[26], cpu_env, offsetof(CPUHPPAState, cr[27]));
         tcg_gen_mov_reg(cpu_iaoq_f, cpu_gr[31]);
         tcg_gen_addi_reg(cpu_iaoq_b, cpu_iaoq_f, 4);
-        return DISAS_IAQ_N_UPDATED;
+        ctx->base.is_jmp = DISAS_IAQ_N_UPDATED;
+        break;
 
     case 0x100: /* SYSCALL */
         gen_excp_1(EXCP_SYSCALL);
-        return DISAS_NORETURN;
+        ctx->base.is_jmp = DISAS_NORETURN;
+        break;
 
     default:
     do_sigill:
         gen_excp_1(EXCP_ILL);
-        return DISAS_NORETURN;
+        ctx->base.is_jmp = DISAS_NORETURN;
+        break;
     }
 }
 #endif
 
-static DisasJumpType trans_nop(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_nop(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_break(DisasContext *ctx, uint32_t insn,
-                                 const DisasInsn *di)
+static void trans_break(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     nullify_over(ctx);
-    return nullify_end(ctx, gen_excp_iir(ctx, EXCP_BREAK));
+    gen_excp_iir(ctx, EXCP_BREAK);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_sync(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_sync(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     /* No point in nullifying the memory barrier.  */
     tcg_gen_mb(TCG_BAR_SC | TCG_MO_ALL);
 
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_mfia(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_mfia(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     TCGv_reg tmp = dest_gpr(ctx, rt);
@@ -2027,11 +2020,9 @@  static DisasJumpType trans_mfia(DisasContext *ctx, uint32_t insn,
     save_gpr(ctx, rt, tmp);
 
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_mfsp(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_mfsp(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned rs = assemble_sr3(insn);
@@ -2047,16 +2038,13 @@  static DisasJumpType trans_mfsp(DisasContext *ctx, uint32_t insn,
     tcg_temp_free_i64(t0);
 
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,
-                                 const DisasInsn *di)
+static void trans_mfctl(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned ctl = extract32(insn, 21, 5);
     TCGv_reg tmp;
-    DisasJumpType ret;
 
     switch (ctl) {
     case CR_SAR:
@@ -2079,13 +2067,13 @@  static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,
             gen_io_start();
             gen_helper_read_interval_timer(tmp);
             gen_io_end();
-            ret = DISAS_IAQ_N_STALE;
+            ctx->base.is_jmp = DISAS_IAQ_N_STALE;
         } else {
             gen_helper_read_interval_timer(tmp);
-            ret = DISAS_NEXT;
         }
         save_gpr(ctx, rt, tmp);
-        return nullify_end(ctx, ret);
+        nullify_end(ctx);
+        return;
     case 26:
     case 27:
         break;
@@ -2101,11 +2089,9 @@  static DisasJumpType trans_mfctl(DisasContext *ctx, uint32_t insn,
 
  done:
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_mtsp(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_mtsp(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rr = extract32(insn, 16, 5);
     unsigned rs = assemble_sr3(insn);
@@ -2128,11 +2114,10 @@  static DisasJumpType trans_mtsp(DisasContext *ctx, uint32_t insn,
     }
     tcg_temp_free_i64(t64);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,
-                                 const DisasInsn *di)
+static void trans_mtctl(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rin = extract32(insn, 16, 5);
     unsigned ctl = extract32(insn, 21, 5);
@@ -2146,7 +2131,7 @@  static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,
         tcg_temp_free(tmp);
 
         cond_free(&ctx->null_cond);
-        return DISAS_NEXT;
+        return;
     }
 
     /* All other control registers are privileged or read-only.  */
@@ -2155,8 +2140,6 @@  static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,
 #ifdef CONFIG_USER_ONLY
     g_assert_not_reached();
 #else
-    DisasJumpType ret = DISAS_NEXT;
-
     nullify_over(ctx);
     switch (ctl) {
     case CR_IT:
@@ -2167,7 +2150,7 @@  static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,
         break;
     case CR_EIEM:
         gen_helper_write_eiem(cpu_env, reg);
-        ret = DISAS_IAQ_N_STALE_EXIT;
+        ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;
         break;
 
     case CR_IIASQ:
@@ -2186,12 +2169,11 @@  static DisasJumpType trans_mtctl(DisasContext *ctx, uint32_t insn,
         tcg_gen_st_reg(reg, cpu_env, offsetof(CPUHPPAState, cr[ctl]));
         break;
     }
-    return nullify_end(ctx, ret);
+    nullify_end(ctx);
 #endif
 }
 
-static DisasJumpType trans_mtsarcm(DisasContext *ctx, uint32_t insn,
-                                   const DisasInsn *di)
+static void trans_mtsarcm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rin = extract32(insn, 16, 5);
     TCGv_reg tmp = tcg_temp_new();
@@ -2202,11 +2184,9 @@  static DisasJumpType trans_mtsarcm(DisasContext *ctx, uint32_t insn,
     tcg_temp_free(tmp);
 
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_ldsid(DisasContext *ctx, uint32_t insn,
-                                 const DisasInsn *di)
+static void trans_ldsid(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     TCGv_reg dest = dest_gpr(ctx, rt);
@@ -2228,7 +2208,6 @@  static DisasJumpType trans_ldsid(DisasContext *ctx, uint32_t insn,
     save_gpr(ctx, rt, dest);
 
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
 #ifndef CONFIG_USER_ONLY
@@ -2246,8 +2225,7 @@  static target_ureg extract_sm_imm(uint32_t insn)
     return val;
 }
 
-static DisasJumpType trans_rsm(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_rsm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     target_ureg sm = extract_sm_imm(insn);
@@ -2263,11 +2241,11 @@  static DisasJumpType trans_rsm(DisasContext *ctx, uint32_t insn,
     save_gpr(ctx, rt, tmp);
 
     /* Exit the TB to recognize new interrupts, e.g. PSW_M.  */
-    return nullify_end(ctx, DISAS_IAQ_N_STALE_EXIT);
+    ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_ssm(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_ssm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     target_ureg sm = extract_sm_imm(insn);
@@ -2283,11 +2261,11 @@  static DisasJumpType trans_ssm(DisasContext *ctx, uint32_t insn,
     save_gpr(ctx, rt, tmp);
 
     /* Exit the TB to recognize new interrupts, e.g. PSW_I.  */
-    return nullify_end(ctx, DISAS_IAQ_N_STALE_EXIT);
+    ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_mtsm(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_mtsm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rr = extract32(insn, 16, 5);
     TCGv_reg tmp, reg;
@@ -2300,11 +2278,11 @@  static DisasJumpType trans_mtsm(DisasContext *ctx, uint32_t insn,
     gen_helper_swap_system_mask(tmp, cpu_env, reg);
 
     /* Exit the TB to recognize new interrupts.  */
-    return nullify_end(ctx, DISAS_IAQ_N_STALE_EXIT);
+    ctx->base.is_jmp = DISAS_IAQ_N_STALE_EXIT;
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_rfi(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_rfi(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned comp = extract32(insn, 5, 4);
 
@@ -2316,17 +2294,18 @@  static DisasJumpType trans_rfi(DisasContext *ctx, uint32_t insn,
     } else {
         gen_helper_rfi(cpu_env);
     }
+    /* Exit the TB to recognize new interrupts.  */
     if (ctx->base.singlestep_enabled) {
         gen_excp_1(EXCP_DEBUG);
     } else {
         tcg_gen_exit_tb(0);
     }
+    ctx->base.is_jmp = DISAS_NORETURN;
 
-    /* Exit the TB to recognize new interrupts.  */
-    return nullify_end(ctx, DISAS_NORETURN);
+    nullify_end(ctx);
 }
 
-static DisasJumpType gen_hlt(DisasContext *ctx, int reset)
+static void gen_hlt(DisasContext *ctx, int reset)
 {
     CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);
     nullify_over(ctx);
@@ -2335,7 +2314,8 @@  static DisasJumpType gen_hlt(DisasContext *ctx, int reset)
     } else {
         gen_helper_halt(cpu_env);
     }
-    return nullify_end(ctx, DISAS_NORETURN);
+    ctx->base.is_jmp = DISAS_NORETURN;
+    nullify_end(ctx);
 }
 #endif /* !CONFIG_USER_ONLY */
 
@@ -2358,8 +2338,8 @@  static const DisasInsn table_system[] = {
 #endif
 };
 
-static DisasJumpType trans_base_idx_mod(DisasContext *ctx, uint32_t insn,
-                                        const DisasInsn *di)
+static void trans_base_idx_mod(DisasContext *ctx, uint32_t insn,
+                               const DisasInsn *di)
 {
     unsigned rb = extract32(insn, 21, 5);
     unsigned rx = extract32(insn, 16, 5);
@@ -2372,11 +2352,9 @@  static DisasJumpType trans_base_idx_mod(DisasContext *ctx, uint32_t insn,
     save_gpr(ctx, rb, dest);
 
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_probe(DisasContext *ctx, uint32_t insn,
-                                 const DisasInsn *di)
+static void trans_probe(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned sp = extract32(insn, 14, 2);
@@ -2408,12 +2386,11 @@  static DisasJumpType trans_probe(DisasContext *ctx, uint32_t insn,
     tcg_temp_free_i32(level);
 
     save_gpr(ctx, rt, dest);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 #ifndef CONFIG_USER_ONLY
-static DisasJumpType trans_ixtlbx(DisasContext *ctx, uint32_t insn,
-                                  const DisasInsn *di)
+static void trans_ixtlbx(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned sp;
     unsigned rr = extract32(insn, 16, 5);
@@ -2442,12 +2419,13 @@  static DisasJumpType trans_ixtlbx(DisasContext *ctx, uint32_t insn,
 
     /* Exit TB for ITLB change if mmu is enabled.  This *should* not be
        the case, since the OS TLB fill handler runs with mmu disabled.  */
-    return nullify_end(ctx, !is_data && (ctx->tb_flags & PSW_C)
-                       ? DISAS_IAQ_N_STALE : DISAS_NEXT);
+    if (!is_data && (ctx->tb_flags & PSW_C)) {
+        ctx->base.is_jmp = DISAS_IAQ_N_STALE;
+    }
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_pxtlbx(DisasContext *ctx, uint32_t insn,
-                                  const DisasInsn *di)
+static void trans_pxtlbx(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned m = extract32(insn, 5, 1);
     unsigned sp;
@@ -2478,12 +2456,13 @@  static DisasJumpType trans_pxtlbx(DisasContext *ctx, uint32_t insn,
     }
 
     /* Exit TB for TLB change if mmu is enabled.  */
-    return nullify_end(ctx, !is_data && (ctx->tb_flags & PSW_C)
-                       ? DISAS_IAQ_N_STALE : DISAS_NEXT);
+    if (!is_data && (ctx->tb_flags & PSW_C)) {
+        ctx->base.is_jmp = DISAS_IAQ_N_STALE;
+    }
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_lpa(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_lpa(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -2508,11 +2487,10 @@  static DisasJumpType trans_lpa(DisasContext *ctx, uint32_t insn,
     save_gpr(ctx, rt, paddr);
     tcg_temp_free(paddr);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_lci(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_lci(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     TCGv_reg ci;
@@ -2527,7 +2505,7 @@  static DisasJumpType trans_lci(DisasContext *ctx, uint32_t insn,
     save_gpr(ctx, rt, ci);
     tcg_temp_free(ci);
 
-    return DISAS_NEXT;
+    cond_free(&ctx->null_cond);
 }
 #endif /* !CONFIG_USER_ONLY */
 
@@ -2561,8 +2539,7 @@  static const DisasInsn table_mem_mgmt[] = {
 #endif
 };
 
-static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_add(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned r1 = extract32(insn, 16, 5);
@@ -2575,7 +2552,6 @@  static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,
     bool is_l = false;
     bool is_tc = false;
     bool is_tsv = false;
-    DisasJumpType ret;
 
     switch (ext) {
     case 0x6: /* ADD, SHLADD */
@@ -2593,7 +2569,8 @@  static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,
         is_c = is_tsv = true;
         break;
     default:
-        return gen_illegal(ctx);
+        gen_illegal(ctx);
+        return;
     }
 
     if (cf) {
@@ -2601,12 +2578,11 @@  static DisasJumpType trans_add(DisasContext *ctx, uint32_t insn,
     }
     tcg_r1 = load_gpr(ctx, r1);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_add(ctx, rt, tcg_r1, tcg_r2, shift, is_l, is_tsv, is_tc, is_c, cf);
-    return nullify_end(ctx, ret);
+    do_add(ctx, rt, tcg_r1, tcg_r2, shift, is_l, is_tsv, is_tc, is_c, cf);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_sub(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_sub(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned r1 = extract32(insn, 16, 5);
@@ -2617,7 +2593,6 @@  static DisasJumpType trans_sub(DisasContext *ctx, uint32_t insn,
     bool is_b = false;
     bool is_tc = false;
     bool is_tsv = false;
-    DisasJumpType ret;
 
     switch (ext) {
     case 0x10: /* SUB */
@@ -2646,32 +2621,29 @@  static DisasJumpType trans_sub(DisasContext *ctx, uint32_t insn,
     }
     tcg_r1 = load_gpr(ctx, r1);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_sub(ctx, rt, tcg_r1, tcg_r2, is_tsv, is_b, is_tc, cf);
-    return nullify_end(ctx, ret);
+    do_sub(ctx, rt, tcg_r1, tcg_r2, is_tsv, is_b, is_tc, cf);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_log(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_log(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned r1 = extract32(insn, 16, 5);
     unsigned cf = extract32(insn, 12, 4);
     unsigned rt = extract32(insn,  0, 5);
     TCGv_reg tcg_r1, tcg_r2;
-    DisasJumpType ret;
 
     if (cf) {
         nullify_over(ctx);
     }
     tcg_r1 = load_gpr(ctx, r1);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_log(ctx, rt, tcg_r1, tcg_r2, cf, di->f.ttt);
-    return nullify_end(ctx, ret);
+    do_log(ctx, rt, tcg_r1, tcg_r2, cf, di->f.ttt);
+    nullify_end(ctx);
 }
 
 /* OR r,0,t -> COPY (according to gas) */
-static DisasJumpType trans_copy(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_copy(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r1 = extract32(insn, 16, 5);
     unsigned rt = extract32(insn,  0, 5);
@@ -2684,49 +2656,43 @@  static DisasJumpType trans_copy(DisasContext *ctx, uint32_t insn,
         save_gpr(ctx, rt, cpu_gr[r1]);
     }
     cond_free(&ctx->null_cond);
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_cmpclr(DisasContext *ctx, uint32_t insn,
-                                  const DisasInsn *di)
+static void trans_cmpclr(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned r1 = extract32(insn, 16, 5);
     unsigned cf = extract32(insn, 12, 4);
     unsigned rt = extract32(insn,  0, 5);
     TCGv_reg tcg_r1, tcg_r2;
-    DisasJumpType ret;
 
     if (cf) {
         nullify_over(ctx);
     }
     tcg_r1 = load_gpr(ctx, r1);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_cmpclr(ctx, rt, tcg_r1, tcg_r2, cf);
-    return nullify_end(ctx, ret);
+    do_cmpclr(ctx, rt, tcg_r1, tcg_r2, cf);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_uxor(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_uxor(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned r1 = extract32(insn, 16, 5);
     unsigned cf = extract32(insn, 12, 4);
     unsigned rt = extract32(insn,  0, 5);
     TCGv_reg tcg_r1, tcg_r2;
-    DisasJumpType ret;
 
     if (cf) {
         nullify_over(ctx);
     }
     tcg_r1 = load_gpr(ctx, r1);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_unit(ctx, rt, tcg_r1, tcg_r2, cf, false, tcg_gen_xor_reg);
-    return nullify_end(ctx, ret);
+    do_unit(ctx, rt, tcg_r1, tcg_r2, cf, false, tcg_gen_xor_reg);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_uaddcm(DisasContext *ctx, uint32_t insn,
-                                  const DisasInsn *di)
+static void trans_uaddcm(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned r1 = extract32(insn, 16, 5);
@@ -2734,7 +2700,6 @@  static DisasJumpType trans_uaddcm(DisasContext *ctx, uint32_t insn,
     unsigned is_tc = extract32(insn, 6, 1);
     unsigned rt = extract32(insn,  0, 5);
     TCGv_reg tcg_r1, tcg_r2, tmp;
-    DisasJumpType ret;
 
     if (cf) {
         nullify_over(ctx);
@@ -2743,19 +2708,17 @@  static DisasJumpType trans_uaddcm(DisasContext *ctx, uint32_t insn,
     tcg_r2 = load_gpr(ctx, r2);
     tmp = get_temp(ctx);
     tcg_gen_not_reg(tmp, tcg_r2);
-    ret = do_unit(ctx, rt, tcg_r1, tmp, cf, is_tc, tcg_gen_add_reg);
-    return nullify_end(ctx, ret);
+    do_unit(ctx, rt, tcg_r1, tmp, cf, is_tc, tcg_gen_add_reg);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_dcor(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_dcor(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned cf = extract32(insn, 12, 4);
     unsigned is_i = extract32(insn, 6, 1);
     unsigned rt = extract32(insn,  0, 5);
     TCGv_reg tmp;
-    DisasJumpType ret;
 
     nullify_over(ctx);
 
@@ -2766,14 +2729,13 @@  static DisasJumpType trans_dcor(DisasContext *ctx, uint32_t insn,
     }
     tcg_gen_andi_reg(tmp, tmp, 0x11111111);
     tcg_gen_muli_reg(tmp, tmp, 6);
-    ret = do_unit(ctx, rt, tmp, load_gpr(ctx, r2), cf, false,
-                  is_i ? tcg_gen_add_reg : tcg_gen_sub_reg);
+    do_unit(ctx, rt, tmp, load_gpr(ctx, r2), cf, false,
+            is_i ? tcg_gen_add_reg : tcg_gen_sub_reg);
 
-    return nullify_end(ctx, ret);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_ds(DisasContext *ctx, uint32_t insn,
-                              const DisasInsn *di)
+static void trans_ds(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned r2 = extract32(insn, 21, 5);
     unsigned r1 = extract32(insn, 16, 5);
@@ -2835,7 +2797,7 @@  static DisasJumpType trans_ds(DisasContext *ctx, uint32_t insn,
     tcg_temp_free(add2);
     tcg_temp_free(dest);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 #ifndef CONFIG_USER_ONLY
@@ -2845,8 +2807,7 @@  static DisasJumpType trans_ds(DisasContext *ctx, uint32_t insn,
  * or %r31,%r31,%r31 -- death loop; offline cpu
  *                      currently implemented as idle.
  */
-static DisasJumpType trans_pause(DisasContext *ctx, uint32_t insn,
-                                 const DisasInsn *di)
+static void trans_pause(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     TCGv_i32 tmp;
 
@@ -2865,8 +2826,9 @@  static DisasJumpType trans_pause(DisasContext *ctx, uint32_t insn,
                                  offsetof(CPUState, halted));
     tcg_temp_free_i32(tmp);
     gen_excp_1(EXCP_HALTED);
+    ctx->base.is_jmp = DISAS_NORETURN;
 
-    return nullify_end(ctx, DISAS_NORETURN);
+    nullify_end(ctx);
 }
 #endif
 
@@ -2892,7 +2854,7 @@  static const DisasInsn table_arith_log[] = {
     { 0x08000200u, 0xfc000320u, trans_add }, /* shladd */
 };
 
-static DisasJumpType trans_addi(DisasContext *ctx, uint32_t insn)
+static void trans_addi(DisasContext *ctx, uint32_t insn)
 {
     target_sreg im = low_sextract(insn, 0, 11);
     unsigned e1 = extract32(insn, 11, 1);
@@ -2901,7 +2863,6 @@  static DisasJumpType trans_addi(DisasContext *ctx, uint32_t insn)
     unsigned r2 = extract32(insn, 21, 5);
     unsigned o1 = extract32(insn, 26, 1);
     TCGv_reg tcg_im, tcg_r2;
-    DisasJumpType ret;
 
     if (cf) {
         nullify_over(ctx);
@@ -2909,12 +2870,12 @@  static DisasJumpType trans_addi(DisasContext *ctx, uint32_t insn)
 
     tcg_im = load_const(ctx, im);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_add(ctx, rt, tcg_im, tcg_r2, 0, false, e1, !o1, false, cf);
+    do_add(ctx, rt, tcg_im, tcg_r2, 0, false, e1, !o1, false, cf);
 
-    return nullify_end(ctx, ret);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_subi(DisasContext *ctx, uint32_t insn)
+static void trans_subi(DisasContext *ctx, uint32_t insn)
 {
     target_sreg im = low_sextract(insn, 0, 11);
     unsigned e1 = extract32(insn, 11, 1);
@@ -2922,7 +2883,6 @@  static DisasJumpType trans_subi(DisasContext *ctx, uint32_t insn)
     unsigned rt = extract32(insn, 16, 5);
     unsigned r2 = extract32(insn, 21, 5);
     TCGv_reg tcg_im, tcg_r2;
-    DisasJumpType ret;
 
     if (cf) {
         nullify_over(ctx);
@@ -2930,19 +2890,18 @@  static DisasJumpType trans_subi(DisasContext *ctx, uint32_t insn)
 
     tcg_im = load_const(ctx, im);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_sub(ctx, rt, tcg_im, tcg_r2, e1, false, false, cf);
+    do_sub(ctx, rt, tcg_im, tcg_r2, e1, false, false, cf);
 
-    return nullify_end(ctx, ret);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_cmpiclr(DisasContext *ctx, uint32_t insn)
+static void trans_cmpiclr(DisasContext *ctx, uint32_t insn)
 {
     target_sreg im = low_sextract(insn, 0, 11);
     unsigned cf = extract32(insn, 12, 4);
     unsigned rt = extract32(insn, 16, 5);
     unsigned r2 = extract32(insn, 21, 5);
     TCGv_reg tcg_im, tcg_r2;
-    DisasJumpType ret;
 
     if (cf) {
         nullify_over(ctx);
@@ -2950,13 +2909,13 @@  static DisasJumpType trans_cmpiclr(DisasContext *ctx, uint32_t insn)
 
     tcg_im = load_const(ctx, im);
     tcg_r2 = load_gpr(ctx, r2);
-    ret = do_cmpclr(ctx, rt, tcg_im, tcg_r2, cf);
+    do_cmpclr(ctx, rt, tcg_im, tcg_r2, cf);
 
-    return nullify_end(ctx, ret);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_ld_idx_i(DisasContext *ctx, uint32_t insn,
-                                    const DisasInsn *di)
+static void trans_ld_idx_i(DisasContext *ctx, uint32_t insn,
+                           const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -2968,11 +2927,11 @@  static DisasJumpType trans_ld_idx_i(DisasContext *ctx, uint32_t insn,
     int modify = (m ? (a ? -1 : 1) : 0);
     TCGMemOp mop = MO_TE | sz;
 
-    return do_load(ctx, rt, rb, 0, 0, disp, sp, modify, mop);
+    do_load(ctx, rt, rb, 0, 0, disp, sp, modify, mop);
 }
 
-static DisasJumpType trans_ld_idx_x(DisasContext *ctx, uint32_t insn,
-                                    const DisasInsn *di)
+static void trans_ld_idx_x(DisasContext *ctx, uint32_t insn,
+                           const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -2983,11 +2942,11 @@  static DisasJumpType trans_ld_idx_x(DisasContext *ctx, uint32_t insn,
     unsigned rb = extract32(insn, 21, 5);
     TCGMemOp mop = MO_TE | sz;
 
-    return do_load(ctx, rt, rb, rx, u ? sz : 0, 0, sp, m, mop);
+    do_load(ctx, rt, rb, rx, u ? sz : 0, 0, sp, m, mop);
 }
 
-static DisasJumpType trans_st_idx_i(DisasContext *ctx, uint32_t insn,
-                                    const DisasInsn *di)
+static void trans_st_idx_i(DisasContext *ctx, uint32_t insn,
+                           const DisasInsn *di)
 {
     int disp = low_sextract(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -2999,11 +2958,10 @@  static DisasJumpType trans_st_idx_i(DisasContext *ctx, uint32_t insn,
     int modify = (m ? (a ? -1 : 1) : 0);
     TCGMemOp mop = MO_TE | sz;
 
-    return do_store(ctx, rr, rb, disp, sp, modify, mop);
+    do_store(ctx, rr, rb, disp, sp, modify, mop);
 }
 
-static DisasJumpType trans_ldcw(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_ldcw(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -3046,11 +3004,10 @@  static DisasJumpType trans_ldcw(DisasContext *ctx, uint32_t insn,
     }
     save_gpr(ctx, rt, dest);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_stby(DisasContext *ctx, uint32_t insn,
-                                const DisasInsn *di)
+static void trans_stby(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     target_sreg disp = low_sextract(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -3085,56 +3042,50 @@  static DisasJumpType trans_stby(DisasContext *ctx, uint32_t insn,
         save_gpr(ctx, rb, ofs);
     }
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 #ifndef CONFIG_USER_ONLY
-static DisasJumpType trans_ldwa_idx_i(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_ldwa_idx_i(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     int hold_mmu_idx = ctx->mmu_idx;
-    DisasJumpType ret;
 
     CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);
 
     /* ??? needs fixing for hppa64 -- ldda does not follow the same
        format wrt the sub-opcode in bits 6:9.  */
     ctx->mmu_idx = MMU_PHYS_IDX;
-    ret = trans_ld_idx_i(ctx, insn, di);
+    trans_ld_idx_i(ctx, insn, di);
     ctx->mmu_idx = hold_mmu_idx;
-    return ret;
 }
 
-static DisasJumpType trans_ldwa_idx_x(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_ldwa_idx_x(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     int hold_mmu_idx = ctx->mmu_idx;
-    DisasJumpType ret;
 
     CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);
 
     /* ??? needs fixing for hppa64 -- ldda does not follow the same
        format wrt the sub-opcode in bits 6:9.  */
     ctx->mmu_idx = MMU_PHYS_IDX;
-    ret = trans_ld_idx_x(ctx, insn, di);
+    trans_ld_idx_x(ctx, insn, di);
     ctx->mmu_idx = hold_mmu_idx;
-    return ret;
 }
 
-static DisasJumpType trans_stwa_idx_i(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_stwa_idx_i(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     int hold_mmu_idx = ctx->mmu_idx;
-    DisasJumpType ret;
 
     CHECK_MOST_PRIVILEGED(EXCP_PRIV_OPR);
 
     /* ??? needs fixing for hppa64 -- ldda does not follow the same
        format wrt the sub-opcode in bits 6:9.  */
     ctx->mmu_idx = MMU_PHYS_IDX;
-    ret = trans_st_idx_i(ctx, insn, di);
+    trans_st_idx_i(ctx, insn, di);
     ctx->mmu_idx = hold_mmu_idx;
-    return ret;
 }
 #endif
 
@@ -3151,7 +3102,7 @@  static const DisasInsn table_index_mem[] = {
 #endif
 };
 
-static DisasJumpType trans_ldil(DisasContext *ctx, uint32_t insn)
+static void trans_ldil(DisasContext *ctx, uint32_t insn)
 {
     unsigned rt = extract32(insn, 21, 5);
     target_sreg i = assemble_21(insn);
@@ -3160,11 +3111,9 @@  static DisasJumpType trans_ldil(DisasContext *ctx, uint32_t insn)
     tcg_gen_movi_reg(tcg_rt, i);
     save_gpr(ctx, rt, tcg_rt);
     cond_free(&ctx->null_cond);
-
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_addil(DisasContext *ctx, uint32_t insn)
+static void trans_addil(DisasContext *ctx, uint32_t insn)
 {
     unsigned rt = extract32(insn, 21, 5);
     target_sreg i = assemble_21(insn);
@@ -3174,11 +3123,9 @@  static DisasJumpType trans_addil(DisasContext *ctx, uint32_t insn)
     tcg_gen_addi_reg(tcg_r1, tcg_rt, i);
     save_gpr(ctx, 1, tcg_r1);
     cond_free(&ctx->null_cond);
-
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_ldo(DisasContext *ctx, uint32_t insn)
+static void trans_ldo(DisasContext *ctx, uint32_t insn)
 {
     unsigned rb = extract32(insn, 21, 5);
     unsigned rt = extract32(insn, 16, 5);
@@ -3194,23 +3141,20 @@  static DisasJumpType trans_ldo(DisasContext *ctx, uint32_t insn)
     }
     save_gpr(ctx, rt, tcg_rt);
     cond_free(&ctx->null_cond);
-
-    return DISAS_NEXT;
 }
 
-static DisasJumpType trans_load(DisasContext *ctx, uint32_t insn,
-                                bool is_mod, TCGMemOp mop)
+static void trans_load(DisasContext *ctx, uint32_t insn,
+                       bool is_mod, TCGMemOp mop)
 {
     unsigned rb = extract32(insn, 21, 5);
     unsigned rt = extract32(insn, 16, 5);
     unsigned sp = extract32(insn, 14, 2);
     target_sreg i = assemble_16(insn);
 
-    return do_load(ctx, rt, rb, 0, 0, i, sp,
-                   is_mod ? (i < 0 ? -1 : 1) : 0, mop);
+    do_load(ctx, rt, rb, 0, 0, i, sp, is_mod ? (i < 0 ? -1 : 1) : 0, mop);
 }
 
-static DisasJumpType trans_load_w(DisasContext *ctx, uint32_t insn)
+static void trans_load_w(DisasContext *ctx, uint32_t insn)
 {
     unsigned rb = extract32(insn, 21, 5);
     unsigned rt = extract32(insn, 16, 5);
@@ -3222,17 +3166,20 @@  static DisasJumpType trans_load_w(DisasContext *ctx, uint32_t insn)
     case 0:
     case 1:
         /* FLDW without modification.  */
-        return do_floadw(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);
+        do_floadw(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);
+        break;
     case 2:
         /* LDW with modification.  Note that the sign of I selects
            post-dec vs pre-inc.  */
-        return do_load(ctx, rt, rb, 0, 0, i, sp, (i < 0 ? 1 : -1), MO_TEUL);
+        do_load(ctx, rt, rb, 0, 0, i, sp, (i < 0 ? 1 : -1), MO_TEUL);
+        break;
     default:
-        return gen_illegal(ctx);
+        gen_illegal(ctx);
+        break;
     }
 }
 
-static DisasJumpType trans_fload_mod(DisasContext *ctx, uint32_t insn)
+static void trans_fload_mod(DisasContext *ctx, uint32_t insn)
 {
     target_sreg i = assemble_16a(insn);
     unsigned t1 = extract32(insn, 1, 1);
@@ -3242,21 +3189,21 @@  static DisasJumpType trans_fload_mod(DisasContext *ctx, uint32_t insn)
     unsigned rb = extract32(insn, 21, 5);
 
     /* FLDW with modification.  */
-    return do_floadw(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));
+    do_floadw(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));
 }
 
-static DisasJumpType trans_store(DisasContext *ctx, uint32_t insn,
-                                 bool is_mod, TCGMemOp mop)
+static void trans_store(DisasContext *ctx, uint32_t insn,
+                        bool is_mod, TCGMemOp mop)
 {
     unsigned rb = extract32(insn, 21, 5);
     unsigned rt = extract32(insn, 16, 5);
     unsigned sp = extract32(insn, 14, 2);
     target_sreg i = assemble_16(insn);
 
-    return do_store(ctx, rt, rb, i, sp, is_mod ? (i < 0 ? -1 : 1) : 0, mop);
+    do_store(ctx, rt, rb, i, sp, is_mod ? (i < 0 ? -1 : 1) : 0, mop);
 }
 
-static DisasJumpType trans_store_w(DisasContext *ctx, uint32_t insn)
+static void trans_store_w(DisasContext *ctx, uint32_t insn)
 {
     unsigned rb = extract32(insn, 21, 5);
     unsigned rt = extract32(insn, 16, 5);
@@ -3268,16 +3215,19 @@  static DisasJumpType trans_store_w(DisasContext *ctx, uint32_t insn)
     case 0:
     case 1:
         /* FSTW without modification.  */
-        return do_fstorew(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);
+        do_fstorew(ctx, ext2 * 32 + rt, rb, 0, 0, i, sp, 0);
+        break;
     case 2:
         /* STW with modification.  */
-        return do_store(ctx, rt, rb, i, sp, (i < 0 ? 1 : -1), MO_TEUL);
+        do_store(ctx, rt, rb, i, sp, (i < 0 ? 1 : -1), MO_TEUL);
+        break;
     default:
-        return gen_illegal(ctx);
+        gen_illegal(ctx);
+        break;
     }
 }
 
-static DisasJumpType trans_fstore_mod(DisasContext *ctx, uint32_t insn)
+static void trans_fstore_mod(DisasContext *ctx, uint32_t insn)
 {
     target_sreg i = assemble_16a(insn);
     unsigned t1 = extract32(insn, 1, 1);
@@ -3287,10 +3237,10 @@  static DisasJumpType trans_fstore_mod(DisasContext *ctx, uint32_t insn)
     unsigned rb = extract32(insn, 21, 5);
 
     /* FSTW with modification.  */
-    return do_fstorew(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));
+    do_fstorew(ctx, t1 * 32 + t0, rb, 0, 0, i, sp, (a ? -1 : 1));
 }
 
-static DisasJumpType trans_copr_w(DisasContext *ctx, uint32_t insn)
+static void trans_copr_w(DisasContext *ctx, uint32_t insn)
 {
     unsigned t0 = extract32(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -3319,14 +3269,18 @@  static DisasJumpType trans_copr_w(DisasContext *ctx, uint32_t insn)
 
     switch (ext3) {
     case 0: /* FLDW */
-        return do_floadw(ctx, rt, rb, rx, scale, disp, sp, modify);
+        do_floadw(ctx, rt, rb, rx, scale, disp, sp, modify);
+        break;
     case 4: /* FSTW */
-        return do_fstorew(ctx, rt, rb, rx, scale, disp, sp, modify);
+        do_fstorew(ctx, rt, rb, rx, scale, disp, sp, modify);
+        break;
+    default:
+        gen_illegal(ctx);
+        break;
     }
-    return gen_illegal(ctx);
 }
 
-static DisasJumpType trans_copr_dw(DisasContext *ctx, uint32_t insn)
+static void trans_copr_dw(DisasContext *ctx, uint32_t insn)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned m = extract32(insn, 5, 1);
@@ -3353,16 +3307,19 @@  static DisasJumpType trans_copr_dw(DisasContext *ctx, uint32_t insn)
 
     switch (ext4) {
     case 0: /* FLDD */
-        return do_floadd(ctx, rt, rb, rx, scale, disp, sp, modify);
+        do_floadd(ctx, rt, rb, rx, scale, disp, sp, modify);
+        break;
     case 8: /* FSTD */
-        return do_fstored(ctx, rt, rb, rx, scale, disp, sp, modify);
+        do_fstored(ctx, rt, rb, rx, scale, disp, sp, modify);
+        break;
     default:
-        return gen_illegal(ctx);
+        gen_illegal(ctx);
+        break;
     }
 }
 
-static DisasJumpType trans_cmpb(DisasContext *ctx, uint32_t insn,
-                                bool is_true, bool is_imm, bool is_dw)
+static void trans_cmpb(DisasContext *ctx, uint32_t insn,
+                       bool is_true, bool is_imm, bool is_dw)
 {
     target_sreg disp = assemble_12(insn) * 4;
     unsigned n = extract32(insn, 1, 1);
@@ -3390,11 +3347,11 @@  static DisasJumpType trans_cmpb(DisasContext *ctx, uint32_t insn,
     }
 
     cond = do_sub_cond(cf, dest, in1, in2, sv);
-    return do_cbranch(ctx, disp, n, &cond);
+    do_cbranch(ctx, disp, n, &cond);
 }
 
-static DisasJumpType trans_addb(DisasContext *ctx, uint32_t insn,
-                                bool is_true, bool is_imm)
+static void trans_addb(DisasContext *ctx, uint32_t insn,
+                       bool is_true, bool is_imm)
 {
     target_sreg disp = assemble_12(insn) * 4;
     unsigned n = extract32(insn, 1, 1);
@@ -3432,10 +3389,10 @@  static DisasJumpType trans_addb(DisasContext *ctx, uint32_t insn,
     }
 
     cond = do_cond(cf, dest, cb_msb, sv);
-    return do_cbranch(ctx, disp, n, &cond);
+    do_cbranch(ctx, disp, n, &cond);
 }
 
-static DisasJumpType trans_bb(DisasContext *ctx, uint32_t insn)
+static void trans_bb(DisasContext *ctx, uint32_t insn)
 {
     target_sreg disp = assemble_12(insn) * 4;
     unsigned n = extract32(insn, 1, 1);
@@ -3458,10 +3415,10 @@  static DisasJumpType trans_bb(DisasContext *ctx, uint32_t insn)
 
     cond = cond_make_0(c ? TCG_COND_GE : TCG_COND_LT, tmp);
     tcg_temp_free(tmp);
-    return do_cbranch(ctx, disp, n, &cond);
+    do_cbranch(ctx, disp, n, &cond);
 }
 
-static DisasJumpType trans_movb(DisasContext *ctx, uint32_t insn, bool is_imm)
+static void trans_movb(DisasContext *ctx, uint32_t insn, bool is_imm)
 {
     target_sreg disp = assemble_12(insn) * 4;
     unsigned n = extract32(insn, 1, 1);
@@ -3483,11 +3440,11 @@  static DisasJumpType trans_movb(DisasContext *ctx, uint32_t insn, bool is_imm)
     }
 
     cond = do_sed_cond(c, dest);
-    return do_cbranch(ctx, disp, n, &cond);
+    do_cbranch(ctx, disp, n, &cond);
 }
 
-static DisasJumpType trans_shrpw_sar(DisasContext *ctx, uint32_t insn,
-                                    const DisasInsn *di)
+static void trans_shrpw_sar(DisasContext *ctx, uint32_t insn,
+                            const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned c = extract32(insn, 13, 3);
@@ -3528,11 +3485,11 @@  static DisasJumpType trans_shrpw_sar(DisasContext *ctx, uint32_t insn,
     if (c) {
         ctx->null_cond = do_sed_cond(c, dest);
     }
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_shrpw_imm(DisasContext *ctx, uint32_t insn,
-                                     const DisasInsn *di)
+static void trans_shrpw_imm(DisasContext *ctx, uint32_t insn,
+                            const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned cpos = extract32(insn, 5, 5);
@@ -3569,11 +3526,11 @@  static DisasJumpType trans_shrpw_imm(DisasContext *ctx, uint32_t insn,
     if (c) {
         ctx->null_cond = do_sed_cond(c, dest);
     }
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_extrw_sar(DisasContext *ctx, uint32_t insn,
-                                     const DisasInsn *di)
+static void trans_extrw_sar(DisasContext *ctx, uint32_t insn,
+                            const DisasInsn *di)
 {
     unsigned clen = extract32(insn, 0, 5);
     unsigned is_se = extract32(insn, 10, 1);
@@ -3608,11 +3565,11 @@  static DisasJumpType trans_extrw_sar(DisasContext *ctx, uint32_t insn,
     if (c) {
         ctx->null_cond = do_sed_cond(c, dest);
     }
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_extrw_imm(DisasContext *ctx, uint32_t insn,
-                                     const DisasInsn *di)
+static void trans_extrw_imm(DisasContext *ctx, uint32_t insn,
+                            const DisasInsn *di)
 {
     unsigned clen = extract32(insn, 0, 5);
     unsigned pos = extract32(insn, 5, 5);
@@ -3642,7 +3599,7 @@  static DisasJumpType trans_extrw_imm(DisasContext *ctx, uint32_t insn,
     if (c) {
         ctx->null_cond = do_sed_cond(c, dest);
     }
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 static const DisasInsn table_sh_ex[] = {
@@ -3652,8 +3609,8 @@  static const DisasInsn table_sh_ex[] = {
     { 0xd0001800u, 0xfc001800u, trans_extrw_imm },
 };
 
-static DisasJumpType trans_depw_imm_c(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_depw_imm_c(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned clen = extract32(insn, 0, 5);
     unsigned cpos = extract32(insn, 5, 5);
@@ -3693,11 +3650,11 @@  static DisasJumpType trans_depw_imm_c(DisasContext *ctx, uint32_t insn,
     if (c) {
         ctx->null_cond = do_sed_cond(c, dest);
     }
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_depw_imm(DisasContext *ctx, uint32_t insn,
-                                    const DisasInsn *di)
+static void trans_depw_imm(DisasContext *ctx, uint32_t insn,
+                           const DisasInsn *di)
 {
     unsigned clen = extract32(insn, 0, 5);
     unsigned cpos = extract32(insn, 5, 5);
@@ -3730,11 +3687,11 @@  static DisasJumpType trans_depw_imm(DisasContext *ctx, uint32_t insn,
     if (c) {
         ctx->null_cond = do_sed_cond(c, dest);
     }
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_depw_sar(DisasContext *ctx, uint32_t insn,
-                                    const DisasInsn *di)
+static void trans_depw_sar(DisasContext *ctx, uint32_t insn,
+                           const DisasInsn *di)
 {
     unsigned clen = extract32(insn, 0, 5);
     unsigned nz = extract32(insn, 10, 1);
@@ -3782,7 +3739,7 @@  static DisasJumpType trans_depw_sar(DisasContext *ctx, uint32_t insn,
     if (c) {
         ctx->null_cond = do_sed_cond(c, dest);
     }
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 static const DisasInsn table_depw[] = {
@@ -3791,7 +3748,7 @@  static const DisasInsn table_depw[] = {
     { 0xd4001800u, 0xfc001800u, trans_depw_imm_c },
 };
 
-static DisasJumpType trans_be(DisasContext *ctx, uint32_t insn, bool is_l)
+static void trans_be(DisasContext *ctx, uint32_t insn, bool is_l)
 {
     unsigned n = extract32(insn, 1, 1);
     unsigned b = extract32(insn, 21, 5);
@@ -3820,7 +3777,7 @@  static DisasJumpType trans_be(DisasContext *ctx, uint32_t insn, bool is_l)
     tmp = do_ibranch_priv(ctx, tmp);
 
 #ifdef CONFIG_USER_ONLY
-    return do_ibranch(ctx, tmp, is_l ? 31 : 0, n);
+    do_ibranch(ctx, tmp, is_l ? 31 : 0, n);
 #else
     TCGv_i64 new_spc = tcg_temp_new_i64();
 
@@ -3845,22 +3802,21 @@  static DisasJumpType trans_be(DisasContext *ctx, uint32_t insn, bool is_l)
     }
     tcg_temp_free_i64(new_spc);
     tcg_gen_lookup_and_goto_ptr();
-    return nullify_end(ctx, DISAS_NORETURN);
+    ctx->base.is_jmp = DISAS_NORETURN;
+    nullify_end(ctx);
 #endif
 }
 
-static DisasJumpType trans_bl(DisasContext *ctx, uint32_t insn,
-                              const DisasInsn *di)
+static void trans_bl(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned n = extract32(insn, 1, 1);
     unsigned link = extract32(insn, 21, 5);
     target_sreg disp = assemble_17(insn);
 
-    return do_dbranch(ctx, iaoq_dest(ctx, disp), link, n);
+    do_dbranch(ctx, iaoq_dest(ctx, disp), link, n);
 }
 
-static DisasJumpType trans_b_gate(DisasContext *ctx, uint32_t insn,
-                                  const DisasInsn *di)
+static void trans_b_gate(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned n = extract32(insn, 1, 1);
     unsigned link = extract32(insn, 21, 5);
@@ -3879,7 +3835,8 @@  static DisasJumpType trans_b_gate(DisasContext *ctx, uint32_t insn,
      * in which instructions at evil would run with increased privs.
      */
     if (ctx->iaoq_b == -1 || ctx->iaoq_b != ctx->iaoq_f + 4) {
-        return gen_illegal(ctx);
+        gen_illegal(ctx);
+        return;
     }
 
 #ifndef CONFIG_USER_ONLY
@@ -3903,20 +3860,18 @@  static DisasJumpType trans_b_gate(DisasContext *ctx, uint32_t insn,
     }
 #endif
 
-    return do_dbranch(ctx, dest, link, n);
+    do_dbranch(ctx, dest, link, n);
 }
 
-static DisasJumpType trans_bl_long(DisasContext *ctx, uint32_t insn,
-                                   const DisasInsn *di)
+static void trans_bl_long(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned n = extract32(insn, 1, 1);
     target_sreg disp = assemble_22(insn);
 
-    return do_dbranch(ctx, iaoq_dest(ctx, disp), 2, n);
+    do_dbranch(ctx, iaoq_dest(ctx, disp), 2, n);
 }
 
-static DisasJumpType trans_blr(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_blr(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned n = extract32(insn, 1, 1);
     unsigned rx = extract32(insn, 16, 5);
@@ -3926,11 +3881,10 @@  static DisasJumpType trans_blr(DisasContext *ctx, uint32_t insn,
     tcg_gen_shli_reg(tmp, load_gpr(ctx, rx), 3);
     tcg_gen_addi_reg(tmp, tmp, ctx->iaoq_f + 8);
     /* The computation here never changes privilege level.  */
-    return do_ibranch(ctx, tmp, link, n);
+    do_ibranch(ctx, tmp, link, n);
 }
 
-static DisasJumpType trans_bv(DisasContext *ctx, uint32_t insn,
-                              const DisasInsn *di)
+static void trans_bv(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned n = extract32(insn, 1, 1);
     unsigned rx = extract32(insn, 16, 5);
@@ -3945,11 +3899,10 @@  static DisasJumpType trans_bv(DisasContext *ctx, uint32_t insn,
         tcg_gen_add_reg(dest, dest, load_gpr(ctx, rb));
     }
     dest = do_ibranch_priv(ctx, dest);
-    return do_ibranch(ctx, dest, 0, n);
+    do_ibranch(ctx, dest, 0, n);
 }
 
-static DisasJumpType trans_bve(DisasContext *ctx, uint32_t insn,
-                               const DisasInsn *di)
+static void trans_bve(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned n = extract32(insn, 1, 1);
     unsigned rb = extract32(insn, 21, 5);
@@ -3958,7 +3911,7 @@  static DisasJumpType trans_bve(DisasContext *ctx, uint32_t insn,
 
 #ifdef CONFIG_USER_ONLY
     dest = do_ibranch_priv(ctx, load_gpr(ctx, rb));
-    return do_ibranch(ctx, dest, link, n);
+    do_ibranch(ctx, dest, link, n);
 #else
     nullify_over(ctx);
     dest = do_ibranch_priv(ctx, load_gpr(ctx, rb));
@@ -3974,7 +3927,8 @@  static DisasJumpType trans_bve(DisasContext *ctx, uint32_t insn,
     }
     nullify_set(ctx, n);
     tcg_gen_lookup_and_goto_ptr();
-    return nullify_end(ctx, DISAS_NORETURN);
+    ctx->base.is_jmp = DISAS_NORETURN;
+    nullify_end(ctx);
 #endif
 }
 
@@ -3987,87 +3941,87 @@  static const DisasInsn table_branch[] = {
     { 0xe8002000u, 0xfc00e000u, trans_b_gate },
 };
 
-static DisasJumpType trans_fop_wew_0c(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fop_wew_0c(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fop_wew(ctx, rt, ra, di->f.wew);
+    do_fop_wew(ctx, rt, ra, di->f.wew);
 }
 
-static DisasJumpType trans_fop_wew_0e(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fop_wew_0e(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = assemble_rt64(insn);
     unsigned ra = assemble_ra64(insn);
-    return do_fop_wew(ctx, rt, ra, di->f.wew);
+    do_fop_wew(ctx, rt, ra, di->f.wew);
 }
 
-static DisasJumpType trans_fop_ded(DisasContext *ctx, uint32_t insn,
-                                   const DisasInsn *di)
+static void trans_fop_ded(DisasContext *ctx, uint32_t insn,
+                          const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fop_ded(ctx, rt, ra, di->f.ded);
+    do_fop_ded(ctx, rt, ra, di->f.ded);
 }
 
-static DisasJumpType trans_fop_wed_0c(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fop_wed_0c(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fop_wed(ctx, rt, ra, di->f.wed);
+    do_fop_wed(ctx, rt, ra, di->f.wed);
 }
 
-static DisasJumpType trans_fop_wed_0e(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fop_wed_0e(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = assemble_rt64(insn);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fop_wed(ctx, rt, ra, di->f.wed);
+    do_fop_wed(ctx, rt, ra, di->f.wed);
 }
 
-static DisasJumpType trans_fop_dew_0c(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fop_dew_0c(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fop_dew(ctx, rt, ra, di->f.dew);
+    do_fop_dew(ctx, rt, ra, di->f.dew);
 }
 
-static DisasJumpType trans_fop_dew_0e(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fop_dew_0e(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned ra = assemble_ra64(insn);
-    return do_fop_dew(ctx, rt, ra, di->f.dew);
+    do_fop_dew(ctx, rt, ra, di->f.dew);
 }
 
-static DisasJumpType trans_fop_weww_0c(DisasContext *ctx, uint32_t insn,
-                                       const DisasInsn *di)
+static void trans_fop_weww_0c(DisasContext *ctx, uint32_t insn,
+                              const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned rb = extract32(insn, 16, 5);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fop_weww(ctx, rt, ra, rb, di->f.weww);
+    do_fop_weww(ctx, rt, ra, rb, di->f.weww);
 }
 
-static DisasJumpType trans_fop_weww_0e(DisasContext *ctx, uint32_t insn,
-                                       const DisasInsn *di)
+static void trans_fop_weww_0e(DisasContext *ctx, uint32_t insn,
+                              const DisasInsn *di)
 {
     unsigned rt = assemble_rt64(insn);
     unsigned rb = assemble_rb64(insn);
     unsigned ra = assemble_ra64(insn);
-    return do_fop_weww(ctx, rt, ra, rb, di->f.weww);
+    do_fop_weww(ctx, rt, ra, rb, di->f.weww);
 }
 
-static DisasJumpType trans_fop_dedd(DisasContext *ctx, uint32_t insn,
-                                    const DisasInsn *di)
+static void trans_fop_dedd(DisasContext *ctx, uint32_t insn,
+                           const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned rb = extract32(insn, 16, 5);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fop_dedd(ctx, rt, ra, rb, di->f.dedd);
+    do_fop_dedd(ctx, rt, ra, rb, di->f.dedd);
 }
 
 static void gen_fcpy_s(TCGv_i32 dst, TCGv_env unused, TCGv_i32 src)
@@ -4110,8 +4064,8 @@  static void gen_fnegabs_d(TCGv_i64 dst, TCGv_env unused, TCGv_i64 src)
     tcg_gen_ori_i64(dst, src, INT64_MIN);
 }
 
-static DisasJumpType do_fcmp_s(DisasContext *ctx, unsigned ra, unsigned rb,
-                               unsigned y, unsigned c)
+static void do_fcmp_s(DisasContext *ctx, unsigned ra, unsigned rb,
+                      unsigned y, unsigned c)
 {
     TCGv_i32 ta, tb, tc, ty;
 
@@ -4129,31 +4083,30 @@  static DisasJumpType do_fcmp_s(DisasContext *ctx, unsigned ra, unsigned rb,
     tcg_temp_free_i32(ty);
     tcg_temp_free_i32(tc);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_fcmp_s_0c(DisasContext *ctx, uint32_t insn,
-                                     const DisasInsn *di)
+static void trans_fcmp_s_0c(DisasContext *ctx, uint32_t insn,
+                            const DisasInsn *di)
 {
     unsigned c = extract32(insn, 0, 5);
     unsigned y = extract32(insn, 13, 3);
     unsigned rb = extract32(insn, 16, 5);
     unsigned ra = extract32(insn, 21, 5);
-    return do_fcmp_s(ctx, ra, rb, y, c);
+    do_fcmp_s(ctx, ra, rb, y, c);
 }
 
-static DisasJumpType trans_fcmp_s_0e(DisasContext *ctx, uint32_t insn,
-                                     const DisasInsn *di)
+static void trans_fcmp_s_0e(DisasContext *ctx, uint32_t insn,
+                            const DisasInsn *di)
 {
     unsigned c = extract32(insn, 0, 5);
     unsigned y = extract32(insn, 13, 3);
     unsigned rb = assemble_rb64(insn);
     unsigned ra = assemble_ra64(insn);
-    return do_fcmp_s(ctx, ra, rb, y, c);
+    do_fcmp_s(ctx, ra, rb, y, c);
 }
 
-static DisasJumpType trans_fcmp_d(DisasContext *ctx, uint32_t insn,
-                                  const DisasInsn *di)
+static void trans_fcmp_d(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned c = extract32(insn, 0, 5);
     unsigned y = extract32(insn, 13, 3);
@@ -4176,11 +4129,11 @@  static DisasJumpType trans_fcmp_d(DisasContext *ctx, uint32_t insn,
     tcg_temp_free_i32(ty);
     tcg_temp_free_i32(tc);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_ftest_t(DisasContext *ctx, uint32_t insn,
-                                   const DisasInsn *di)
+static void trans_ftest_t(DisasContext *ctx, uint32_t insn,
+                          const DisasInsn *di)
 {
     unsigned y = extract32(insn, 13, 3);
     unsigned cbit = (y ^ 1) - 1;
@@ -4194,11 +4147,11 @@  static DisasJumpType trans_ftest_t(DisasContext *ctx, uint32_t insn,
     ctx->null_cond = cond_make_0(TCG_COND_NE, t);
     tcg_temp_free(t);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_ftest_q(DisasContext *ctx, uint32_t insn,
-                                   const DisasInsn *di)
+static void trans_ftest_q(DisasContext *ctx, uint32_t insn,
+                          const DisasInsn *di)
 {
     unsigned c = extract32(insn, 0, 5);
     int mask;
@@ -4237,7 +4190,8 @@  static DisasJumpType trans_ftest_q(DisasContext *ctx, uint32_t insn,
         mask = 0x4200000;
         break;
     default:
-        return gen_illegal(ctx);
+        gen_illegal(ctx);
+        return;
     }
     if (inv) {
         TCGv_reg c = load_const(ctx, mask);
@@ -4248,11 +4202,10 @@  static DisasJumpType trans_ftest_q(DisasContext *ctx, uint32_t insn,
         ctx->null_cond = cond_make_0(TCG_COND_EQ, t);
     }
  done:
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_xmpyu(DisasContext *ctx, uint32_t insn,
-                                 const DisasInsn *di)
+static void trans_xmpyu(DisasContext *ctx, uint32_t insn, const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned rb = assemble_rb64(insn);
@@ -4268,7 +4221,7 @@  static DisasJumpType trans_xmpyu(DisasContext *ctx, uint32_t insn,
     tcg_temp_free_i64(a);
     tcg_temp_free_i64(b);
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 #define FOP_DED  trans_fop_ded, .f.ded
@@ -4443,8 +4396,7 @@  static inline int fmpyadd_s_reg(unsigned r)
     return (r & 16) * 2 + 16 + (r & 15);
 }
 
-static DisasJumpType trans_fmpyadd(DisasContext *ctx,
-                                   uint32_t insn, bool is_sub)
+static void trans_fmpyadd(DisasContext *ctx, uint32_t insn, bool is_sub)
 {
     unsigned tm = extract32(insn, 0, 5);
     unsigned f = extract32(insn, 5, 1);
@@ -4472,11 +4424,11 @@  static DisasJumpType trans_fmpyadd(DisasContext *ctx,
                     is_sub ? gen_helper_fsub_d : gen_helper_fadd_d);
     }
 
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_fmpyfadd_s(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fmpyfadd_s(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = assemble_rt64(insn);
     unsigned neg = extract32(insn, 5, 1);
@@ -4500,11 +4452,11 @@  static DisasJumpType trans_fmpyfadd_s(DisasContext *ctx, uint32_t insn,
     tcg_temp_free_i32(c);
     save_frw_i32(rt, a);
     tcg_temp_free_i32(a);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
-static DisasJumpType trans_fmpyfadd_d(DisasContext *ctx, uint32_t insn,
-                                      const DisasInsn *di)
+static void trans_fmpyfadd_d(DisasContext *ctx, uint32_t insn,
+                             const DisasInsn *di)
 {
     unsigned rt = extract32(insn, 0, 5);
     unsigned neg = extract32(insn, 5, 1);
@@ -4528,7 +4480,7 @@  static DisasJumpType trans_fmpyfadd_d(DisasContext *ctx, uint32_t insn,
     tcg_temp_free_i64(c);
     save_frd(rt, a);
     tcg_temp_free_i64(a);
-    return nullify_end(ctx, DISAS_NEXT);
+    nullify_end(ctx);
 }
 
 static const DisasInsn table_fp_fused[] = {
@@ -4536,127 +4488,175 @@  static const DisasInsn table_fp_fused[] = {
     { 0xb8000800u, 0xfc0019c0u, trans_fmpyfadd_d }
 };
 
-static DisasJumpType translate_table_int(DisasContext *ctx, uint32_t insn,
-                                         const DisasInsn table[], size_t n)
+static void translate_table_int(DisasContext *ctx, uint32_t insn,
+                                const DisasInsn table[], size_t n)
 {
     size_t i;
     for (i = 0; i < n; ++i) {
         if ((insn & table[i].mask) == table[i].insn) {
-            return table[i].trans(ctx, insn, &table[i]);
+            table[i].trans(ctx, insn, &table[i]);
+            return;
         }
     }
     qemu_log_mask(LOG_UNIMP, "UNIMP insn %08x @ " TARGET_FMT_lx "\n",
                   insn, ctx->base.pc_next);
-    return gen_illegal(ctx);
+    gen_illegal(ctx);
 }
 
 #define translate_table(ctx, insn, table) \
     translate_table_int(ctx, insn, table, ARRAY_SIZE(table))
 
-static DisasJumpType translate_one(DisasContext *ctx, uint32_t insn)
+static void translate_one(DisasContext *ctx, uint32_t insn)
 {
     uint32_t opc = extract32(insn, 26, 6);
 
     switch (opc) {
     case 0x00: /* system op */
-        return translate_table(ctx, insn, table_system);
+        translate_table(ctx, insn, table_system);
+        return;
     case 0x01:
-        return translate_table(ctx, insn, table_mem_mgmt);
+        translate_table(ctx, insn, table_mem_mgmt);
+        return;
     case 0x02:
-        return translate_table(ctx, insn, table_arith_log);
+        translate_table(ctx, insn, table_arith_log);
+        return;
     case 0x03:
-        return translate_table(ctx, insn, table_index_mem);
+        translate_table(ctx, insn, table_index_mem);
+        return;
     case 0x06:
-        return trans_fmpyadd(ctx, insn, false);
+        trans_fmpyadd(ctx, insn, false);
+        return;
     case 0x08:
-        return trans_ldil(ctx, insn);
+        trans_ldil(ctx, insn);
+        return;
     case 0x09:
-        return trans_copr_w(ctx, insn);
+        trans_copr_w(ctx, insn);
+        return;
     case 0x0A:
-        return trans_addil(ctx, insn);
+        trans_addil(ctx, insn);
+        return;
     case 0x0B:
-        return trans_copr_dw(ctx, insn);
+        trans_copr_dw(ctx, insn);
+        return;
     case 0x0C:
-        return translate_table(ctx, insn, table_float_0c);
+        translate_table(ctx, insn, table_float_0c);
+        return;
     case 0x0D:
-        return trans_ldo(ctx, insn);
+        trans_ldo(ctx, insn);
+        return;
     case 0x0E:
-        return translate_table(ctx, insn, table_float_0e);
+        translate_table(ctx, insn, table_float_0e);
+        return;
 
     case 0x10:
-        return trans_load(ctx, insn, false, MO_UB);
+        trans_load(ctx, insn, false, MO_UB);
+        return;
     case 0x11:
-        return trans_load(ctx, insn, false, MO_TEUW);
+        trans_load(ctx, insn, false, MO_TEUW);
+        return;
     case 0x12:
-        return trans_load(ctx, insn, false, MO_TEUL);
+        trans_load(ctx, insn, false, MO_TEUL);
+        return;
     case 0x13:
-        return trans_load(ctx, insn, true, MO_TEUL);
+        trans_load(ctx, insn, true, MO_TEUL);
+        return;
     case 0x16:
-        return trans_fload_mod(ctx, insn);
+        trans_fload_mod(ctx, insn);
+        return;
     case 0x17:
-        return trans_load_w(ctx, insn);
+        trans_load_w(ctx, insn);
+        return;
     case 0x18:
-        return trans_store(ctx, insn, false, MO_UB);
+        trans_store(ctx, insn, false, MO_UB);
+        return;
     case 0x19:
-        return trans_store(ctx, insn, false, MO_TEUW);
+        trans_store(ctx, insn, false, MO_TEUW);
+        return;
     case 0x1A:
-        return trans_store(ctx, insn, false, MO_TEUL);
+        trans_store(ctx, insn, false, MO_TEUL);
+        return;
     case 0x1B:
-        return trans_store(ctx, insn, true, MO_TEUL);
+        trans_store(ctx, insn, true, MO_TEUL);
+        return;
     case 0x1E:
-        return trans_fstore_mod(ctx, insn);
+        trans_fstore_mod(ctx, insn);
+        return;
     case 0x1F:
-        return trans_store_w(ctx, insn);
+        trans_store_w(ctx, insn);
+        return;
 
     case 0x20:
-        return trans_cmpb(ctx, insn, true, false, false);
+        trans_cmpb(ctx, insn, true, false, false);
+        return;
     case 0x21:
-        return trans_cmpb(ctx, insn, true, true, false);
+        trans_cmpb(ctx, insn, true, true, false);
+        return;
     case 0x22:
-        return trans_cmpb(ctx, insn, false, false, false);
+        trans_cmpb(ctx, insn, false, false, false);
+        return;
     case 0x23:
-        return trans_cmpb(ctx, insn, false, true, false);
+        trans_cmpb(ctx, insn, false, true, false);
+        return;
     case 0x24:
-        return trans_cmpiclr(ctx, insn);
+        trans_cmpiclr(ctx, insn);
+        return;
     case 0x25:
-        return trans_subi(ctx, insn);
+        trans_subi(ctx, insn);
+        return;
     case 0x26:
-        return trans_fmpyadd(ctx, insn, true);
+        trans_fmpyadd(ctx, insn, true);
+        return;
     case 0x27:
-        return trans_cmpb(ctx, insn, true, false, true);
+        trans_cmpb(ctx, insn, true, false, true);
+        return;
     case 0x28:
-        return trans_addb(ctx, insn, true, false);
+        trans_addb(ctx, insn, true, false);
+        return;
     case 0x29:
-        return trans_addb(ctx, insn, true, true);
+        trans_addb(ctx, insn, true, true);
+        return;
     case 0x2A:
-        return trans_addb(ctx, insn, false, false);
+        trans_addb(ctx, insn, false, false);
+        return;
     case 0x2B:
-        return trans_addb(ctx, insn, false, true);
+        trans_addb(ctx, insn, false, true);
+        return;
     case 0x2C:
     case 0x2D:
-        return trans_addi(ctx, insn);
+        trans_addi(ctx, insn);
+        return;
     case 0x2E:
-        return translate_table(ctx, insn, table_fp_fused);
+        translate_table(ctx, insn, table_fp_fused);
+        return;
     case 0x2F:
-        return trans_cmpb(ctx, insn, false, false, true);
+        trans_cmpb(ctx, insn, false, false, true);
+        return;
 
     case 0x30:
     case 0x31:
-        return trans_bb(ctx, insn);
+        trans_bb(ctx, insn);
+        return;
     case 0x32:
-        return trans_movb(ctx, insn, false);
+        trans_movb(ctx, insn, false);
+        return;
     case 0x33:
-        return trans_movb(ctx, insn, true);
+        trans_movb(ctx, insn, true);
+        return;
     case 0x34:
-        return translate_table(ctx, insn, table_sh_ex);
+        translate_table(ctx, insn, table_sh_ex);
+        return;
     case 0x35:
-        return translate_table(ctx, insn, table_depw);
+        translate_table(ctx, insn, table_depw);
+        return;
     case 0x38:
-        return trans_be(ctx, insn, false);
+        trans_be(ctx, insn, false);
+        return;
     case 0x39:
-        return trans_be(ctx, insn, true);
+        trans_be(ctx, insn, true);
+        return;
     case 0x3A:
-        return translate_table(ctx, insn, table_branch);
+        translate_table(ctx, insn, table_branch);
+        return;
 
     case 0x04: /* spopn */
     case 0x05: /* diag */
@@ -4672,17 +4672,19 @@  static DisasJumpType translate_one(DisasContext *ctx, uint32_t insn)
 #ifndef CONFIG_USER_ONLY
         /* Unassigned, but use as system-halt.  */
         if (insn == 0xfffdead0) {
-            return gen_hlt(ctx, 0); /* halt system */
+            gen_hlt(ctx, 0); /* halt system */
+            return;
         }
         if (insn == 0xfffdead1) {
-            return gen_hlt(ctx, 1); /* reset system */
+            gen_hlt(ctx, 1); /* reset system */
+            return;
         }
 #endif
         break;
     default:
         break;
     }
-    return gen_illegal(ctx);
+    gen_illegal(ctx);
 }
 
 static int hppa_tr_init_disas_context(DisasContextBase *dcbase,
@@ -4752,7 +4754,7 @@  static bool hppa_tr_breakpoint_check(DisasContextBase *dcbase, CPUState *cs,
 {
     DisasContext *ctx = container_of(dcbase, DisasContext, base);
 
-    ctx->base.is_jmp = gen_excp(ctx, EXCP_DEBUG);
+    gen_excp(ctx, EXCP_DEBUG);
     ctx->base.pc_next += 4;
     return true;
 }
@@ -4767,7 +4769,8 @@  static void hppa_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)
     /* Execute one insn.  */
 #ifdef CONFIG_USER_ONLY
     if (ctx->base.pc_next < TARGET_PAGE_SIZE) {
-        ret = do_page_zero(ctx);
+        do_page_zero(ctx);
+        ret = ctx->base.is_jmp;
         assert(ret != DISAS_NEXT);
     } else
 #endif
@@ -4792,7 +4795,8 @@  static void hppa_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)
             ret = DISAS_NEXT;
         } else {
             ctx->insn = insn;
-            ret = translate_one(ctx, insn);
+            translate_one(ctx, insn);
+            ret = ctx->base.is_jmp;
             assert(ctx->null_lab == NULL);
         }
     }
@@ -4818,14 +4822,13 @@  static void hppa_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)
                 || ctx->null_cond.c == TCG_COND_ALWAYS)) {
             nullify_set(ctx, ctx->null_cond.c == TCG_COND_ALWAYS);
             gen_goto_tb(ctx, 0, ctx->iaoq_b, ctx->iaoq_n);
-            ret = DISAS_NORETURN;
+            ctx->base.is_jmp = ret = DISAS_NORETURN;
         } else {
-            ret = DISAS_IAQ_N_STALE;
+            ctx->base.is_jmp = ret = DISAS_IAQ_N_STALE;
         }
     }
     ctx->iaoq_f = ctx->iaoq_b;
     ctx->iaoq_b = ctx->iaoq_n;
-    ctx->base.is_jmp = ret;
     ctx->base.pc_next += 4;
 
     if (ret == DISAS_NORETURN || ret == DISAS_IAQ_N_UPDATED) {