mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
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:
parent
2a7c671e2e
commit
104e4ce162
@ -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;
|
||||||
|
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user