diff options
Diffstat (limited to 'llvm/lib/Bitcode')
-rw-r--r-- | llvm/lib/Bitcode/Writer/BitcodeWriter.cpp | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp index 6510bce92b7..26cfe5943e1 100644 --- a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp +++ b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -34,7 +34,6 @@ #include "llvm/IR/Operator.h" #include "llvm/IR/UseListOrder.h" #include "llvm/IR/ValueSymbolTable.h" -#include "llvm/ProfileData/ProfileCommon.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/ErrorHandling.h" #include "llvm/Support/MathExtras.h" @@ -2575,14 +2574,11 @@ static void WriteFunction( auto *CalledFunction = CS.getCalledFunction(); if (CalledFunction && CalledFunction->hasName() && !CalledFunction->isIntrinsic()) { - uint64_t ScaledCount = 0; - if (HasProfileData) - ScaledCount = getBlockProfileCount( - BFI->getBlockFreq(&(*BB)).getFrequency(), BFI->getEntryFreq(), - F.getEntryCount().getValue()); + auto ScaledCount = BFI ? BFI->getBlockProfileCount(&*BB) : None; unsigned CalleeId = VE.getValueID( M->getValueSymbolTable().lookup(CalledFunction->getName())); - CallGraphEdges[CalleeId] += ScaledCount; + CallGraphEdges[CalleeId] += + (ScaledCount ? ScaledCount.getValue() : 0); } } findRefEdges(&*I, VE, RefEdges, Visited); |