Make this code not depend on LinkModules leaving the second argument unmolested.

llvm-svn: 17874
This commit is contained in:
Chris Lattner 2004-11-16 06:31:38 +00:00
parent 09e9f2a37b
commit d308797cae
3 changed files with 41 additions and 22 deletions

View File

@ -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;

View File

@ -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) {

View File

@ -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;
}