[PATCH] D47213: [llvm-mca] Move DispatchStage::cycleEvent to preExecute. NFC.
Matt Davis via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue May 22 13:55:53 PDT 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rL333029: [llvm-mca] Move DispatchStage::cycleEvent to preExecute. NFC. (authored by mattd, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D47213?vs=148064&id=148098#toc
Repository:
rL LLVM
https://reviews.llvm.org/D47213
Files:
llvm/trunk/tools/llvm-mca/Backend.cpp
llvm/trunk/tools/llvm-mca/DispatchStage.cpp
llvm/trunk/tools/llvm-mca/DispatchStage.h
Index: llvm/trunk/tools/llvm-mca/DispatchStage.h
===================================================================
--- llvm/trunk/tools/llvm-mca/DispatchStage.h
+++ llvm/trunk/tools/llvm-mca/DispatchStage.h
@@ -98,14 +98,8 @@
this)),
Owner(B), STI(Subtarget) {}
- void cycleEvent() {
- RCU->cycleEvent();
- AvailableEntries =
- CarryOver >= DispatchWidth ? 0 : DispatchWidth - CarryOver;
- CarryOver = CarryOver >= DispatchWidth ? CarryOver - DispatchWidth : 0U;
- }
-
virtual bool isReady() const override final { return isRCUEmpty(); }
+ virtual void preExecute(const InstRef &IR) override final;
virtual bool execute(InstRef &IR) override final;
void notifyInstructionRetired(const InstRef &IR);
void notifyDispatchStall(const InstRef &IR, unsigned EventType);
Index: llvm/trunk/tools/llvm-mca/Backend.cpp
===================================================================
--- llvm/trunk/tools/llvm-mca/Backend.cpp
+++ llvm/trunk/tools/llvm-mca/Backend.cpp
@@ -38,6 +38,9 @@
notifyCycleBegin(Cycle);
InstRef IR;
+ Dispatch->preExecute(IR);
+ HWS->cycleEvent(); // TODO: This will eventually be stage-ified.
+
while (Fetch->execute(IR)) {
if (!Dispatch->execute(IR))
break;
@@ -51,9 +54,6 @@
LLVM_DEBUG(dbgs() << "[E] Cycle begin: " << Cycle << '\n');
for (HWEventListener *Listener : Listeners)
Listener->onCycleBegin();
-
- Dispatch->cycleEvent();
- HWS->cycleEvent();
}
void Backend::notifyInstructionEvent(const HWInstructionEvent &Event) {
Index: llvm/trunk/tools/llvm-mca/DispatchStage.cpp
===================================================================
--- llvm/trunk/tools/llvm-mca/DispatchStage.cpp
+++ llvm/trunk/tools/llvm-mca/DispatchStage.cpp
@@ -142,6 +142,12 @@
SC->scheduleInstruction(IR);
}
+void DispatchStage::preExecute(const InstRef &IR) {
+ RCU->cycleEvent();
+ AvailableEntries = CarryOver >= DispatchWidth ? 0 : DispatchWidth - CarryOver;
+ CarryOver = CarryOver >= DispatchWidth ? CarryOver - DispatchWidth : 0U;
+}
+
bool DispatchStage::execute(InstRef &IR) {
const InstrDesc &Desc = IR.getInstruction()->getDesc();
if (!isAvailable(Desc.NumMicroOps) || !canDispatch(IR))
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D47213.148098.patch
Type: text/x-patch
Size: 2257 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180522/4b27be67/attachment.bin>
More information about the llvm-commits
mailing list