mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-14 00:14:19 +00:00
Moved isDeclaration() check further down to allow for function counts for
declarations if necessary. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@80084 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
383cbff031
commit
3772fb11fe
@ -67,12 +67,15 @@ double ProfileInfo::getExecutionCount(const BasicBlock *BB) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
double ProfileInfo::getExecutionCount(const Function *F) {
|
double ProfileInfo::getExecutionCount(const Function *F) {
|
||||||
if (F->isDeclaration()) return MissingValue;
|
|
||||||
std::map<const Function*, double>::iterator J =
|
std::map<const Function*, double>::iterator J =
|
||||||
FunctionInformation.find(F);
|
FunctionInformation.find(F);
|
||||||
if (J != FunctionInformation.end())
|
if (J != FunctionInformation.end())
|
||||||
return J->second;
|
return J->second;
|
||||||
|
|
||||||
|
// isDeclaration() is checked here and not at start of function to allow
|
||||||
|
// functions without a body still to have a execution count.
|
||||||
|
if (F->isDeclaration()) return MissingValue;
|
||||||
|
|
||||||
double Count = getExecutionCount(&F->getEntryBlock());
|
double Count = getExecutionCount(&F->getEntryBlock());
|
||||||
if (Count != MissingValue) FunctionInformation[F] = Count;
|
if (Count != MissingValue) FunctionInformation[F] = Count;
|
||||||
return Count;
|
return Count;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user