mirror of https://gitee.com/openkylin/qemu.git
target/m68k: check CF_PARALLEL instead of parallel_cpus
Thereby decoupling the resulting translated code from the current state of the system. Reviewed-by: Richard Henderson <rth@twiddle.net> Signed-off-by: Emilio G. Cota <cota@braap.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
b5e3b4c2ac
commit
f0ddf11b23
|
@ -11,6 +11,7 @@ DEF_HELPER_2(set_sr, void, env, i32)
|
|||
DEF_HELPER_3(movec, void, env, i32, i32)
|
||||
DEF_HELPER_4(cas2w, void, env, i32, i32, i32)
|
||||
DEF_HELPER_4(cas2l, void, env, i32, i32, i32)
|
||||
DEF_HELPER_4(cas2l_parallel, void, env, i32, i32, i32)
|
||||
|
||||
#define dh_alias_fp ptr
|
||||
#define dh_ctype_fp FPReg *
|
||||
|
|
|
@ -361,6 +361,7 @@ void HELPER(divsll)(CPUM68KState *env, int numr, int regr, int32_t den)
|
|||
env->dregs[numr] = quot;
|
||||
}
|
||||
|
||||
/* We're executing in a serial context -- no need to be atomic. */
|
||||
void HELPER(cas2w)(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2)
|
||||
{
|
||||
uint32_t Dc1 = extract32(regs, 9, 3);
|
||||
|
@ -374,17 +375,11 @@ void HELPER(cas2w)(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2)
|
|||
int16_t l1, l2;
|
||||
uintptr_t ra = GETPC();
|
||||
|
||||
if (parallel_cpus) {
|
||||
/* Tell the main loop we need to serialize this insn. */
|
||||
cpu_loop_exit_atomic(ENV_GET_CPU(env), ra);
|
||||
} else {
|
||||
/* We're executing in a serial context -- no need to be atomic. */
|
||||
l1 = cpu_lduw_data_ra(env, a1, ra);
|
||||
l2 = cpu_lduw_data_ra(env, a2, ra);
|
||||
if (l1 == c1 && l2 == c2) {
|
||||
cpu_stw_data_ra(env, a1, u1, ra);
|
||||
cpu_stw_data_ra(env, a2, u2, ra);
|
||||
}
|
||||
l1 = cpu_lduw_data_ra(env, a1, ra);
|
||||
l2 = cpu_lduw_data_ra(env, a2, ra);
|
||||
if (l1 == c1 && l2 == c2) {
|
||||
cpu_stw_data_ra(env, a1, u1, ra);
|
||||
cpu_stw_data_ra(env, a2, u2, ra);
|
||||
}
|
||||
|
||||
if (c1 != l1) {
|
||||
|
@ -399,7 +394,8 @@ void HELPER(cas2w)(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2)
|
|||
env->dregs[Dc2] = deposit32(env->dregs[Dc2], 0, 16, l2);
|
||||
}
|
||||
|
||||
void HELPER(cas2l)(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2)
|
||||
static void do_cas2l(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2,
|
||||
bool parallel)
|
||||
{
|
||||
uint32_t Dc1 = extract32(regs, 9, 3);
|
||||
uint32_t Dc2 = extract32(regs, 6, 3);
|
||||
|
@ -416,7 +412,7 @@ void HELPER(cas2l)(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2)
|
|||
TCGMemOpIdx oi;
|
||||
#endif
|
||||
|
||||
if (parallel_cpus) {
|
||||
if (parallel) {
|
||||
/* We're executing in a parallel context -- must be atomic. */
|
||||
#ifdef CONFIG_ATOMIC64
|
||||
uint64_t c, u, l;
|
||||
|
@ -470,6 +466,17 @@ void HELPER(cas2l)(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2)
|
|||
env->dregs[Dc2] = l2;
|
||||
}
|
||||
|
||||
void HELPER(cas2l)(CPUM68KState *env, uint32_t regs, uint32_t a1, uint32_t a2)
|
||||
{
|
||||
do_cas2l(env, regs, a1, a2, false);
|
||||
}
|
||||
|
||||
void HELPER(cas2l_parallel)(CPUM68KState *env, uint32_t regs, uint32_t a1,
|
||||
uint32_t a2)
|
||||
{
|
||||
do_cas2l(env, regs, a1, a2, true);
|
||||
}
|
||||
|
||||
struct bf_data {
|
||||
uint32_t addr;
|
||||
uint32_t bofs;
|
||||
|
|
|
@ -2312,7 +2312,11 @@ DISAS_INSN(cas2w)
|
|||
(REG(ext1, 6) << 3) |
|
||||
(REG(ext2, 0) << 6) |
|
||||
(REG(ext1, 0) << 9));
|
||||
gen_helper_cas2w(cpu_env, regs, addr1, addr2);
|
||||
if (tb_cflags(s->tb) & CF_PARALLEL) {
|
||||
gen_helper_exit_atomic(cpu_env);
|
||||
} else {
|
||||
gen_helper_cas2w(cpu_env, regs, addr1, addr2);
|
||||
}
|
||||
tcg_temp_free(regs);
|
||||
|
||||
/* Note that cas2w also assigned to env->cc_op. */
|
||||
|
@ -2358,7 +2362,11 @@ DISAS_INSN(cas2l)
|
|||
(REG(ext1, 6) << 3) |
|
||||
(REG(ext2, 0) << 6) |
|
||||
(REG(ext1, 0) << 9));
|
||||
gen_helper_cas2l(cpu_env, regs, addr1, addr2);
|
||||
if (tb_cflags(s->tb) & CF_PARALLEL) {
|
||||
gen_helper_cas2l_parallel(cpu_env, regs, addr1, addr2);
|
||||
} else {
|
||||
gen_helper_cas2l(cpu_env, regs, addr1, addr2);
|
||||
}
|
||||
tcg_temp_free(regs);
|
||||
|
||||
/* Note that cas2l also assigned to env->cc_op. */
|
||||
|
|
Loading…
Reference in New Issue