[llvm] r347055 - [InstSimplify] add test to demonstrate undef matching differences; NFC

Sanjay Patel via llvm-commits llvm-commits at lists.llvm.org
Fri Nov 16 07:35:58 PST 2018


Author: spatel
Date: Fri Nov 16 07:35:58 2018
New Revision: 347055

URL: http://llvm.org/viewvc/llvm-project?rev=347055&view=rev
Log:
[InstSimplify] add test to demonstrate undef matching differences; NFC

This is a baseline test for D54631.
Patch by:
@nikic (Nikita Popov)


Added:
    llvm/trunk/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll

Added: llvm/trunk/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll?rev=347055&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll (added)
+++ llvm/trunk/test/Transforms/InstSimplify/shr-scalar-vector-consistency.ll Fri Nov 16 07:35:58 2018
@@ -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
+}
+




More information about the llvm-commits mailing list