mirror of
https://github.com/RPCS3/llvm.git
synced 2025-05-22 13:26:03 +00:00

Summary: This class maintains the same logic as the original RetireControlUnit. This is just an intermediate patch to make the RCU a Stage. Future patches will remove the dependency on the DispatchStage, and then more properly populate the pre/execute/post Stage interface. Reviewers: andreadb, RKSimon, courbet Reviewed By: andreadb, courbet Subscribers: javed.absar, mgorny, tschuett, gbedwell, llvm-commits Differential Revision: https://reviews.llvm.org/D47244 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@333292 91177308-0d34-0410-b5e6-96231b3b80d8
57 lines
1.8 KiB
C++
57 lines
1.8 KiB
C++
//===---------------------- RetireStage.cpp ---------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
/// \file
|
|
///
|
|
/// This file defines the retire stage of an instruction pipeline.
|
|
/// The RetireStage represents the process logic that interacts with the
|
|
/// simulated RetireControlUnit hardware.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "RetireStage.h"
|
|
#include "Backend.h"
|
|
#include "HWEventListener.h"
|
|
#include "llvm/Support/Debug.h"
|
|
|
|
using namespace llvm;
|
|
|
|
#define DEBUG_TYPE "llvm-mca"
|
|
|
|
namespace mca {
|
|
|
|
void RetireStage::preExecute(const InstRef &IR) {
|
|
if (RCU.isEmpty())
|
|
return;
|
|
|
|
const unsigned MaxRetirePerCycle = RCU.getMaxRetirePerCycle();
|
|
unsigned NumRetired = 0;
|
|
while (!RCU.isEmpty()) {
|
|
if (MaxRetirePerCycle != 0 && NumRetired == MaxRetirePerCycle)
|
|
break;
|
|
const RetireControlUnit::RUToken &Current = RCU.peekCurrentToken();
|
|
if (!Current.Executed)
|
|
break;
|
|
RCU.consumeCurrentToken();
|
|
notifyInstructionRetired(Current.IR);
|
|
NumRetired++;
|
|
}
|
|
}
|
|
|
|
void RetireStage::notifyInstructionRetired(const InstRef &IR) {
|
|
LLVM_DEBUG(dbgs() << "[E] Instruction Retired: " << IR << '\n');
|
|
SmallVector<unsigned, 4> FreedRegs(PRF.getNumRegisterFiles());
|
|
const InstrDesc &Desc = IR.getInstruction()->getDesc();
|
|
|
|
for (const std::unique_ptr<WriteState> &WS : IR.getInstruction()->getDefs())
|
|
PRF.removeRegisterWrite(*WS.get(), FreedRegs, !Desc.isZeroLatency());
|
|
Owner->notifyInstructionEvent(HWInstructionRetiredEvent(IR, FreedRegs));
|
|
}
|
|
|
|
} // namespace mca
|