Browse Source

Change basic block linking order to get better results (still not perfect)

cl-refactor
Paweł Bylica 10 years ago
parent
commit
3ec44144e5
  1. 32
      evmcc/Compiler.cpp

32
evmcc/Compiler.cpp

@ -5,6 +5,8 @@
#include <llvm/IR/IRBuilder.h> #include <llvm/IR/IRBuilder.h>
#include <llvm/IR/CFG.h> #include <llvm/IR/CFG.h>
#include <llvm/ADT/PostOrderIterator.h>
//#include <llvm/Transforms/Scalar.h>
#include <libevmface/Instruction.h> #include <libevmface/Instruction.h>
@ -901,36 +903,26 @@ void Compiler::linkBasicBlocks()
auto phi = llvm::cast<llvm::PHINode>(instIt); auto phi = llvm::cast<llvm::PHINode>(instIt);
for (auto predIt = llvm::pred_begin(_llbb); predIt != llvm::pred_end(_llbb); ++predIt) for (auto predIt = llvm::pred_begin(_llbb); predIt != llvm::pred_end(_llbb); ++predIt)
{ {
// TODO: In case entry block is reached - report error
auto& predBB = findBasicBlock(*predIt); auto& predBB = findBasicBlock(*predIt);
// assert(valueIdx < predBB.getStack().size()); // TODO: Report error auto value = predBB.getStack().get(valueIdx);
phi->addIncoming(predBB.getStack().get(valueIdx), predBB); phi->addIncoming(value, predBB);
} }
} }
}; };
// Link basic blocks
for (auto&& p : basicBlocks)
{
BasicBlock& bb = p.second;
completePhiNodes(bb.llvm());
}
completePhiNodes(m_jumpTableBlock->llvm());
/*
llvm::BasicBlock* llvmBB = bb.llvm();
size_t valueIdx = 0; // TODO: It is crappy visiting of basic blocks.
auto firstNonPhi = llvmBB->getFirstNonPHI(); llvm::SmallPtrSet<llvm::BasicBlock*, 32> visitSet;
for (auto instIt = llvmBB->begin(); &*instIt != firstNonPhi; ++instIt, ++valueIdx) for (auto&& bb : basicBlocks) // TODO: External loop is to visit unreable blocks that can also have phi nodes
{ {
auto phi = llvm::cast<llvm::PHINode>(instIt); for (auto it = llvm::po_ext_begin(bb.second.llvm(), visitSet),
for (auto predIt = llvm::pred_begin(llvmBB); predIt != llvm::pred_end(llvmBB); ++predIt) end = llvm::po_ext_end(bb.second.llvm(), visitSet); it != end; ++it)
{ {
auto& predBB = findBasicBlock(*predIt); std::cerr << it->getName().str() << std::endl;
assert(valueIdx < predBB.getStack().size()); // TODO: Report error completePhiNodes(*it);
phi->addIncoming(predBB.getStack().get(valueIdx), predBB);
} }
} }
*/
} }
} }

Loading…
Cancel
Save