Do trivial local CSE for constants and other non-Instruction values

in FastISel.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55748 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Dan Gohman 2008-09-03 23:32:19 +00:00
parent 2a7c671e2e
commit 104e4ce162
2 changed files with 16 additions and 12 deletions

View File

@ -36,6 +36,7 @@ class TargetRegisterClass;
class FastISel { class FastISel {
protected: protected:
MachineBasicBlock *MBB; MachineBasicBlock *MBB;
DenseMap<const Value *, unsigned> LocalValueMap;
DenseMap<const Value *, unsigned> &ValueMap; DenseMap<const Value *, unsigned> &ValueMap;
DenseMap<const BasicBlock *, MachineBasicBlock *> &MBBMap; DenseMap<const BasicBlock *, MachineBasicBlock *> &MBBMap;
MachineFunction &MF; MachineFunction &MF;

View File

@ -21,13 +21,16 @@
#include "llvm/Target/TargetMachine.h" #include "llvm/Target/TargetMachine.h"
using namespace llvm; using namespace llvm;
// Don't cache constant materializations. To do so would require
// tracking what uses they dominate. Non-constants, however, already
// have the SSA def-doms-use requirement enforced, so we can cache their
// computations.
unsigned FastISel::getRegForValue(Value *V) { unsigned FastISel::getRegForValue(Value *V) {
// Look up the value to see if we already have a register for it. We
// cache values defined by Instructions across blocks, and other values
// only locally. This is because Instructions already have the SSA
// def-dominatess-use requirement enforced.
if (ValueMap.count(V)) if (ValueMap.count(V))
return ValueMap[V]; return ValueMap[V];
unsigned Reg = LocalValueMap[V];
if (Reg != 0)
return Reg;
MVT::SimpleValueType VT = TLI.getValueType(V->getType()).getSimpleVT(); MVT::SimpleValueType VT = TLI.getValueType(V->getType()).getSimpleVT();
if (ConstantInt *CI = dyn_cast<ConstantInt>(V)) { if (ConstantInt *CI = dyn_cast<ConstantInt>(V)) {
@ -35,11 +38,11 @@ unsigned FastISel::getRegForValue(Value *V) {
return 0; return 0;
// Don't cache constant materializations. To do so would require // Don't cache constant materializations. To do so would require
// tracking what uses they dominate. // tracking what uses they dominate.
return FastEmit_i(VT, VT, ISD::Constant, CI->getZExtValue()); Reg = FastEmit_i(VT, VT, ISD::Constant, CI->getZExtValue());
} else if (isa<ConstantPointerNull>(V)) { } else if (isa<ConstantPointerNull>(V)) {
return FastEmit_i(VT, VT, ISD::Constant, 0); Reg = FastEmit_i(VT, VT, ISD::Constant, 0);
} else if (ConstantFP *CF = dyn_cast<ConstantFP>(V)) { } else if (ConstantFP *CF = dyn_cast<ConstantFP>(V)) {
unsigned Reg = FastEmit_f(VT, VT, ISD::ConstantFP, CF); Reg = FastEmit_f(VT, VT, ISD::ConstantFP, CF);
if (!Reg) { if (!Reg) {
const APFloat &Flt = CF->getValueAPF(); const APFloat &Flt = CF->getValueAPF();
@ -60,15 +63,15 @@ unsigned FastISel::getRegForValue(Value *V) {
if (Reg == 0) if (Reg == 0)
return 0; return 0;
} }
return Reg;
} else if (isa<UndefValue>(V)) { } else if (isa<UndefValue>(V)) {
unsigned Reg = createResultReg(TLI.getRegClassFor(VT)); Reg = createResultReg(TLI.getRegClassFor(VT));
BuildMI(MBB, TII.get(TargetInstrInfo::IMPLICIT_DEF), Reg); BuildMI(MBB, TII.get(TargetInstrInfo::IMPLICIT_DEF), Reg);
return Reg; } else {
return 0;
} }
return 0; LocalValueMap[V] = Reg;
return Reg;
} }
/// UpdateValueMap - Update the value map to include the new mapping for this /// UpdateValueMap - Update the value map to include the new mapping for this