[PATCH] D66257: [Bugpoint redesign] Modified Functions pass to consider declarations
Phabricator via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Aug 14 15:21:42 PDT 2019
This revision was automatically updated to reflect the committed changes.
Closed by commit rL368934: [Bugpoint redesign] Modified Functions pass to consider declarations (authored by diegotf30, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D66257?vs=215257&id=215267#toc
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D66257/new/
https://reviews.llvm.org/D66257
Files:
llvm/trunk/test/Reduce/remove-funcs.ll
llvm/trunk/tools/llvm-reduce/deltas/ReduceFunctions.cpp
Index: llvm/trunk/tools/llvm-reduce/deltas/ReduceFunctions.cpp
===================================================================
--- llvm/trunk/tools/llvm-reduce/deltas/ReduceFunctions.cpp
+++ llvm/trunk/tools/llvm-reduce/deltas/ReduceFunctions.cpp
@@ -22,7 +22,7 @@
std::set<Function *> FuncsToKeep;
unsigned I = 0, FunctionCount = 0;
for (auto &F : *Program)
- if (!F.isDeclaration() && I < ChunksToKeep.size()) {
+ if (I < ChunksToKeep.size()) {
if (ChunksToKeep[I].contains(++FunctionCount))
FuncsToKeep.insert(&F);
if (FunctionCount == ChunksToKeep[I].end)
@@ -31,41 +31,34 @@
// Delete out-of-chunk functions, and replace their calls with undef
std::vector<Function *> FuncsToRemove;
+ std::vector<CallInst *> CallsToRemove;
for (auto &F : *Program)
- if (!F.isDeclaration() && !FuncsToKeep.count(&F)) {
+ if (!FuncsToKeep.count(&F)) {
+ for (auto U : F.users())
+ if (auto *Call = dyn_cast<CallInst>(U)) {
+ Call->replaceAllUsesWith(UndefValue::get(Call->getType()));
+ CallsToRemove.push_back(Call);
+ }
F.replaceAllUsesWith(UndefValue::get(F.getType()));
FuncsToRemove.push_back(&F);
}
+ for (auto *C : CallsToRemove)
+ C->eraseFromParent();
+
for (auto *F : FuncsToRemove)
F->eraseFromParent();
-
- // Delete instructions with undef calls
- std::vector<Instruction *> InstToRemove;
- for (auto &F : *Program)
- for (auto &BB : F)
- for (auto &I : BB)
- if (auto *Call = dyn_cast<CallInst>(&I))
- if (!Call->getCalledFunction()) {
- // Instruction might be stored / used somewhere else
- I.replaceAllUsesWith(UndefValue::get(I.getType()));
- InstToRemove.push_back(&I);
- }
-
- for (auto *I : InstToRemove)
- I->eraseFromParent();
}
/// Counts the amount of non-declaration functions and prints their
/// respective name & index
-static unsigned countDefinedFunctions(Module *Program) {
+static unsigned countFunctions(Module *Program) {
// TODO: Silence index with --quiet flag
outs() << "----------------------------\n";
outs() << "Function Index Reference:\n";
unsigned FunctionCount = 0;
for (auto &F : *Program)
- if (!F.isDeclaration())
- outs() << "\t" << ++FunctionCount << ": " << F.getName() << "\n";
+ outs() << "\t" << ++FunctionCount << ": " << F.getName() << "\n";
outs() << "----------------------------\n";
return FunctionCount;
@@ -73,7 +66,7 @@
void llvm::reduceFunctionsDeltaPass(TestRunner &Test) {
outs() << "*** Reducing Functions...\n";
- unsigned Functions = countDefinedFunctions(Test.getProgram());
+ unsigned Functions = countFunctions(Test.getProgram());
runDeltaPass(Test, Functions, extractFunctionsFromModule);
outs() << "----------------------------\n";
-}
+}
\ No newline at end of file
Index: llvm/trunk/test/Reduce/remove-funcs.ll
===================================================================
--- llvm/trunk/test/Reduce/remove-funcs.ll
+++ llvm/trunk/test/Reduce/remove-funcs.ll
@@ -28,7 +28,4 @@
}
; CHECK-NOT: uninteresting3()
-define i32 @uninteresting3() {
-entry:
- ret i32 10
-}
+declare void @uninteresting3()
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D66257.215267.patch
Type: text/x-patch
Size: 3226 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190814/f6c0c0ef/attachment.bin>
More information about the llvm-commits
mailing list