copyFastMathFlags utility and test case
authorMichael Ilseman <milseman@apple.com>
Thu, 29 Nov 2012 21:25:12 +0000 (21:25 +0000)
committerMichael Ilseman <milseman@apple.com>
Thu, 29 Nov 2012 21:25:12 +0000 (21:25 +0000)
llvm-svn: 168943

llvm/include/llvm/Instruction.h
llvm/lib/VMCore/Instruction.cpp
llvm/unittests/VMCore/IRBuilderTest.cpp

index 2c1d41c..0f717ad 100644 (file)
@@ -227,6 +227,9 @@ public:
   /// these flats.
   FastMathFlags getFastMathFlags() const;
 
+  /// Copy I's fast-math flags
+  void copyFastMathFlags(const Instruction *I);
+
 private:
   /// hasMetadataHashEntry - Return true if we have an entry in the on-the-side
   /// metadata hash.
index d93c1d7..7b73e77 100644 (file)
@@ -177,6 +177,12 @@ FastMathFlags Instruction::getFastMathFlags() const {
   return cast<FPMathOperator>(this)->getFastMathFlags();
 }
 
+/// Copy I's fast-math flags
+void Instruction::copyFastMathFlags(const Instruction *I) {
+  setFastMathFlags(I->getFastMathFlags());
+}
+
+
 const char *Instruction::getOpcodeName(unsigned OpCode) {
   switch (OpCode) {
   // Terminators
index 8a22b10..665cfb3 100644 (file)
@@ -164,6 +164,15 @@ TEST_F(IRBuilderTest, FastMathFlags) {
   FDiv = cast<Instruction>(F);
   EXPECT_TRUE(FDiv->hasAllowReciprocal());
 
+  Builder.clearFastMathFlags();
+
+  F = Builder.CreateFDiv(F, F);
+  ASSERT_TRUE(isa<Instruction>(F));
+  FDiv = cast<Instruction>(F);
+  EXPECT_FALSE(FDiv->getFastMathFlags().any());
+  FDiv->copyFastMathFlags(FAdd);
+  EXPECT_TRUE(FDiv->hasNoNaNs());
+
 }
 
 }