[llvm] 83e84cd - [InstCombine] precommit tests for D143593

via llvm-commits llvm-commits at lists.llvm.org
Fri Feb 10 11:10:01 PST 2023


Author: ManuelJBrito
Date: 2023-02-10T19:09:52Z
New Revision: 83e84cdbe4bc6b6f42cf948b1f8410fb74acc650

URL: https://github.com/llvm/llvm-project/commit/83e84cdbe4bc6b6f42cf948b1f8410fb74acc650
DIFF: https://github.com/llvm/llvm-project/commit/83e84cdbe4bc6b6f42cf948b1f8410fb74acc650.diff

LOG: [InstCombine] precommit tests for D143593

Added: 
    llvm/test/Transforms/InstCombine/shufflevector_freezepoison.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/InstCombine/shufflevector_freezepoison.ll b/llvm/test/Transforms/InstCombine/shufflevector_freezepoison.ll
new file mode 100644
index 0000000000000..6a8a88e6f24cd
--- /dev/null
+++ b/llvm/test/Transforms/InstCombine/shufflevector_freezepoison.ll
@@ -0,0 +1,74 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -passes='instcombine' -S %s | FileCheck %s
+
+
+define <4 x double> @shuffle_op0_freeze_poison(<2 x double> %a) {
+; CHECK-LABEL: @shuffle_op0_freeze_poison(
+; CHECK-NEXT:    [[SHUFFLE:%.*]] = shufflevector <2 x double> zeroinitializer, <2 x double> [[A:%.*]], <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+; CHECK-NEXT:    ret <4 x double> [[SHUFFLE]]
+;
+  %b = freeze <2 x double> poison
+  %shuffle = shufflevector <2 x double> %b, <2 x double> %a, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+  ret <4 x double> %shuffle
+}
+
+define <4 x double> @shuffle_op1_freeze_poison(<2 x double> %a) {
+; CHECK-LABEL: @shuffle_op1_freeze_poison(
+; CHECK-NEXT:    [[SHUFFLE:%.*]] = shufflevector <2 x double> [[A:%.*]], <2 x double> zeroinitializer, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+; CHECK-NEXT:    ret <4 x double> [[SHUFFLE]]
+;
+  %b = freeze <2 x double> poison
+  %shuffle = shufflevector <2 x double> %a, <2 x double> %b, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+  ret <4 x double> %shuffle
+}
+
+define <4 x double> @shuffle_op0_freeze_poison_use(<2 x double> %a) {
+; CHECK-LABEL: @shuffle_op0_freeze_poison_use(
+; CHECK-NEXT:    call void @use(<2 x double> zeroinitializer)
+; CHECK-NEXT:    [[SHUFFLE:%.*]] = shufflevector <2 x double> zeroinitializer, <2 x double> [[A:%.*]], <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+; CHECK-NEXT:    ret <4 x double> [[SHUFFLE]]
+;
+  %b = freeze <2 x double> poison
+  call void @use(<2 x double> %b)
+  %shuffle = shufflevector <2 x double> %b, <2 x double> %a, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+  ret <4 x double> %shuffle
+}
+
+define <4 x double> @shuffle_op1_freeze_poison_use(<2 x double> %a) {
+; CHECK-LABEL: @shuffle_op1_freeze_poison_use(
+; CHECK-NEXT:    call void @use(<2 x double> zeroinitializer)
+; CHECK-NEXT:    [[SHUFFLE:%.*]] = shufflevector <2 x double> [[A:%.*]], <2 x double> zeroinitializer, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+; CHECK-NEXT:    ret <4 x double> [[SHUFFLE]]
+;
+  %b = freeze <2 x double> poison
+  call void @use(<2 x double> %b)
+  %shuffle = shufflevector <2 x double> %a, <2 x double> %b, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+  ret <4 x double> %shuffle
+}
+
+define <4 x double> @shuffle_op0_freeze_undef(<2 x double> %a) {
+; CHECK-LABEL: @shuffle_op0_freeze_undef(
+; CHECK-NEXT:    call void @use(<2 x double> zeroinitializer)
+; CHECK-NEXT:    [[SHUFFLE:%.*]] = shufflevector <2 x double> zeroinitializer, <2 x double> [[A:%.*]], <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+; CHECK-NEXT:    ret <4 x double> [[SHUFFLE]]
+;
+  %b = freeze <2 x double> undef
+  call void @use(<2 x double> %b)
+  %shuffle = shufflevector <2 x double> %b, <2 x double> %a, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+  ret <4 x double> %shuffle
+}
+
+define <4 x double> @shuffle_op1_freeze_undef(<2 x double> %a) {
+; CHECK-LABEL: @shuffle_op1_freeze_undef(
+; CHECK-NEXT:    call void @use(<2 x double> zeroinitializer)
+; CHECK-NEXT:    [[SHUFFLE:%.*]] = shufflevector <2 x double> [[A:%.*]], <2 x double> zeroinitializer, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+; CHECK-NEXT:    ret <4 x double> [[SHUFFLE]]
+;
+  %b = freeze <2 x double> undef
+  call void @use(<2 x double> %b)
+  %shuffle = shufflevector <2 x double> %a, <2 x double> %b, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+  ret <4 x double> %shuffle
+}
+
+declare void @use(<2 x double>)
+


        


More information about the llvm-commits mailing list