summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-11-16 06:31:38 +0000
committerChris Lattner <sabre@nondot.org>2004-11-16 06:31:38 +0000
commit90c18c5c69d9c451e5fdca1e4b4b95e8ed13291a (patch)
treed9da08a621f44bf027cd25f377cbf57d540b824c /tools
parent8bf7fba10b60834d6edfa8d4666edd8cb73b043c (diff)
downloadllvm-90c18c5c69d9c451e5fdca1e4b4b95e8ed13291a.tar.gz
llvm-90c18c5c69d9c451e5fdca1e4b4b95e8ed13291a.tar.bz2
llvm-90c18c5c69d9c451e5fdca1e4b4b95e8ed13291a.tar.xz
Make this code not depend on LinkModules leaving the second argument unmolested.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17874 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools')
-rw-r--r--tools/bugpoint/ExtractFunction.cpp11
-rw-r--r--tools/bugpoint/ListReducer.h2
-rw-r--r--tools/bugpoint/Miscompilation.cpp50
3 files changed, 41 insertions, 22 deletions
diff --git a/tools/bugpoint/ExtractFunction.cpp b/tools/bugpoint/ExtractFunction.cpp
index d65736a1ea..bc38751048 100644
--- a/tools/bugpoint/ExtractFunction.cpp
+++ b/tools/bugpoint/ExtractFunction.cpp
@@ -143,9 +143,18 @@ Module *BugDriver::ExtractLoop(Module *M) {
// Check to see if we created any new functions. If not, no loops were
// extracted and we should return null.
- if (M->size() == NewM->size()) {
+ static unsigned NumExtracted = 15;
+
+ if (M->size() == NewM->size() || --NumExtracted == 0) {
delete NewM;
return 0;
+ } else {
+ assert(M->size() < NewM->size() && "Loop extract removed functions?");
+ Module::iterator MI = NewM->begin();
+ for (unsigned i = 0, e = M->size(); i != e; ++i)
+ ++MI;
+ for (; MI != NewM->end(); ++MI)
+ std::cerr << "NEW FUNCTION: " << *MI;
}
return NewM;
diff --git a/tools/bugpoint/ListReducer.h b/tools/bugpoint/ListReducer.h
index 9e248ff1cc..2af1ae769d 100644
--- a/tools/bugpoint/ListReducer.h
+++ b/tools/bugpoint/ListReducer.h
@@ -90,7 +90,7 @@ struct ListReducer {
// could. If there is more two elements in the list, try deleting interior
// elements and testing that.
//
- if (TheList.size() > 2) {
+ if (0 && TheList.size() > 2) {
bool Changed = true;
std::vector<ElTy> EmptyList;
while (Changed) {
diff --git a/tools/bugpoint/Miscompilation.cpp b/tools/bugpoint/Miscompilation.cpp
index ca4fb61826..b578202402 100644
--- a/tools/bugpoint/Miscompilation.cpp
+++ b/tools/bugpoint/Miscompilation.cpp
@@ -171,13 +171,16 @@ static bool TestMergedProgram(BugDriver &BD, Module *M1, Module *M2,
bool DeleteInputs) {
// Link the two portions of the program back to together.
std::string ErrorMsg;
- if (!DeleteInputs) M1 = CloneModule(M1);
+ if (!DeleteInputs) {
+ M1 = CloneModule(M1);
+ M2 = CloneModule(M2);
+ }
if (LinkModules(M1, M2, &ErrorMsg)) {
std::cerr << BD.getToolName() << ": Error linking modules together:"
<< ErrorMsg << '\n';
exit(1);
}
- if (DeleteInputs) delete M2; // We are done with this module...
+ delete M2; // We are done with this module.
Module *OldProgram = BD.swapProgramIn(M1);
@@ -289,6 +292,12 @@ static bool ExtractLoops(BugDriver &BD,
std::cout << "*** Loop extraction successful!\n";
+ std::vector<std::pair<std::string, const FunctionType*> > MisCompFunctions;
+ for (Module::iterator I = ToOptimizeLoopExtracted->begin(),
+ E = ToOptimizeLoopExtracted->end(); I != E; ++I)
+ MisCompFunctions.push_back(std::make_pair(I->getName(),
+ I->getFunctionType()));
+
// Okay, great! Now we know that we extracted a loop and that loop
// extraction both didn't break the program, and didn't mask the problem.
// Replace the current program with the loop extracted version, and try to
@@ -299,21 +308,18 @@ static bool ExtractLoops(BugDriver &BD,
<< ErrorMsg << '\n';
exit(1);
}
+ delete ToOptimizeLoopExtracted;
// All of the Function*'s in the MiscompiledFunctions list are in the old
// module. Update this list to include all of the functions in the
// optimized and loop extracted module.
MiscompiledFunctions.clear();
- for (Module::iterator I = ToOptimizeLoopExtracted->begin(),
- E = ToOptimizeLoopExtracted->end(); I != E; ++I) {
- if (!I->isExternal()) {
- Function *NewF = ToNotOptimize->getFunction(I->getName(),
- I->getFunctionType());
- assert(NewF && "Function not found??");
- MiscompiledFunctions.push_back(NewF);
- }
+ for (unsigned i = 0, e = MisCompFunctions.size(); i != e; ++i) {
+ Function *NewF = ToNotOptimize->getFunction(MisCompFunctions[i].first,
+ MisCompFunctions[i].second);
+ assert(NewF && "Function not found??");
+ MiscompiledFunctions.push_back(NewF);
}
- delete ToOptimizeLoopExtracted;
BD.setNewProgram(ToNotOptimize);
MadeChange = true;
@@ -423,12 +429,19 @@ static bool ExtractBlocks(BugDriver &BD,
// together.
delete ToExtract;
+ std::vector<std::pair<std::string, const FunctionType*> > MisCompFunctions;
+ for (Module::iterator I = Extracted->begin(), E = Extracted->end();
+ I != E; ++I)
+ MisCompFunctions.push_back(std::make_pair(I->getName(),
+ I->getFunctionType()));
+
std::string ErrorMsg;
if (LinkModules(ProgClone, Extracted, &ErrorMsg)) {
std::cerr << BD.getToolName() << ": Error linking modules together:"
<< ErrorMsg << '\n';
exit(1);
}
+ delete Extracted;
// Set the new program and delete the old one.
BD.setNewProgram(ProgClone);
@@ -436,15 +449,12 @@ static bool ExtractBlocks(BugDriver &BD,
// Update the list of miscompiled functions.
MiscompiledFunctions.clear();
- for (Module::iterator I = Extracted->begin(), E = Extracted->end(); I != E;
- ++I)
- if (!I->isExternal()) {
- Function *NF = ProgClone->getFunction(I->getName(), I->getFunctionType());
- assert(NF && "Mapped function not found!");
- MiscompiledFunctions.push_back(NF);
- }
-
- delete Extracted;
+ for (unsigned i = 0, e = MisCompFunctions.size(); i != e; ++i) {
+ Function *NewF = ProgClone->getFunction(MisCompFunctions[i].first,
+ MisCompFunctions[i].second);
+ assert(NewF && "Function not found??");
+ MiscompiledFunctions.push_back(NewF);
+ }
return true;
}