diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2013-04-12 08:33:11 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2013-04-12 08:33:11 +0000 |
commit | 71c1b228552ece06003d744b815f669dbfbb0772 (patch) | |
tree | a3557d6d772f61dda70da12584ffbfbe6d168319 /unittests/IR | |
parent | 5eacadd64953918cc9d3bcb63387d7e0d20a40d2 (diff) | |
download | external_llvm-71c1b228552ece06003d744b815f669dbfbb0772.zip external_llvm-71c1b228552ece06003d744b815f669dbfbb0772.tar.gz external_llvm-71c1b228552ece06003d744b815f669dbfbb0772.tar.bz2 |
Fix a disconcerting bug in Value::isUsedInBasicBlock, which gave wrong answers for blocks larger than 3 instrs.
Also add a unit test. PR15727.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@179370 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'unittests/IR')
-rw-r--r-- | unittests/IR/CMakeLists.txt | 1 | ||||
-rw-r--r-- | unittests/IR/ValueTest.cpp | 46 |
2 files changed, 47 insertions, 0 deletions
diff --git a/unittests/IR/CMakeLists.txt b/unittests/IR/CMakeLists.txt index aed4597..b6098c7 100644 --- a/unittests/IR/CMakeLists.txt +++ b/unittests/IR/CMakeLists.txt @@ -16,6 +16,7 @@ set(IRSources TypeBuilderTest.cpp TypesTest.cpp ValueMapTest.cpp + ValueTest.cpp VerifierTest.cpp WaymarkTest.cpp ) diff --git a/unittests/IR/ValueTest.cpp b/unittests/IR/ValueTest.cpp new file mode 100644 index 0000000..52efb1a --- /dev/null +++ b/unittests/IR/ValueTest.cpp @@ -0,0 +1,46 @@ +//===- llvm/unittest/IR/ValueTest.cpp - Value 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/Assembly/Parser.h" +#include "llvm/IR/Function.h" +#include "llvm/IR/LLVMContext.h" +#include "llvm/IR/Module.h" +#include "llvm/IR/Value.h" +#include "llvm/Support/SourceMgr.h" +#include "gtest/gtest.h" +using namespace llvm; + +namespace { + +TEST(ValueTest, UsedInBasicBlock) { + LLVMContext C; + + const char *ModuleString = "define void @f(i32 %x, i32 %y) {\n" + "bb0:\n" + " %y1 = add i32 %y, 1\n" + " %y2 = add i32 %y, 1\n" + " %y3 = add i32 %y, 1\n" + " %y4 = add i32 %y, 1\n" + " %y5 = add i32 %y, 1\n" + " %y6 = add i32 %y, 1\n" + " %y7 = add i32 %y, 1\n" + " %y8 = add i32 %x, 1\n" + " ret void\n" + "}\n"; + SMDiagnostic Err; + Module *M = ParseAssemblyString(ModuleString, NULL, Err, C); + + Function *F = M->getFunction("f"); + + EXPECT_FALSE(F->isUsedInBasicBlock(F->begin())); + EXPECT_TRUE((++F->arg_begin())->isUsedInBasicBlock(F->begin())); + EXPECT_TRUE(F->arg_begin()->isUsedInBasicBlock(F->begin())); +} + +} // end anonymous namespace |