Disable my little CopyToReg argument hack with fast-isel. rdar://problem/9413587 .
authorEli Friedman <eli.friedman@gmail.com>
Tue, 10 May 2011 21:50:58 +0000 (21:50 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Tue, 10 May 2011 21:50:58 +0000 (21:50 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@131156 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp

index a01e2b86c2b7389b4313deb8a9fa30d5a44df6f3..e5329f76f1c50355504de1d1464cd7b347a0d9f3 100644 (file)
@@ -6440,10 +6440,11 @@ void SelectionDAGISel::LowerArguments(const BasicBlock *LLVMBB) {
 
     // If this argument is live outside of the entry block, insert a copy from
     // wherever we got it to the vreg that other BB's will reference it as.
-    if (Res.getOpcode() == ISD::CopyFromReg) {
+    if (!EnableFastISel && Res.getOpcode() == ISD::CopyFromReg) {
       // If we can, though, try to skip creating an unnecessary vreg.
       // FIXME: This isn't very clean... it would be nice to make this more
-      // general.
+      // general.  It's also subtly incompatible with the hacks FastISel
+      // uses with vregs.
       unsigned Reg = cast<RegisterSDNode>(Res.getOperand(1))->getReg();
       if (TargetRegisterInfo::isVirtualRegister(Reg)) {
         FuncInfo->ValueMap[I] = Reg;