diff options
author | Dan Gohman <gohman@apple.com> | 2008-08-27 20:41:38 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2008-08-27 20:41:38 +0000 |
commit | a318dabc0edbcc7a2b54d99b026a093361ec14fc (patch) | |
tree | 4d84639ac3a3e4258e690b815e3f9361f9898e9c /lib/CodeGen/SelectionDAG/FastISel.cpp | |
parent | df3b99381f1c211071cc1daf0cc297666877bbcb (diff) |
Fix FastISel's bitcast code for the case where getRegForValue fails.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55431 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/FastISel.cpp')
-rw-r--r-- | lib/CodeGen/SelectionDAG/FastISel.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/lib/CodeGen/SelectionDAG/FastISel.cpp b/lib/CodeGen/SelectionDAG/FastISel.cpp index 7d40405bd5..82eee56cd2 100644 --- a/lib/CodeGen/SelectionDAG/FastISel.cpp +++ b/lib/CodeGen/SelectionDAG/FastISel.cpp @@ -226,7 +226,10 @@ bool FastISel::SelectBitCast(Instruction *I, DenseMap<const Value*, unsigned> &ValueMap) { // If the bitcast doesn't change the type, just use the operand value. if (I->getType() == I->getOperand(0)->getType()) { - ValueMap[I] = getRegForValue(I->getOperand(0), ValueMap); + unsigned Reg = getRegForValue(I->getOperand(0), ValueMap); + if (Reg == 0) + return false; + ValueMap[I] = Reg; return true; } |