[llvm] [CodeGen] Resolve FIXME: Find the same unit free in each cycle instead of one in each cycle (PR #82732)
via llvm-commits
llvm-commits at lists.llvm.org
Sun Mar 3 10:26:50 PST 2024
https://github.com/AtariDreams updated https://github.com/llvm/llvm-project/pull/82732
>From e63ebc5c18471bdf4f9609d1d7ce2f716af3250a Mon Sep 17 00:00:00 2001
From: Rose <83477269+AtariDreams at users.noreply.github.com>
Date: Thu, 22 Feb 2024 23:01:52 -0500
Subject: [PATCH] [CodeGen] Resolve FIXME: Find the same unit free in each
cycle instead of one in each cycle
---
.../CodeGen/ScoreboardHazardRecognizer.cpp | 25 +++++++++++--------
1 file changed, 14 insertions(+), 11 deletions(-)
diff --git a/llvm/lib/CodeGen/ScoreboardHazardRecognizer.cpp b/llvm/lib/CodeGen/ScoreboardHazardRecognizer.cpp
index 209c6d81f60203..6b6331379b78ed 100644
--- a/llvm/lib/CodeGen/ScoreboardHazardRecognizer.cpp
+++ b/llvm/lib/CodeGen/ScoreboardHazardRecognizer.cpp
@@ -127,9 +127,9 @@ ScoreboardHazardRecognizer::getHazardType(SUnit *SU, int Stalls) {
unsigned idx = MCID->getSchedClass();
for (const InstrStage *IS = ItinData->beginStage(idx),
*E = ItinData->endStage(idx); IS != E; ++IS) {
- // We must find one of the stage's units free for every cycle the
- // stage is occupied. FIXME it would be more accurate to find the
- // same unit free in all the cycles.
+ // We must find the same unit free in all the cycles
+ // Initialize freeUnits to all units of the stage.
+ InstrStage::FuncUnits freeUnits = IS->getUnits();
for (unsigned int i = 0; i < IS->getCycles(); ++i) {
int StageCycle = cycle + (int)i;
if (StageCycle < 0)
@@ -142,23 +142,26 @@ ScoreboardHazardRecognizer::getHazardType(SUnit *SU, int Stalls) {
break;
}
- InstrStage::FuncUnits freeUnits = IS->getUnits();
+ // For each cycle, update freeUnits to the intersection of its current
+ // value and the units free in this cycle
+ InstrStage::FuncUnits cycleFreeUnits = IS->getUnits();
switch (IS->getReservationKind()) {
case InstrStage::Required:
// Required FUs conflict with both reserved and required ones
- freeUnits &= ~ReservedScoreboard[StageCycle];
+ cycleFreeUnits &= ~ReservedScoreboard[StageCycle];
[[fallthrough]];
case InstrStage::Reserved:
// Reserved FUs can conflict only with required ones.
- freeUnits &= ~RequiredScoreboard[StageCycle];
+ cycleFreeUnits &= ~RequiredScoreboard[StageCycle];
break;
}
+ freeUnits &= cycleFreeUnits;
+ }
- if (!freeUnits) {
- LLVM_DEBUG(dbgs() << "*** Hazard in cycle +" << StageCycle << ", ");
- LLVM_DEBUG(DAG->dumpNode(*SU));
- return Hazard;
- }
+ if (!freeUnits) {
+ LLVM_DEBUG(dbgs() << "*** Hazard in cycle +" << cycle << ", ");
+ LLVM_DEBUG(DAG->dumpNode(*SU));
+ return Hazard;
}
// Advance the cycle to the next stage.
More information about the llvm-commits
mailing list