summaryrefslogtreecommitdiffstats
path: root/llvm/unittests/Analysis
diff options
context:
space:
mode:
authorSanjay Patel <spatel@rotateright.com>2018-11-02 18:14:24 +0000
committerSanjay Patel <spatel@rotateright.com>2018-11-02 18:14:24 +0000
commit45a148de854db888b27320b1cbc4d541f304a715 (patch)
tree8995de68355408ba96fb87be968e00b95461b488 /llvm/unittests/Analysis
parent6cef4e5c87a089249f1e91b49f7c545b3a0aea95 (diff)
downloadbcm5719-llvm-45a148de854db888b27320b1cbc4d541f304a715.tar.gz
bcm5719-llvm-45a148de854db888b27320b1cbc4d541f304a715.zip
[ValueTracking] add test for non-canonical shuffle; NFC
llvm-svn: 346025
Diffstat (limited to 'llvm/unittests/Analysis')
-rw-r--r--llvm/unittests/Analysis/ValueTrackingTest.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/llvm/unittests/Analysis/ValueTrackingTest.cpp b/llvm/unittests/Analysis/ValueTrackingTest.cpp
index f7d715c6447..e66d8f77fd4 100644
--- a/llvm/unittests/Analysis/ValueTrackingTest.cpp
+++ b/llvm/unittests/Analysis/ValueTrackingTest.cpp
@@ -514,6 +514,29 @@ TEST(ValueTracking, ComputeNumSignBits_Shuffle) {
EXPECT_EQ(ComputeNumSignBits(RVal, M->getDataLayout()), 1u);
}
+// FIXME:
+// No guarantees for canonical IR in this analysis, so a shuffle element that
+// references an undef value means this can't return any extra information.
+TEST(ValueTracking, ComputeNumSignBits_Shuffle2) {
+ StringRef Assembly = "define <2 x i32> @f(<2 x i1> %x) { "
+ " %sext = sext <2 x i1> %x to <2 x i32> "
+ " %val = shufflevector <2 x i32> %sext, <2 x i32> undef, <2 x i32> <i32 0, i32 2> "
+ " ret <2 x i32> %val "
+ "} ";
+
+ LLVMContext Context;
+ SMDiagnostic Error;
+ auto M = parseAssemblyString(Assembly, Error, Context);
+ assert(M && "Bad assembly?");
+
+ auto *F = M->getFunction("f");
+ assert(F && "Bad assembly?");
+
+ auto *RVal =
+ cast<ReturnInst>(F->getEntryBlock().getTerminator())->getOperand(0);
+ EXPECT_EQ(ComputeNumSignBits(RVal, M->getDataLayout()), 32u);
+}
+
TEST(ValueTracking, ComputeKnownBits) {
StringRef Assembly = "define i32 @f(i32 %a, i32 %b) { "
" %ash = mul i32 %a, 8 "
OpenPOWER on IntegriCloud