mirror of
https://github.com/xemu-project/xemu.git
synced 2025-02-11 15:17:32 +00:00
target/mips: Make check_cp0_enabled() return a boolean
To avoid callers to emit dead code if check_cp0_enabled() raise an exception, let it return a boolean value, whether CP0 is enabled or not. Suggested-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20210420193453.1913810-4-f4bug@amsat.org>
This commit is contained in:
parent
df44e81703
commit
905bdf72a6
@ -1572,11 +1572,13 @@ void gen_move_high32(TCGv ret, TCGv_i64 arg)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void check_cp0_enabled(DisasContext *ctx)
|
bool check_cp0_enabled(DisasContext *ctx)
|
||||||
{
|
{
|
||||||
if (unlikely(!(ctx->hflags & MIPS_HFLAG_CP0))) {
|
if (unlikely(!(ctx->hflags & MIPS_HFLAG_CP0))) {
|
||||||
generate_exception_end(ctx, EXCP_CpU);
|
generate_exception_end(ctx, EXCP_CpU);
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void check_cp1_enabled(DisasContext *ctx)
|
void check_cp1_enabled(DisasContext *ctx)
|
||||||
|
@ -120,7 +120,12 @@ void gen_reserved_instruction(DisasContext *ctx);
|
|||||||
|
|
||||||
void check_insn(DisasContext *ctx, uint64_t flags);
|
void check_insn(DisasContext *ctx, uint64_t flags);
|
||||||
void check_mips_64(DisasContext *ctx);
|
void check_mips_64(DisasContext *ctx);
|
||||||
void check_cp0_enabled(DisasContext *ctx);
|
/**
|
||||||
|
* check_cp0_enabled:
|
||||||
|
* Return %true if CP0 is enabled, otherwise return %false
|
||||||
|
* and emit a 'coprocessor unusable' exception.
|
||||||
|
*/
|
||||||
|
bool check_cp0_enabled(DisasContext *ctx);
|
||||||
void check_cp1_enabled(DisasContext *ctx);
|
void check_cp1_enabled(DisasContext *ctx);
|
||||||
void check_cp1_64bitmode(DisasContext *ctx);
|
void check_cp1_64bitmode(DisasContext *ctx);
|
||||||
void check_cp1_registers(DisasContext *ctx, int regs);
|
void check_cp1_registers(DisasContext *ctx, int regs);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user