提交 7372c2b9 编写于 作者: P Peter Maydell 提交者: Andreas Färber

target-m68k: Remove custom qemu_assert() function

Remove the custom qemu_assert() function defined by target-m68k/translate.c
in favour of either using glib g_assert_not_reached() (for the genuinely
can't-happen cases) or cpu_abort() (for the "this isn't implemented",
in line with other unimplemented cases in the target).

This has the benefit of silencing some clang warnings about
variables used while uninitialized (which are emitted because
clang can't figure out that qemu_assert(0, something) never
returns.
Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
Signed-off-by: NAndreas Färber <afaerber@suse.de>
上级 9262685b
...@@ -110,14 +110,6 @@ void m68k_tcg_init(void) ...@@ -110,14 +110,6 @@ void m68k_tcg_init(void)
store_dummy = tcg_global_mem_new(TCG_AREG0, -8, "NULL"); store_dummy = tcg_global_mem_new(TCG_AREG0, -8, "NULL");
} }
static inline void qemu_assert(int cond, const char *msg)
{
if (!cond) {
fprintf (stderr, "badness: %s\n", msg);
abort();
}
}
/* internal defines */ /* internal defines */
typedef struct DisasContext { typedef struct DisasContext {
CPUM68KState *env; CPUM68KState *env;
...@@ -199,7 +191,7 @@ static inline TCGv gen_load(DisasContext * s, int opsize, TCGv addr, int sign) ...@@ -199,7 +191,7 @@ static inline TCGv gen_load(DisasContext * s, int opsize, TCGv addr, int sign)
tcg_gen_qemu_ld32u(tmp, addr, index); tcg_gen_qemu_ld32u(tmp, addr, index);
break; break;
default: default:
qemu_assert(0, "bad load size"); g_assert_not_reached();
} }
gen_throws_exception = gen_last_qop; gen_throws_exception = gen_last_qop;
return tmp; return tmp;
...@@ -233,7 +225,7 @@ static inline void gen_store(DisasContext *s, int opsize, TCGv addr, TCGv val) ...@@ -233,7 +225,7 @@ static inline void gen_store(DisasContext *s, int opsize, TCGv addr, TCGv val)
tcg_gen_qemu_st32(val, addr, index); tcg_gen_qemu_st32(val, addr, index);
break; break;
default: default:
qemu_assert(0, "bad store size"); g_assert_not_reached();
} }
gen_throws_exception = gen_last_qop; gen_throws_exception = gen_last_qop;
} }
...@@ -437,8 +429,7 @@ static inline int opsize_bytes(int opsize) ...@@ -437,8 +429,7 @@ static inline int opsize_bytes(int opsize)
case OS_SINGLE: return 4; case OS_SINGLE: return 4;
case OS_DOUBLE: return 8; case OS_DOUBLE: return 8;
default: default:
qemu_assert(0, "bad operand size"); g_assert_not_reached();
return 0;
} }
} }
...@@ -465,8 +456,7 @@ static void gen_partset_reg(int opsize, TCGv reg, TCGv val) ...@@ -465,8 +456,7 @@ static void gen_partset_reg(int opsize, TCGv reg, TCGv val)
tcg_gen_mov_i32(reg, val); tcg_gen_mov_i32(reg, val);
break; break;
default: default:
qemu_assert(0, "Bad operand size"); g_assert_not_reached();
break;
} }
} }
...@@ -495,7 +485,7 @@ static inline TCGv gen_extend(TCGv val, int opsize, int sign) ...@@ -495,7 +485,7 @@ static inline TCGv gen_extend(TCGv val, int opsize, int sign)
tmp = val; tmp = val;
break; break;
default: default:
qemu_assert(0, "Bad operand size"); g_assert_not_reached();
} }
return tmp; return tmp;
} }
...@@ -669,7 +659,7 @@ static TCGv gen_ea(CPUM68KState *env, DisasContext *s, uint16_t insn, ...@@ -669,7 +659,7 @@ static TCGv gen_ea(CPUM68KState *env, DisasContext *s, uint16_t insn,
offset = read_im32(env, s); offset = read_im32(env, s);
break; break;
default: default:
qemu_assert(0, "Bad immediate operand"); g_assert_not_reached();
} }
return tcg_const_i32(offset); return tcg_const_i32(offset);
default: default:
...@@ -2092,7 +2082,7 @@ DISAS_INSN(wdebug) ...@@ -2092,7 +2082,7 @@ DISAS_INSN(wdebug)
return; return;
} }
/* TODO: Implement wdebug. */ /* TODO: Implement wdebug. */
qemu_assert(0, "WDEBUG not implemented"); cpu_abort(env, "WDEBUG not implemented");
} }
DISAS_INSN(trap) DISAS_INSN(trap)
...@@ -2467,13 +2457,13 @@ DISAS_INSN(fbcc) ...@@ -2467,13 +2457,13 @@ DISAS_INSN(fbcc)
DISAS_INSN(frestore) DISAS_INSN(frestore)
{ {
/* TODO: Implement frestore. */ /* TODO: Implement frestore. */
qemu_assert(0, "FRESTORE not implemented"); cpu_abort(env, "FRESTORE not implemented");
} }
DISAS_INSN(fsave) DISAS_INSN(fsave)
{ {
/* TODO: Implement fsave. */ /* TODO: Implement fsave. */
qemu_assert(0, "FSAVE not implemented"); cpu_abort(env, "FSAVE not implemented");
} }
static inline TCGv gen_mac_extract_word(DisasContext *s, TCGv val, int upper) static inline TCGv gen_mac_extract_word(DisasContext *s, TCGv val, int upper)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册