diff options
| author | Dan Gohman <gohman@apple.com> | 2010-05-03 23:36:34 +0000 |
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2010-05-03 23:36:34 +0000 |
| commit | 080b7d4073d554d405f9fd81d5a5bee529f755e6 (patch) | |
| tree | 0f638ff5229a8b966d57b7c527dbdb327aaed823 /lib/CodeGen | |
| parent | 140fb4490593aeb603ffb39e81919554c8daeff0 (diff) | |
| download | external_llvm-080b7d4073d554d405f9fd81d5a5bee529f755e6.zip external_llvm-080b7d4073d554d405f9fd81d5a5bee529f755e6.tar.gz external_llvm-080b7d4073d554d405f9fd81d5a5bee529f755e6.tar.bz2 | |
Factor out FastISel's code for materializing constants and other values
in registers into a separate function to de-couple it from the
top-down-specific logic in getRegForValue.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@102975 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
| -rw-r--r-- | lib/CodeGen/SelectionDAG/FastISel.cpp | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/lib/CodeGen/SelectionDAG/FastISel.cpp b/lib/CodeGen/SelectionDAG/FastISel.cpp index 49bfbff..b4c3833 100644 --- a/lib/CodeGen/SelectionDAG/FastISel.cpp +++ b/lib/CodeGen/SelectionDAG/FastISel.cpp @@ -84,6 +84,15 @@ unsigned FastISel::getRegForValue(const Value *V) { if (Reg != 0) return Reg; + return materializeRegForValue(V, VT); +} + +/// materializeRegForValue - Helper for getRegForVale. This function is +/// called when the value isn't already available in a register and must +/// be materialized with new instructions. +unsigned FastISel::materializeRegForValue(const Value *V, MVT VT) { + unsigned Reg = 0; + if (const ConstantInt *CI = dyn_cast<ConstantInt>(V)) { if (CI->getValue().getActiveBits() <= 64) Reg = FastEmit_i(VT, VT, ISD::Constant, CI->getZExtValue()); @@ -141,7 +150,7 @@ unsigned FastISel::lookUpRegForValue(const 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. + // def-dominates-use requirement enforced. if (ValueMap.count(V)) return ValueMap[V]; return LocalValueMap[V]; |
