[llvm] r267216 - [PGO] change the interface for createPGOFuncNameMetadata()
Rong Xu via llvm-commits
llvm-commits at lists.llvm.org
Fri Apr 22 14:00:18 PDT 2016
Author: xur
Date: Fri Apr 22 16:00:17 2016
New Revision: 267216
URL: http://llvm.org/viewvc/llvm-project?rev=267216&view=rev
Log:
[PGO] change the interface for createPGOFuncNameMetadata()
This patch changes the interface for createPGOFuncNameMetadata() where we add
another PGOFuncName argument.
Differential Revision: http://reviews.llvm.org/D19433
Modified:
llvm/trunk/include/llvm/ProfileData/InstrProf.h
llvm/trunk/lib/ProfileData/InstrProf.cpp
llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp
Modified: llvm/trunk/include/llvm/ProfileData/InstrProf.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/ProfileData/InstrProf.h?rev=267216&r1=267215&r2=267216&view=diff
==============================================================================
--- llvm/trunk/include/llvm/ProfileData/InstrProf.h (original)
+++ llvm/trunk/include/llvm/ProfileData/InstrProf.h Fri Apr 22 16:00:17 2016
@@ -253,7 +253,7 @@ MDNode *getPGOFuncNameMetadata(const Fun
/// Create the PGOFuncName meta data if PGOFuncName is different from
/// function's raw name. This should only apply to internal linkage functions
/// declared by users only.
-void createPGOFuncNameMetadata(Function &F);
+void createPGOFuncNameMetadata(Function &F, const std::string &PGOFuncName);
const std::error_category &instrprof_category();
Modified: llvm/trunk/lib/ProfileData/InstrProf.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/ProfileData/InstrProf.cpp?rev=267216&r1=267215&r2=267216&view=diff
==============================================================================
--- llvm/trunk/lib/ProfileData/InstrProf.cpp (original)
+++ llvm/trunk/lib/ProfileData/InstrProf.cpp Fri Apr 22 16:00:17 2016
@@ -732,13 +732,15 @@ MDNode *getPGOFuncNameMetadata(const Fun
return F.getMetadata(getPGOFuncNameMetadataName());
}
-void createPGOFuncNameMetadata(Function &F) {
- const std::string &FuncName = getPGOFuncName(F);
- if (FuncName == F.getName())
+void createPGOFuncNameMetadata(Function &F, const std::string &PGOFuncName) {
+ // Only for internal linkage functions.
+ if (PGOFuncName == F.getName())
+ return;
+ // Don't create duplicated meta-data.
+ if (getPGOFuncNameMetadata(F))
return;
-
LLVMContext &C = F.getContext();
- MDNode *N = MDNode::get(C, MDString::get(C, FuncName.c_str()));
+ MDNode *N = MDNode::get(C, MDString::get(C, PGOFuncName.c_str()));
F.setMetadata(getPGOFuncNameMetadataName(), N);
}
Modified: llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp?rev=267216&r1=267215&r2=267216&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp (original)
+++ llvm/trunk/lib/Transforms/Instrumentation/PGOInstrumentation.cpp Fri Apr 22 16:00:17 2016
@@ -732,7 +732,7 @@ void PGOUseFunc::annotateIndirectCallSit
return;
// Create the PGOFuncName meta data.
- createPGOFuncNameMetadata(F);
+ createPGOFuncNameMetadata(F, FuncInfo.FuncName);
unsigned IndirectCallSiteIndex = 0;
auto IndirectCallSites = findIndirectCallSites(F);
More information about the llvm-commits
mailing list