From: Bastian Koppelmann Date: Tue, 5 May 2015 17:41:10 +0000 (+0200) Subject: target-tricore: fix rfe not restoring the PC X-Git-Tag: v2.4.0-rc0~140^2 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=3446a11181c6e8263dbd9c13c28986df4317099e;p=users%2Fdwmw2%2Fqemu.git target-tricore: fix rfe not restoring the PC Signed-off-by: Bastian Koppelmann --- diff --git a/target-tricore/op_helper.c b/target-tricore/op_helper.c index 1dc25c2349..9919b5b17b 100644 --- a/target-tricore/op_helper.c +++ b/target-tricore/op_helper.c @@ -2458,6 +2458,7 @@ void helper_rfe(CPUTriCoreState *env) if (!cdc_zero(&(env->PSW)) && (env->PSW & MASK_PSW_CDE)) { /* raise MNG trap */ } + env->PC = env->gpr_a[11] & ~0x1; /* ICR.IE = PCXI.PIE; */ env->ICR = (env->ICR & ~MASK_ICR_IE) + ((env->PCXI & MASK_PCXI_PIE) >> 15); /* ICR.CCPN = PCXI.PCPN; */