[llvm-commits] [llvm] r168814 - /llvm/trunk/unittests/VMCore/IRBuilderTest.cpp
Michael Ilseman
milseman at apple.com
Wed Nov 28 13:17:34 PST 2012
Author: milseman
Date: Wed Nov 28 15:17:34 2012
New Revision: 168814
URL: http://llvm.org/viewvc/llvm-project?rev=168814&view=rev
Log:
Fast-math: IRBuilder test for creating instructions with fast-math flags
Modified:
llvm/trunk/unittests/VMCore/IRBuilderTest.cpp
Modified: llvm/trunk/unittests/VMCore/IRBuilderTest.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/VMCore/IRBuilderTest.cpp?rev=168814&r1=168813&r2=168814&view=diff
==============================================================================
--- llvm/trunk/unittests/VMCore/IRBuilderTest.cpp (original)
+++ llvm/trunk/unittests/VMCore/IRBuilderTest.cpp Wed Nov 28 15:17:34 2012
@@ -31,6 +31,8 @@
/*isVarArg=*/false);
F = Function::Create(FTy, Function::ExternalLinkage, "", M.get());
BB = BasicBlock::Create(getGlobalContext(), "", F);
+ GV = new GlobalVariable(Type::getFloatTy(getGlobalContext()), true,
+ GlobalValue::ExternalLinkage);
}
virtual void TearDown() {
@@ -41,6 +43,7 @@
OwningPtr<Module> M;
Function *F;
BasicBlock *BB;
+ GlobalVariable *GV;
};
TEST_F(IRBuilderTest, Lifetime) {
@@ -108,4 +111,59 @@
EXPECT_EQ(IntPtrTy, IntegerType::get(getGlobalContext(), IntPtrBitSize));
}
+TEST_F(IRBuilderTest, FastMathFlags) {
+ IRBuilder<> Builder(BB);
+ Value *F;
+ Instruction *FDiv, *FAdd;
+
+ F = Builder.CreateLoad(GV);
+ F = Builder.CreateFAdd(F, F);
+
+ EXPECT_FALSE(Builder.GetFastMathFlags().any());
+ ASSERT_TRUE(isa<Instruction>(F));
+ FAdd = cast<Instruction>(F);
+ EXPECT_FALSE(FAdd->hasNoNaNs());
+
+ FastMathFlags FMF;
+ Builder.SetFastMathFlags(FMF);
+
+ F = Builder.CreateFAdd(F, F);
+ EXPECT_FALSE(Builder.GetFastMathFlags().any());
+
+ FMF.UnsafeAlgebra = true;
+ Builder.SetFastMathFlags(FMF);
+
+ F = Builder.CreateFAdd(F, F);
+ EXPECT_TRUE(Builder.GetFastMathFlags().any());
+ ASSERT_TRUE(isa<Instruction>(F));
+ FAdd = cast<Instruction>(F);
+ EXPECT_TRUE(FAdd->hasNoNaNs());
+
+ F = Builder.CreateFDiv(F, F);
+ EXPECT_TRUE(Builder.GetFastMathFlags().any());
+ EXPECT_TRUE(Builder.GetFastMathFlags().UnsafeAlgebra);
+ ASSERT_TRUE(isa<Instruction>(F));
+ 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->hasAllowReciprocal());
+
+ FMF.clear();
+ FMF.AllowReciprocal = true;
+ Builder.SetFastMathFlags(FMF);
+
+ F = Builder.CreateFDiv(F, F);
+ EXPECT_TRUE(Builder.GetFastMathFlags().any());
+ EXPECT_TRUE(Builder.GetFastMathFlags().AllowReciprocal);
+ ASSERT_TRUE(isa<Instruction>(F));
+ FDiv = cast<Instruction>(F);
+ EXPECT_TRUE(FDiv->hasAllowReciprocal());
+
+}
+
}
More information about the llvm-commits
mailing list