[llvm] r263835 - Interface to get/set profile summary metadata to module
Easwaran Raman via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 18 14:29:30 PDT 2016
Author: eraman
Date: Fri Mar 18 16:29:30 2016
New Revision: 263835
URL: http://llvm.org/viewvc/llvm-project?rev=263835&view=rev
Log:
Interface to get/set profile summary metadata to module
Differential Revision: http://reviews.llvm.org/D17894
Modified:
llvm/trunk/include/llvm/IR/Module.h
llvm/trunk/lib/IR/Module.cpp
llvm/trunk/unittests/ProfileData/InstrProfTest.cpp
llvm/trunk/unittests/ProfileData/SampleProfTest.cpp
Modified: llvm/trunk/include/llvm/IR/Module.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/IR/Module.h?rev=263835&r1=263834&r2=263835&view=diff
==============================================================================
--- llvm/trunk/include/llvm/IR/Module.h (original)
+++ llvm/trunk/include/llvm/IR/Module.h Fri Mar 18 16:29:30 2016
@@ -637,7 +637,7 @@ public:
void setPICLevel(PICLevel::Level PL);
/// @}
- /// @name Utility functions for querying and setting PGO counts
+ /// @name Utility functions for querying and setting PGO summary
/// @{
/// \brief Set maximum function count in PGO mode
@@ -645,6 +645,12 @@ public:
/// \brief Returns maximum function count in PGO mode
Optional<uint64_t> getMaximumFunctionCount();
+
+ /// \brief Attach profile summary metadata to this module.
+ void setProfileSummary(Metadata *M);
+
+ /// \brief Returns profile summary metadata
+ Metadata *getProfileSummary();
/// @}
};
Modified: llvm/trunk/lib/IR/Module.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/IR/Module.cpp?rev=263835&r1=263834&r2=263835&view=diff
==============================================================================
--- llvm/trunk/lib/IR/Module.cpp (original)
+++ llvm/trunk/lib/IR/Module.cpp Fri Mar 18 16:29:30 2016
@@ -485,3 +485,11 @@ Optional<uint64_t> Module::getMaximumFun
return None;
return cast<ConstantInt>(Val->getValue())->getZExtValue();
}
+
+void Module::setProfileSummary(Metadata *M) {
+ addModuleFlag(ModFlagBehavior::Error, "ProfileSummary", M);
+}
+
+Metadata *Module::getProfileSummary() {
+ return getModuleFlag("ProfileSummary");
+}
Modified: llvm/trunk/unittests/ProfileData/InstrProfTest.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/ProfileData/InstrProfTest.cpp?rev=263835&r1=263834&r2=263835&view=diff
==============================================================================
--- llvm/trunk/unittests/ProfileData/InstrProfTest.cpp (original)
+++ llvm/trunk/unittests/ProfileData/InstrProfTest.cpp Fri Mar 18 16:29:30 2016
@@ -180,6 +180,8 @@ TEST_F(InstrProfTest, get_profile_summar
};
InstrProfSummary &PS = Reader->getSummary();
VerifySummary(PS);
+
+ // Test that conversion of summary to and from Metadata works.
Metadata *MD = PS.getMD(getGlobalContext());
ASSERT_TRUE(MD);
ProfileSummary *PSFromMD = ProfileSummary::getFromMD(MD);
@@ -188,6 +190,18 @@ TEST_F(InstrProfTest, get_profile_summar
InstrProfSummary *IPS = cast<InstrProfSummary>(PSFromMD);
VerifySummary(*IPS);
delete IPS;
+
+ // Test that summary can be attached to and read back from module.
+ Module M("my_module", getGlobalContext());
+ M.setProfileSummary(MD);
+ MD = M.getProfileSummary();
+ ASSERT_TRUE(MD);
+ PSFromMD = ProfileSummary::getFromMD(MD);
+ ASSERT_TRUE(PSFromMD);
+ ASSERT_TRUE(isa<InstrProfSummary>(PSFromMD));
+ IPS = cast<InstrProfSummary>(PSFromMD);
+ VerifySummary(*IPS);
+ delete IPS;
}
TEST_P(MaybeSparseInstrProfTest, get_icall_data_read_write) {
Modified: llvm/trunk/unittests/ProfileData/SampleProfTest.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/ProfileData/SampleProfTest.cpp?rev=263835&r1=263834&r2=263835&view=diff
==============================================================================
--- llvm/trunk/unittests/ProfileData/SampleProfTest.cpp (original)
+++ llvm/trunk/unittests/ProfileData/SampleProfTest.cpp Fri Mar 18 16:29:30 2016
@@ -126,6 +126,7 @@ struct SampleProfTest : ::testing::Test
SampleProfileSummary &Summary = Reader->getSummary();
VerifySummary(Summary);
+ // Test that conversion of summary to and from Metadata works.
Metadata *MD = Summary.getMD(getGlobalContext());
ASSERT_TRUE(MD);
ProfileSummary *PS = ProfileSummary::getFromMD(MD);
@@ -134,6 +135,18 @@ struct SampleProfTest : ::testing::Test
SampleProfileSummary *SPS = cast<SampleProfileSummary>(PS);
VerifySummary(*SPS);
delete SPS;
+
+ // Test that summary can be attached to and read back from module.
+ Module M("my_module", getGlobalContext());
+ M.setProfileSummary(MD);
+ MD = M.getProfileSummary();
+ ASSERT_TRUE(MD);
+ PS = ProfileSummary::getFromMD(MD);
+ ASSERT_TRUE(PS);
+ ASSERT_TRUE(isa<SampleProfileSummary>(PS));
+ SPS = cast<SampleProfileSummary>(PS);
+ VerifySummary(*SPS);
+ delete SPS;
}
};
More information about the llvm-commits
mailing list