From: Sanjay Patel Date: Fri, 16 Nov 2018 15:35:58 +0000 (+0000) Subject: [InstSimplify] add test to demonstrate undef matching differences; NFC X-Git-Tag: llvmorg-8.0.0-rc1~4112 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5ebd2a785ef0f105f4d65ea73ce58c16720a3839;p=platform%2Fupstream%2Fllvm.git [InstSimplify] add test to demonstrate undef matching differences; NFC This is a baseline test for D54631. Patch by: @nikic (Nikita Popov) llvm-svn: 347055 --- diff --git a/llvm/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll b/llvm/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll new file mode 100644 index 0000000..f1bba37 --- /dev/null +++ b/llvm/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll @@ -0,0 +1,25 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py +; RUN: opt < %s -instsimplify -S | FileCheck %s + +; This tests checks optimization consistency for scalar and vector code. +; If m_Zero() is able to match a vector undef, but not a scalar undef, +; the two cases will simplify differently. + +define i32 @test_scalar(i32 %a, i1 %b) { +; CHECK-LABEL: @test_scalar( +; CHECK-NEXT: ret i32 undef +; + %c = sext i1 %b to i32 + %d = ashr i32 undef, %c + ret i32 %d +} + +define <2 x i32> @test_vector(<2 x i32> %a, <2 x i1> %b) { +; CHECK-LABEL: @test_vector( +; CHECK-NEXT: ret <2 x i32> zeroinitializer +; + %c = sext <2 x i1> %b to <2 x i32> + %d = ashr <2 x i32> undef, %c + ret <2 x i32> %d +} +