diff options
author | Duncan Sands <baldrick@free.fr> | 2012-04-16 16:28:59 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2012-04-16 16:28:59 +0000 |
commit | 8883c43ddc13e5f92ba8dfe00f2116a153a570d5 (patch) | |
tree | 40b5bad6be11275bb56cb7f227d1e4ee6544718d /unittests | |
parent | 9e67db4af13abb967cae5858502207a43d26bf84 (diff) | |
download | external_llvm-8883c43ddc13e5f92ba8dfe00f2116a153a570d5.zip external_llvm-8883c43ddc13e5f92ba8dfe00f2116a153a570d5.tar.gz external_llvm-8883c43ddc13e5f92ba8dfe00f2116a153a570d5.tar.bz2 |
Make it possible to indicate relaxed floating point requirements at the IR level
through the use of 'fpmath' metadata. Currently this only provides a 'fpaccuracy'
value, which may be a number in ULPs or the keyword 'fast', however the intent is
that this will be extended with additional information about NaN's, infinities
etc later. No optimizations have been hooked up to this so far.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@154822 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'unittests')
-rw-r--r-- | unittests/Support/MDBuilderTest.cpp | 64 | ||||
-rw-r--r-- | unittests/VMCore/InstructionsTest.cpp | 25 |
2 files changed, 70 insertions, 19 deletions
diff --git a/unittests/Support/MDBuilderTest.cpp b/unittests/Support/MDBuilderTest.cpp index 44218d3..e8e0386 100644 --- a/unittests/Support/MDBuilderTest.cpp +++ b/unittests/Support/MDBuilderTest.cpp @@ -8,6 +8,8 @@ //===----------------------------------------------------------------------===// #include "gtest/gtest.h" +#include "llvm/Operator.h" +#include "llvm/Support/IRBuilder.h" #include "llvm/Support/MDBuilder.h" using namespace llvm; @@ -18,19 +20,43 @@ protected: LLVMContext Context; }; -TEST_F(MDBuilderTest, CreateString) { +TEST_F(MDBuilderTest, createString) { MDBuilder MDHelper(Context); - MDString *Str0 = MDHelper.CreateString(""); - MDString *Str1 = MDHelper.CreateString("string"); + MDString *Str0 = MDHelper.createString(""); + MDString *Str1 = MDHelper.createString("string"); EXPECT_EQ(Str0->getString(), StringRef("")); EXPECT_EQ(Str1->getString(), StringRef("string")); } - -TEST_F(MDBuilderTest, CreateRangeMetadata) { +TEST_F(MDBuilderTest, createFastFPMath) { + MDBuilder MDHelper(Context); + MDNode *MD = MDHelper.createFastFPMath(); + EXPECT_NE(MD, (MDNode *)0); + EXPECT_EQ(MD->getNumOperands(), 1U); + Value *Op = MD->getOperand(0); + EXPECT_TRUE(isa<MDString>(Op)); + EXPECT_EQ(cast<MDString>(Op)->getString(), "fast"); +} +TEST_F(MDBuilderTest, createFPMath) { + MDBuilder MDHelper(Context); + MDNode *MD0 = MDHelper.createFPMath(0.0); + MDNode *MD1 = MDHelper.createFPMath(1.0); + MDNode *MDF = MDHelper.createFPMath(-1.0); + MDNode *MDF2 = MDHelper.createFastFPMath(); + EXPECT_EQ(MD0, (MDNode *)0); + EXPECT_NE(MD1, (MDNode *)0); + EXPECT_EQ(MDF, MDF2); + EXPECT_EQ(MD1->getNumOperands(), 1U); + Value *Op = MD1->getOperand(0); + EXPECT_TRUE(isa<ConstantFP>(Op)); + EXPECT_TRUE(Op->getType()->isFloatingPointTy()); + ConstantFP *Val = cast<ConstantFP>(Op); + EXPECT_TRUE(Val->isExactlyValue(1.0)); +} +TEST_F(MDBuilderTest, createRangeMetadata) { MDBuilder MDHelper(Context); APInt A(8, 1), B(8, 2); - MDNode *R0 = MDHelper.CreateRange(A, A); - MDNode *R1 = MDHelper.CreateRange(A, B); + MDNode *R0 = MDHelper.createRange(A, A); + MDNode *R1 = MDHelper.createRange(A, B); EXPECT_EQ(R0, (MDNode *)0); EXPECT_NE(R1, (MDNode *)0); EXPECT_EQ(R1->getNumOperands(), 2U); @@ -41,10 +67,10 @@ TEST_F(MDBuilderTest, CreateRangeMetadata) { EXPECT_EQ(C0->getValue(), A); EXPECT_EQ(C1->getValue(), B); } -TEST_F(MDBuilderTest, CreateAnonymousTBAARoot) { +TEST_F(MDBuilderTest, createAnonymousTBAARoot) { MDBuilder MDHelper(Context); - MDNode *R0 = MDHelper.CreateAnonymousTBAARoot(); - MDNode *R1 = MDHelper.CreateAnonymousTBAARoot(); + MDNode *R0 = MDHelper.createAnonymousTBAARoot(); + MDNode *R1 = MDHelper.createAnonymousTBAARoot(); EXPECT_NE(R0, R1); EXPECT_GE(R0->getNumOperands(), 1U); EXPECT_GE(R1->getNumOperands(), 1U); @@ -53,23 +79,23 @@ TEST_F(MDBuilderTest, CreateAnonymousTBAARoot) { EXPECT_TRUE(R0->getNumOperands() == 1 || R0->getOperand(1) == 0); EXPECT_TRUE(R1->getNumOperands() == 1 || R1->getOperand(1) == 0); } -TEST_F(MDBuilderTest, CreateTBAARoot) { +TEST_F(MDBuilderTest, createTBAARoot) { MDBuilder MDHelper(Context); - MDNode *R0 = MDHelper.CreateTBAARoot("Root"); - MDNode *R1 = MDHelper.CreateTBAARoot("Root"); + MDNode *R0 = MDHelper.createTBAARoot("Root"); + MDNode *R1 = MDHelper.createTBAARoot("Root"); EXPECT_EQ(R0, R1); EXPECT_GE(R0->getNumOperands(), 1U); EXPECT_TRUE(isa<MDString>(R0->getOperand(0))); EXPECT_EQ(cast<MDString>(R0->getOperand(0))->getString(), "Root"); EXPECT_TRUE(R0->getNumOperands() == 1 || R0->getOperand(1) == 0); } -TEST_F(MDBuilderTest, CreateTBAANode) { +TEST_F(MDBuilderTest, createTBAANode) { MDBuilder MDHelper(Context); - MDNode *R = MDHelper.CreateTBAARoot("Root"); - MDNode *N0 = MDHelper.CreateTBAANode("Node", R); - MDNode *N1 = MDHelper.CreateTBAANode("edoN", R); - MDNode *N2 = MDHelper.CreateTBAANode("Node", R, true); - MDNode *N3 = MDHelper.CreateTBAANode("Node", R); + MDNode *R = MDHelper.createTBAARoot("Root"); + MDNode *N0 = MDHelper.createTBAANode("Node", R); + MDNode *N1 = MDHelper.createTBAANode("edoN", R); + MDNode *N2 = MDHelper.createTBAANode("Node", R, true); + MDNode *N3 = MDHelper.createTBAANode("Node", R); EXPECT_EQ(N0, N3); EXPECT_NE(N0, N1); EXPECT_NE(N0, N2); diff --git a/unittests/VMCore/InstructionsTest.cpp b/unittests/VMCore/InstructionsTest.cpp index 218a9a0..9c0cb44 100644 --- a/unittests/VMCore/InstructionsTest.cpp +++ b/unittests/VMCore/InstructionsTest.cpp @@ -12,8 +12,11 @@ #include "llvm/Constants.h" #include "llvm/DerivedTypes.h" #include "llvm/LLVMContext.h" +#include "llvm/Operator.h" #include "llvm/ADT/STLExtras.h" #include "llvm/Analysis/ValueTracking.h" +#include "llvm/Support/MDBuilder.h" +#include "llvm/Support/IRBuilder.h" #include "llvm/Target/TargetData.h" #include "gtest/gtest.h" @@ -226,5 +229,27 @@ TEST(InstructionsTest, VectorGep) { delete PtrVecB; } +TEST(InstructionsTest, FPMathOperator) { + LLVMContext &Context = getGlobalContext(); + IRBuilder<> Builder(Context); + MDBuilder MDHelper(Context); + Instruction *I = Builder.CreatePHI(Builder.getDoubleTy(), 0); + MDNode *MD1 = MDHelper.createFPMath(1.0); + MDNode *MDF = MDHelper.createFastFPMath(); + Value *V1 = Builder.CreateFAdd(I, I, "", MD1); + Value *VF = Builder.CreateFAdd(I, I, "", MDF); + EXPECT_TRUE(isa<FPMathOperator>(V1)); + EXPECT_TRUE(isa<FPMathOperator>(VF)); + FPMathOperator *O1 = cast<FPMathOperator>(V1); + FPMathOperator *OF = cast<FPMathOperator>(VF); + EXPECT_FALSE(O1->isFastFPAccuracy()); + EXPECT_TRUE(OF->isFastFPAccuracy()); + EXPECT_EQ(O1->getFPAccuracy(), 1.0); + EXPECT_GT(OF->getFPAccuracy(), 999.0); + delete V1; + delete VF; + delete I; +} + } // end anonymous namespace } // end namespace llvm |