| //===- llvm/unittest/VMCore/InstructionsTest.cpp - Instructions unit tests ===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "llvm/Instructions.h" |
| #include "llvm/BasicBlock.h" |
| #include "llvm/Constants.h" |
| #include "llvm/DerivedTypes.h" |
| #include "llvm/LLVMContext.h" |
| #include "llvm/ADT/STLExtras.h" |
| #include "gtest/gtest.h" |
| |
| namespace llvm { |
| namespace { |
| |
| TEST(InstructionsTest, ReturnInst) { |
| LLVMContext &C(getGlobalContext()); |
| |
| // test for PR6589 |
| const ReturnInst* r0 = ReturnInst::Create(C); |
| EXPECT_EQ(r0->getNumOperands(), 0U); |
| EXPECT_EQ(r0->op_begin(), r0->op_end()); |
| |
| IntegerType* Int1 = IntegerType::get(C, 1); |
| Constant* One = ConstantInt::get(Int1, 1, true); |
| const ReturnInst* r1 = ReturnInst::Create(C, One); |
| EXPECT_EQ(1U, r1->getNumOperands()); |
| User::const_op_iterator b(r1->op_begin()); |
| EXPECT_NE(r1->op_end(), b); |
| EXPECT_EQ(One, *b); |
| EXPECT_EQ(One, r1->getOperand(0)); |
| ++b; |
| EXPECT_EQ(r1->op_end(), b); |
| |
| // clean up |
| delete r0; |
| delete r1; |
| } |
| |
| TEST(InstructionsTest, BranchInst) { |
| LLVMContext &C(getGlobalContext()); |
| |
| // Make a BasicBlocks |
| BasicBlock* bb0 = BasicBlock::Create(C); |
| BasicBlock* bb1 = BasicBlock::Create(C); |
| |
| // Mandatory BranchInst |
| const BranchInst* b0 = BranchInst::Create(bb0); |
| |
| EXPECT_TRUE(b0->isUnconditional()); |
| EXPECT_FALSE(b0->isConditional()); |
| EXPECT_EQ(1U, b0->getNumSuccessors()); |
| |
| // check num operands |
| EXPECT_EQ(1U, b0->getNumOperands()); |
| |
| EXPECT_NE(b0->op_begin(), b0->op_end()); |
| EXPECT_EQ(b0->op_end(), llvm::next(b0->op_begin())); |
| |
| EXPECT_EQ(b0->op_end(), llvm::next(b0->op_begin())); |
| |
| IntegerType* Int1 = IntegerType::get(C, 1); |
| Constant* One = ConstantInt::get(Int1, 1, true); |
| |
| // Conditional BranchInst |
| BranchInst* b1 = BranchInst::Create(bb0, bb1, One); |
| |
| EXPECT_FALSE(b1->isUnconditional()); |
| EXPECT_TRUE(b1->isConditional()); |
| EXPECT_EQ(2U, b1->getNumSuccessors()); |
| |
| // check num operands |
| EXPECT_EQ(3U, b1->getNumOperands()); |
| |
| User::const_op_iterator b(b1->op_begin()); |
| |
| // check COND |
| EXPECT_NE(b, b1->op_end()); |
| EXPECT_EQ(One, *b); |
| EXPECT_EQ(One, b1->getOperand(0)); |
| EXPECT_EQ(One, b1->getCondition()); |
| ++b; |
| |
| // check ELSE |
| EXPECT_EQ(bb1, *b); |
| EXPECT_EQ(bb1, b1->getOperand(1)); |
| EXPECT_EQ(bb1, b1->getSuccessor(1)); |
| ++b; |
| |
| // check THEN |
| EXPECT_EQ(bb0, *b); |
| EXPECT_EQ(bb0, b1->getOperand(2)); |
| EXPECT_EQ(bb0, b1->getSuccessor(0)); |
| ++b; |
| |
| EXPECT_EQ(b1->op_end(), b); |
| |
| // clean up |
| delete b0; |
| delete b1; |
| |
| delete bb0; |
| delete bb1; |
| } |
| |
| TEST(InstructionsTest, CastInst) { |
| LLVMContext &C(getGlobalContext()); |
| |
| Type* Int8Ty = Type::getInt8Ty(C); |
| Type* Int64Ty = Type::getInt64Ty(C); |
| Type* V8x8Ty = VectorType::get(Int8Ty, 8); |
| Type* V8x64Ty = VectorType::get(Int64Ty, 8); |
| Type* X86MMXTy = Type::getX86_MMXTy(C); |
| |
| const Constant* c8 = Constant::getNullValue(V8x8Ty); |
| const Constant* c64 = Constant::getNullValue(V8x64Ty); |
| |
| EXPECT_TRUE(CastInst::isCastable(V8x8Ty, X86MMXTy)); |
| EXPECT_TRUE(CastInst::isCastable(X86MMXTy, V8x8Ty)); |
| EXPECT_FALSE(CastInst::isCastable(Int64Ty, X86MMXTy)); |
| EXPECT_TRUE(CastInst::isCastable(V8x64Ty, V8x8Ty)); |
| EXPECT_TRUE(CastInst::isCastable(V8x8Ty, V8x64Ty)); |
| EXPECT_EQ(CastInst::Trunc, CastInst::getCastOpcode(c64, true, V8x8Ty, true)); |
| EXPECT_EQ(CastInst::SExt, CastInst::getCastOpcode(c8, true, V8x64Ty, true)); |
| } |
| |
| } // end anonymous namespace |
| } // end namespace llvm |