[llvm] r271089 - [IRPGO] Centralize the function attribute inliner hint logic. NFC.
Sean Silva via llvm-commits
llvm-commits at lists.llvm.org
Fri May 27 20:02:50 PDT 2016
Author: silvas
Date: Fri May 27 22:02:50 2016
New Revision: 271089
URL: http://llvm.org/viewvc/llvm-project?rev=271089&view=rev
Log:
[IRPGO] Centralize the function attribute inliner hint logic. NFC.
This keeps the logic in the same function.
Modified:
llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp
Modified: llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp?rev=271089&r1=271088&r2=271089&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp (original)
+++ llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp Fri May 27 22:02:50 2016
@@ -458,8 +458,7 @@ class PGOUseFunc {
public:
PGOUseFunc(Function &Func, Module *Modu, BranchProbabilityInfo *BPI = nullptr,
BlockFrequencyInfo *BFI = nullptr)
- : F(Func), M(Modu), FuncInfo(Func, false, BPI, BFI),
- FreqAttr(FFA_Normal) {}
+ : F(Func), M(Modu), FuncInfo(Func, false, BPI, BFI) {}
// Read counts for the instrumented BB from profile.
bool readCounters(IndexedInstrProfReader *PGOReader);
@@ -473,15 +472,15 @@ public:
// Annotate the indirect call sites.
void annotateIndirectCallSites();
- // The hotness of the function from the profile count.
- enum FuncFreqAttr { FFA_Normal, FFA_Cold, FFA_Hot };
-
- // Return the function hotness from the profile.
- FuncFreqAttr getFuncFreqAttr() const { return FreqAttr; }
-
// Return the profile record for this function;
InstrProfRecord &getProfileRecord() { return ProfileRecord; }
+ // The entry count of this function.
+ uint64_t EntryCount;
+
+ // The maximum count value of any BB in this function.
+ uint64_t MaxBBCount;
+
private:
Function &F;
Module *M;
@@ -493,16 +492,9 @@ private:
return FuncInfo.getBBInfo(BB);
}
- // The maximum count value in the profile. This is only used in PGO use
- // compilation.
- uint64_t ProgramMaxCount;
-
// ProfileRecord for this function.
InstrProfRecord ProfileRecord;
- // Function hotness info derived from profile.
- FuncFreqAttr FreqAttr;
-
// Find the Instrumented BB and set the value.
void setInstrumentedCounts(const std::vector<uint64_t> &CountFromProfile);
@@ -512,22 +504,6 @@ private:
// Return FuncName string;
const std::string getFuncName() const { return FuncInfo.FuncName; }
-
- // Set the hot/cold inline hints based on the count values.
- // FIXME: This function should be removed once the functionality in
- // the inliner is implemented.
- void markFunctionAttributes(uint64_t EntryCount, uint64_t MaxCount) {
- if (ProgramMaxCount == 0)
- return;
- // Threshold of the hot functions.
- const BranchProbability HotFunctionThreshold(1, 100);
- // Threshold of the cold functions.
- const BranchProbability ColdFunctionThreshold(2, 10000);
- if (EntryCount >= HotFunctionThreshold.scale(ProgramMaxCount))
- FreqAttr = FFA_Hot;
- else if (MaxCount <= ColdFunctionThreshold.scale(ProgramMaxCount))
- FreqAttr = FFA_Cold;
- }
};
// Visit all the edges and assign the count value for the instrumented
@@ -627,7 +603,6 @@ bool PGOUseFunc::readCounters(IndexedIns
getBBInfo(nullptr).UnknownCountInEdge = 2;
setInstrumentedCounts(CountFromProfile);
- ProgramMaxCount = PGOReader->getMaximumFunctionCount();
return true;
}
@@ -691,16 +666,14 @@ void PGOUseFunc::populateCounters() {
}
DEBUG(dbgs() << "Populate counts in " << NumPasses << " passes.\n");
- // Assert every BB has a valid counter.
- uint64_t FuncEntryCount = getBBInfo(&*F.begin()).CountValue;
- uint64_t FuncMaxCount = FuncEntryCount;
+
+ EntryCount = getBBInfo(&*F.begin()).CountValue;
+ MaxBBCount = 0;
for (auto &BB : F) {
+ // Assert every BB has a valid counter.
assert(getBBInfo(&BB).CountValid && "BB count is not valid");
- uint64_t Count = getBBInfo(&BB).CountValue;
- if (Count > FuncMaxCount)
- FuncMaxCount = Count;
+ MaxBBCount = std::max(MaxBBCount, getBBInfo(&BB).CountValue);
}
- markFunctionAttributes(FuncEntryCount, FuncMaxCount);
DEBUG(FuncInfo.dumpInfo("after reading profile."));
}
@@ -888,6 +861,8 @@ static bool annotateAllFunctions(
std::vector<Function *> HotFunctions;
std::vector<Function *> ColdFunctions;
InstrProfSummaryBuilder Builder(ProfileSummaryBuilder::DefaultCutoffs);
+ uint64_t ProgramMaxCount = PGOReader->getMaximumFunctionCount();
+ bool HasProgramMaxCount = ProgramMaxCount != 0;
for (auto &F : M) {
if (F.isDeclaration())
continue;
@@ -897,14 +872,25 @@ static bool annotateAllFunctions(
setPGOCountOnFunc(Func, PGOReader.get());
if (!Func.getProfileRecord().Counts.empty())
Builder.addRecord(Func.getProfileRecord());
- PGOUseFunc::FuncFreqAttr FreqAttr = Func.getFuncFreqAttr();
- if (FreqAttr == PGOUseFunc::FFA_Cold)
- ColdFunctions.push_back(&F);
- else if (FreqAttr == PGOUseFunc::FFA_Hot)
+
+ if (!HasProgramMaxCount)
+ continue;
+ // Set the hot/cold inline hints based on the count values.
+ // FIXME: This should be removed once the functionality in
+ // the inliner is implemented.
+ const BranchProbability HotFunctionThreshold(1, 100);
+ const BranchProbability ColdFunctionThreshold(2, 10000);
+ if (Func.EntryCount >= HotFunctionThreshold.scale(ProgramMaxCount))
HotFunctions.push_back(&F);
+ else if (Func.MaxBBCount <= ColdFunctionThreshold.scale(ProgramMaxCount))
+ ColdFunctions.push_back(&F);
}
M.setProfileSummary(Builder.getSummary()->getMD(M.getContext()));
+
// Set function hotness attribute from the profile.
+ // We have to apply these attributes at the end because their presence
+ // can affect the BranchProbabilityInfo of any callers, resulting in an
+ // inconsistent MST between prof-gen and prof-use.
for (auto &F : HotFunctions) {
F->addFnAttr(llvm::Attribute::InlineHint);
DEBUG(dbgs() << "Set inline attribute to function: " << F->getName()
More information about the llvm-commits
mailing list