[PATCH] D46095: [GlobalISel] Reporting rules covered as part of the InstructionSelect's debug-only printing
Roman Tereshin via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Apr 25 17:06:51 PDT 2018
rtereshin created this revision.
rtereshin added reviewers: dsanders, aemerson.
Herald added subscribers: llvm-commits, kristof.beyls, rovka.
The main goal of this change is to make it much easier to track which rules are actually covered by Testgen'erated regression tests.
Originally part of the larger https://reviews.llvm.org/D43962 ([GlobalISel][utils] Adding the init version of Instruction Select Testgen) patch, extracted as to make it smaller and more targeted.
Partially reviewed by @dsanders within the patch mentioned.
Repository:
rL LLVM
https://reviews.llvm.org/D46095
Files:
include/llvm/Support/CodeGenCoverage.h
lib/CodeGen/GlobalISel/InstructionSelect.cpp
lib/Support/CodeGenCoverage.cpp
Index: lib/Support/CodeGenCoverage.cpp
===================================================================
--- lib/Support/CodeGenCoverage.cpp
+++ lib/Support/CodeGenCoverage.cpp
@@ -38,12 +38,17 @@
RuleCoverage[RuleID] = true;
}
-bool CodeGenCoverage::isCovered(uint64_t RuleID) {
+bool CodeGenCoverage::isCovered(uint64_t RuleID) const {
if (RuleCoverage.size() <= RuleID)
return false;
return RuleCoverage[RuleID];
}
+iterator_range<CodeGenCoverage::const_covered_iterator>
+CodeGenCoverage::covered() const {
+ return RuleCoverage.set_bits();
+}
+
bool CodeGenCoverage::parse(MemoryBuffer &Buffer, StringRef BackendName) {
const char *CurPtr = Buffer.getBufferStart();
Index: lib/CodeGen/GlobalISel/InstructionSelect.cpp
===================================================================
--- lib/CodeGen/GlobalISel/InstructionSelect.cpp
+++ lib/CodeGen/GlobalISel/InstructionSelect.cpp
@@ -218,6 +218,12 @@
auto &TLI = *MF.getSubtarget().getTargetLowering();
TLI.finalizeLowering(MF);
+ DEBUG({
+ dbgs() << "Rules covered by selecting function: " << MF.getName() << ":";
+ for (auto RuleID : CoverageInfo.covered())
+ dbgs() << " id" << RuleID;
+ dbgs() << "\n\n";
+ });
CoverageInfo.emit(CoveragePrefix,
MF.getSubtarget()
.getTargetLowering()
Index: include/llvm/Support/CodeGenCoverage.h
===================================================================
--- include/llvm/Support/CodeGenCoverage.h
+++ include/llvm/Support/CodeGenCoverage.h
@@ -23,15 +23,18 @@
BitVector RuleCoverage;
public:
+ using const_covered_iterator = BitVector::const_set_bits_iterator;
+
CodeGenCoverage();
void setCovered(uint64_t RuleID);
- bool isCovered(uint64_t RuleID);
+ bool isCovered(uint64_t RuleID) const;
+ iterator_range<const_covered_iterator> covered() const;
bool parse(MemoryBuffer &Buffer, StringRef BackendName);
bool emit(StringRef FilePrefix, StringRef BackendName) const;
void reset();
};
-} // end namespace llvm
+} // namespace llvm
#endif // ifndef LLVM_SUPPORT_CODEGENCOVERAGE_H
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D46095.144039.patch
Type: text/x-patch
Size: 2122 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180426/1c61bb8d/attachment.bin>
More information about the llvm-commits
mailing list