Add all implicit defs to FP_REG_KILL mi.
authorEvan Cheng <evan.cheng@apple.com>
Sat, 11 Nov 2006 07:19:36 +0000 (07:19 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Sat, 11 Nov 2006 07:19:36 +0000 (07:19 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31674 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/X86ISelDAGToDAG.cpp

index 68b89a4d160f48f81be2466eedc1acb21f696ddf..ddc730d9593e25479756c93a7c87342b5b70a6b7 100644 (file)
@@ -525,7 +525,12 @@ void X86DAGToDAGISel::InstructionSelectBasicBlock(SelectionDAG &DAG) {
 
     // Finally, if we found any FP code, emit the FP_REG_KILL instruction.
     if (ContainsFPCode) {
-      BuildMI(*BB, BB->getFirstTerminator(), X86::FP_REG_KILL, 0);
+      const TargetInstrDescriptor &II= TM.getInstrInfo()->get(X86::FP_REG_KILL);
+      MachineInstrBuilder MIB =
+        BuildMI(*BB, BB->getFirstTerminator(), X86::FP_REG_KILL, 0);
+      for (const unsigned *ImplicitDefs = II.ImplicitDefs;
+           *ImplicitDefs; ++ImplicitDefs)
+        MIB = MIB.addReg(*ImplicitDefs, true, true);
       ++NumFPKill;
     }
   }