From 0fddbbf2559579ab6274c50819001f4eb9896b2a Mon Sep 17 00:00:00 2001 From: Nathan Froyd Date: Tue, 8 Jun 2010 13:30:02 -0700 Subject: [PATCH] linux-user: honor low bit of entry PC for MIPS Signed-off-by: Nathan Froyd Signed-off-by: Aurelien Jarno --- linux-user/main.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/linux-user/main.c b/linux-user/main.c index 0f23fc9cd9..ad292f16e4 100644 --- a/linux-user/main.c +++ b/linux-user/main.c @@ -3271,7 +3271,10 @@ int main(int argc, char **argv, char **envp) for(i = 0; i < 32; i++) { env->active_tc.gpr[i] = regs->regs[i]; } - env->active_tc.PC = regs->cp0_epc; + env->active_tc.PC = regs->cp0_epc & ~(target_ulong)1; + if (regs->cp0_epc & 1) { + env->hflags |= MIPS_HFLAG_M16; + } } #elif defined(TARGET_SH4) {