pc_before, target);
     }
 
-    if (inst->predictedTaken && !force_branch) {
+    if (thread->status() == ThreadContext::Suspended) {
+        /* Thread got suspended */
+        DPRINTF(Branch, "Thread got suspended: branch from 0x%x to 0x%x "
+            "inst: %s\n",
+            inst->pc.instAddr(), target.instAddr(), *inst);
+
+        reason = BranchData::SuspendThread;
+    } else if (inst->predictedTaken && !force_branch) {
         /* Predicted to branch */
         if (!must_branch) {
             /* No branch was taken, change stream to get us back to the
         !branch.isStreamChange() && /* No real branch */
         fault == NoFault && /* No faults */
         completed_inst && /* Still finding instructions to execute */
-        num_insts_committed != commitLimit && /* Not reached commit limit */
-        cpu.getContext(thread_id)->status() != ThreadContext::Suspended
+        num_insts_committed != commitLimit /* Not reached commit limit */
         )
     {
         if (only_commit_microops) {