target/sh4: Keep env->flags clean
If we mask off any out-of-band bits before we assign to the variable, then we don't need to clean it up when reading. Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Aurelien Jarno <aurelien@aurel32.net> Signed-off-by: Richard Henderson <rth@twiddle.net> Message-Id: <20170718200255.31647-5-rth@twiddle.net> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
This commit is contained in:
parent
e1933d1435
commit
ca69176d52
@ -39,7 +39,7 @@ static void superh_cpu_synchronize_from_tb(CPUState *cs, TranslationBlock *tb)
|
|||||||
SuperHCPU *cpu = SUPERH_CPU(cs);
|
SuperHCPU *cpu = SUPERH_CPU(cs);
|
||||||
|
|
||||||
cpu->env.pc = tb->pc;
|
cpu->env.pc = tb->pc;
|
||||||
cpu->env.flags = tb->flags;
|
cpu->env.flags = tb->flags & TB_FLAG_ENVFLAGS_MASK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool superh_cpu_has_work(CPUState *cs)
|
static bool superh_cpu_has_work(CPUState *cs)
|
||||||
|
@ -390,7 +390,7 @@ static inline void cpu_get_tb_cpu_state(CPUSH4State *env, target_ulong *pc,
|
|||||||
{
|
{
|
||||||
*pc = env->pc;
|
*pc = env->pc;
|
||||||
*cs_base = 0;
|
*cs_base = 0;
|
||||||
*flags = (env->flags & TB_FLAG_ENVFLAGS_MASK) /* Bits 0-2 */
|
*flags = env->flags /* Bits 0-2 */
|
||||||
| (env->fpscr & (FPSCR_FR | FPSCR_SZ | FPSCR_PR)) /* Bits 19-21 */
|
| (env->fpscr & (FPSCR_FR | FPSCR_SZ | FPSCR_PR)) /* Bits 19-21 */
|
||||||
| (env->sr & ((1u << SR_MD) | (1u << SR_RB))) /* Bits 29-30 */
|
| (env->sr & ((1u << SR_MD) | (1u << SR_RB))) /* Bits 29-30 */
|
||||||
| (env->sr & (1u << SR_FD)) /* Bit 15 */
|
| (env->sr & (1u << SR_FD)) /* Bit 15 */
|
||||||
|
Loading…
Reference in New Issue
Block a user