From: Gabe Black Date: Wed, 2 Jun 2010 17:58:17 +0000 (-0500) Subject: ARM: Make sure the upc is zeroed when vectoring to a fault. X-Git-Tag: stable_2012_02_02~1081 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=563db6cb990a0dd5442b51b507152904e7bbd152;p=gem5.git ARM: Make sure the upc is zeroed when vectoring to a fault. --- diff --git a/src/arch/arm/faults.cc b/src/arch/arm/faults.cc index 0de5db527..3dd0b7f2f 100644 --- a/src/arch/arm/faults.cc +++ b/src/arch/arm/faults.cc @@ -143,6 +143,7 @@ ArmFault::invoke(ThreadContext *tc) tc->setPC(newPc); tc->setNextPC(newPc + cpsr.t ? 2 : 4 ); tc->setMicroPC(0); + tc->setNextMicroPC(1); } void @@ -189,6 +190,8 @@ SupervisorCall::invoke(ThreadContext *tc) // Advance the PC since that won't happen automatically. tc->setPC(tc->readNextPC()); tc->setNextPC(tc->readNextNPC()); + tc->setMicroPC(0); + tc->setNextMicroPC(1); } #endif // FULL_SYSTEM