Add a machine instruction flag indicating the instruction can clobber condition code...
authorEvan Cheng <evan.cheng@apple.com>
Wed, 6 Jun 2007 10:13:55 +0000 (10:13 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Wed, 6 Jun 2007 10:13:55 +0000 (10:13 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@37464 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Target/TargetInstrInfo.h

index 5fe9130634b8cceff0b4fe70c070c998a7a997fc..f03fbb532143fd4608a8a83c595707794bb14c85 100644 (file)
@@ -82,6 +82,9 @@ const unsigned M_PREDICABLE = 1 << 12;
 // at any time, e.g. constant generation, load from constant pool.
 const unsigned M_REMATERIALIZIBLE = 1 << 13;
 
+// M_CLOBBERS_PRED - Set if this instruction may clobbers the condition code
+// register and / or registers that are used to predicate instructions.
+const unsigned M_CLOBBERS_PRED = 1 << 14;
 
 // Machine operand flags
 // M_LOOK_UP_PTR_REG_CLASS - Set if this operand is a pointer value and it
@@ -211,6 +214,9 @@ public:
   bool isPredicable(MachineOpCode Opcode) const {
     return get(Opcode).Flags & M_PREDICABLE;
   }
+  bool clobbersPredicate(MachineOpCode Opcode) const {
+    return get(Opcode).Flags & M_CLOBBERS_PRED;
+  }
   bool isReMaterializable(MachineOpCode Opcode) const {
     return get(Opcode).Flags & M_REMATERIALIZIBLE;
   }