Hexagon: Clear isKill flag on the predicate register in
authorJyotsna Verma <jverma@codeaurora.org>
Wed, 1 May 2013 21:27:30 +0000 (21:27 +0000)
committerJyotsna Verma <jverma@codeaurora.org>
Wed, 1 May 2013 21:27:30 +0000 (21:27 +0000)
PredicateInstruction function.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@180884 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/Hexagon/HexagonInstrInfo.cpp

index 725fc8a5bd0e2d4699dc1d16f5f27de5becb29fb..7a0268afd7c8c27b03c4fe3b1484179066aa6efc 100644 (file)
@@ -1811,11 +1811,15 @@ PredicateInstruction(MachineInstr *MI,
   // It is better to have an assert here to check this. But I don't know how
   // to write this assert because findFirstPredOperandIdx() would return -1
   if (oper < -1) oper = -1;
+
   MI->getOperand(oper+1).ChangeToRegister(PredMO.getReg(), PredMO.isDef(),
-                                          PredMO.isImplicit(), PredMO.isKill(),
+                                          PredMO.isImplicit(), false,
                                           PredMO.isDead(), PredMO.isUndef(),
                                           PredMO.isDebug());
 
+  MachineRegisterInfo &RegInfo = MI->getParent()->getParent()->getRegInfo();
+  RegInfo.clearKillFlags(PredMO.getReg());
+
   if (hasGAOpnd)
   {
     unsigned int i;