forked from OSchip/llvm-project
Just roll back the previous change to -mem2reg.
Will re-think about this according to Chris's comments. llvm-svn: 65126
This commit is contained in:
parent
d0b80c8c75
commit
053737e1ae
|
@ -16,7 +16,6 @@
|
|||
#include "llvm/Transforms/Scalar.h"
|
||||
#include "llvm/Transforms/Utils/PromoteMemToReg.h"
|
||||
#include "llvm/Transforms/Utils/UnifyFunctionExitNodes.h"
|
||||
#include "llvm/IntrinsicInst.h"
|
||||
#include "llvm/Analysis/Dominators.h"
|
||||
#include "llvm/Instructions.h"
|
||||
#include "llvm/Function.h"
|
||||
|
@ -54,30 +53,6 @@ namespace {
|
|||
char PromotePass::ID = 0;
|
||||
static RegisterPass<PromotePass> X("mem2reg", "Promote Memory to Register");
|
||||
|
||||
/// Remove the invalid or redundant debug information.
|
||||
static void CleanDbgInfo(Function& F) {
|
||||
std::vector<Instruction*> DeadDbgs;
|
||||
for (Function::iterator BBI = F.begin(), BBE = F.end(); BBI != BBE; ++BBI) {
|
||||
if (BBI->size() <= 1)
|
||||
continue;
|
||||
for (BasicBlock::iterator I = BBI->begin(), E = BBI->getTerminator();
|
||||
I != E; ++I) {
|
||||
BasicBlock::iterator NextI = I;
|
||||
++NextI;
|
||||
if (isa<DbgStopPointInst>(I) && isa<DbgStopPointInst>(NextI))
|
||||
DeadDbgs.push_back(I);
|
||||
else if (isa<DbgStopPointInst>(I) && isa<BranchInst>(NextI))
|
||||
DeadDbgs.push_back(I);
|
||||
}
|
||||
}
|
||||
|
||||
while (!DeadDbgs.empty()) {
|
||||
Instruction *Inst = DeadDbgs.back();
|
||||
DeadDbgs.pop_back();
|
||||
Inst->eraseFromParent();
|
||||
}
|
||||
}
|
||||
|
||||
bool PromotePass::runOnFunction(Function &F) {
|
||||
std::vector<AllocaInst*> Allocas;
|
||||
|
||||
|
@ -101,7 +76,6 @@ bool PromotePass::runOnFunction(Function &F) {
|
|||
if (Allocas.empty()) break;
|
||||
|
||||
PromoteMemToReg(Allocas, DT, DF);
|
||||
CleanDbgInfo(F);
|
||||
NumPromoted += Allocas.size();
|
||||
Changed = true;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue