[llvm] 1968f76 - [Test] Add LICM test for PR55672 showing problem with freeze instruction

Max Kazantsev via llvm-commits llvm-commits at lists.llvm.org
Tue May 24 03:17:54 PDT 2022


Author: Max Kazantsev
Date: 2022-05-24T17:17:46+07:00
New Revision: 1968f765c359304860b063ebe51cee2544433728

URL: https://github.com/llvm/llvm-project/commit/1968f765c359304860b063ebe51cee2544433728
DIFF: https://github.com/llvm/llvm-project/commit/1968f765c359304860b063ebe51cee2544433728.diff

LOG: [Test] Add LICM test for PR55672 showing problem with freeze instruction

Added: 
    llvm/test/Transforms/LICM/pr55672.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/LICM/pr55672.ll b/llvm/test/Transforms/LICM/pr55672.ll
new file mode 100644
index 0000000000000..479bd39f35e71
--- /dev/null
+++ b/llvm/test/Transforms/LICM/pr55672.ll
@@ -0,0 +1,105 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -S -passes='licm' < %s | FileCheck %s
+
+define void @test_01(i8 addrspace(1)* addrspace(1)* %arg, i32 %arg2) {
+; CHECK-LABEL: @test_01(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    [[TMP103:%.*]] = load atomic i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* [[ARG:%.*]] unordered, align 8, !dereferenceable_or_null !0, !align !1
+; CHECK-NEXT:    [[TMP117:%.*]] = icmp eq i8 addrspace(1)* [[TMP103]], null
+; CHECK-NEXT:    [[TMP118:%.*]] = getelementptr inbounds i8, i8 addrspace(1)* [[TMP103]], i64 8
+; CHECK-NEXT:    [[TMP119:%.*]] = bitcast i8 addrspace(1)* [[TMP118]] to i32 addrspace(1)*
+; CHECK-NEXT:    br i1 [[TMP117]], label [[FAIL:%.*]], label [[PREHEADER:%.*]]
+; CHECK:       fail:
+; CHECK-NEXT:    ret void
+; CHECK:       preheader:
+; CHECK-NEXT:    [[TMP157:%.*]] = load atomic i32, i32 addrspace(1)* [[TMP119]] unordered, align 8
+; CHECK-NEXT:    br label [[LOOP:%.*]]
+; CHECK:       loop:
+; CHECK-NEXT:    [[TMP151:%.*]] = phi i32 [ 0, [[PREHEADER]] ], [ [[TMP163:%.*]], [[LOOP]] ]
+; CHECK-NEXT:    [[TMP152:%.*]] = icmp ult i32 [[TMP151]], [[ARG2:%.*]]
+; CHECK-NEXT:    call void (i1, ...) @llvm.experimental.guard(i1 [[TMP152]]) [ "deopt"() ]
+; CHECK-NEXT:    [[TMP158:%.*]] = icmp ult i32 [[TMP151]], [[TMP157]]
+; CHECK-NEXT:    call void (i1, ...) @llvm.experimental.guard(i1 [[TMP158]]) [ "deopt"() ]
+; CHECK-NEXT:    [[TMP163]] = add i32 [[TMP151]], 1
+; CHECK-NEXT:    br label [[LOOP]]
+;
+entry:
+  %tmp103 = load atomic i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* %arg unordered, align 8, !dereferenceable_or_null !0, !align !1
+  %tmp117 = icmp eq i8 addrspace(1)* %tmp103, null
+  %tmp118 = getelementptr inbounds i8, i8 addrspace(1)* %tmp103, i64 8
+  %tmp119 = bitcast i8 addrspace(1)* %tmp118 to i32 addrspace(1)*
+  br i1 %tmp117, label %fail, label %preheader
+
+fail:                                             ; preds = %entry
+  ret void
+
+preheader:                                        ; preds = %bb
+  br label %loop
+
+loop:                                             ; preds = %loop, %preheader
+  %tmp151 = phi i32 [ 0, %preheader ], [ %tmp163, %loop ]
+  %tmp152 = icmp ult i32 %tmp151, %arg2
+  call void (i1, ...) @llvm.experimental.guard(i1 %tmp152) [ "deopt"() ]
+  %tmp157 = load atomic i32, i32 addrspace(1)* %tmp119 unordered, align 8
+  %tmp158 = icmp ult i32 %tmp151, %tmp157
+  call void (i1, ...) @llvm.experimental.guard(i1 %tmp158) [ "deopt"() ]
+  %tmp163 = add i32 %tmp151, 1
+  br label %loop
+}
+
+; FIXME: should be able to hoist load just as test_01
+define void @test_02(i8 addrspace(1)* addrspace(1)* %arg, i32 %arg2) {
+; CHECK-LABEL: @test_02(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    [[TMP103:%.*]] = load atomic i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* [[ARG:%.*]] unordered, align 8, !dereferenceable_or_null !0, !align !1
+; CHECK-NEXT:    [[TMP117:%.*]] = icmp eq i8 addrspace(1)* [[TMP103]], null
+; CHECK-NEXT:    [[TMP118:%.*]] = getelementptr inbounds i8, i8 addrspace(1)* [[TMP103]], i64 8
+; CHECK-NEXT:    [[TMP119:%.*]] = bitcast i8 addrspace(1)* [[TMP118]] to i32 addrspace(1)*
+; CHECK-NEXT:    [[FREEZE:%.*]] = freeze i1 [[TMP117]]
+; CHECK-NEXT:    br i1 [[FREEZE]], label [[FAIL:%.*]], label [[PREHEADER:%.*]]
+; CHECK:       fail:
+; CHECK-NEXT:    ret void
+; CHECK:       preheader:
+; CHECK-NEXT:    br label [[LOOP:%.*]]
+; CHECK:       loop:
+; CHECK-NEXT:    [[TMP151:%.*]] = phi i32 [ 0, [[PREHEADER]] ], [ [[TMP163:%.*]], [[LOOP]] ]
+; CHECK-NEXT:    [[TMP152:%.*]] = icmp ult i32 [[TMP151]], [[ARG2:%.*]]
+; CHECK-NEXT:    call void (i1, ...) @llvm.experimental.guard(i1 [[TMP152]]) [ "deopt"() ]
+; CHECK-NEXT:    [[TMP157:%.*]] = load atomic i32, i32 addrspace(1)* [[TMP119]] unordered, align 8
+; CHECK-NEXT:    [[TMP158:%.*]] = icmp ult i32 [[TMP151]], [[TMP157]]
+; CHECK-NEXT:    call void (i1, ...) @llvm.experimental.guard(i1 [[TMP158]]) [ "deopt"() ]
+; CHECK-NEXT:    [[TMP163]] = add i32 [[TMP151]], 1
+; CHECK-NEXT:    br label [[LOOP]]
+;
+entry:
+  %tmp103 = load atomic i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* %arg unordered, align 8, !dereferenceable_or_null !0, !align !1
+  %tmp117 = icmp eq i8 addrspace(1)* %tmp103, null
+  %tmp118 = getelementptr inbounds i8, i8 addrspace(1)* %tmp103, i64 8
+  %tmp119 = bitcast i8 addrspace(1)* %tmp118 to i32 addrspace(1)*
+  %freeze = freeze i1 %tmp117
+  br i1 %freeze, label %fail, label %preheader
+
+fail:                                             ; preds = %entry
+  ret void
+
+preheader:                                        ; preds = %entry
+  br label %loop
+
+loop:                                             ; preds = %loop, %preheader
+  %tmp151 = phi i32 [ 0, %preheader ], [ %tmp163, %loop ]
+  %tmp152 = icmp ult i32 %tmp151, %arg2
+  call void (i1, ...) @llvm.experimental.guard(i1 %tmp152) [ "deopt"() ]
+  %tmp157 = load atomic i32, i32 addrspace(1)* %tmp119 unordered, align 8
+  %tmp158 = icmp ult i32 %tmp151, %tmp157
+  call void (i1, ...) @llvm.experimental.guard(i1 %tmp158) [ "deopt"() ]
+  %tmp163 = add i32 %tmp151, 1
+  br label %loop
+}
+
+; Function Attrs: nocallback nofree nosync willreturn
+declare void @llvm.experimental.guard(i1, ...) #0
+
+attributes #0 = { nocallback nofree nosync willreturn }
+
+!0 = !{i64 16}
+!1 = !{i64 8}


        


More information about the llvm-commits mailing list