[llvm] d43634c - [X86] Pre-commit test for D157513

Nabeel Omer via llvm-commits llvm-commits at lists.llvm.org
Thu Aug 10 07:55:13 PDT 2023


Author: Nabeel Omer
Date: 2023-08-10T15:40:12+01:00
New Revision: d43634cd743d86356ac2f4140c644e07e7d1fa44

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

LOG: [X86] Pre-commit test for D157513

https://reviews.llvm.org/D157513

Added: 
    llvm/test/CodeGen/X86/pr63645.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/CodeGen/X86/pr63645.ll b/llvm/test/CodeGen/X86/pr63645.ll
new file mode 100644
index 00000000000000..c1e3d1224d4617
--- /dev/null
+++ b/llvm/test/CodeGen/X86/pr63645.ll
@@ -0,0 +1,60 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
+; RUN: llc < %s -mtriple=x86_64-- | FileCheck %s
+
+ at p = dso_local local_unnamed_addr global i64 0, align 8
+ at l = dso_local local_unnamed_addr global ptr null, align 8
+ at c = dso_local local_unnamed_addr global i32 0, align 4
+
+; Function Attrs: mustprogress nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
+declare void @llvm.lifetime.start.p0(i64 immarg, ptr nocapture)
+
+; Function Attrs: mustprogress nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
+declare void @llvm.lifetime.end.p0(i64 immarg, ptr nocapture)
+
+; Function Attrs: nofree nosync nounwind memory(readwrite, inaccessiblemem: none) uwtable
+define i32 @main() #1 {
+; CHECK-LABEL: main:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    movl $0, c(%rip)
+; CHECK-NEXT:    movq $64, p(%rip)
+; CHECK-NEXT:    cmpl $42828, -{{[0-9]+}}(%rsp) # imm = 0xA74C
+; CHECK-NEXT:    jg .LBB0_2
+; CHECK-NEXT:  # %bb.1: # %if.then.1.i
+; CHECK-NEXT:    movq l(%rip), %rax
+; CHECK-NEXT:    movb $0, (%rax)
+; CHECK-NEXT:  .LBB0_2: # %t.exit
+; CHECK-NEXT:    xorl %eax, %eax
+; CHECK-NEXT:    retq
+entry:
+  %a.i = alloca [2 x i32], align 4
+  store i32 0, ptr @c, align 4
+  %arrayidx15.i = getelementptr inbounds [2 x i32], ptr %a.i, i64 0, i64 1
+  call void @llvm.lifetime.start.p0(i64 8, ptr nonnull %a.i)
+  store i32 50009, ptr %a.i, align 4
+  %arrayidx.i.1 = getelementptr inbounds [2 x i32], ptr %a.i, i64 0, i64 1
+  store i32 50009, ptr %arrayidx.i.1, align 4
+  call void @llvm.lifetime.end.p0(i64 8, ptr nonnull %a.i)
+  call void @llvm.lifetime.start.p0(i64 8, ptr nonnull %a.i)
+  store i64 64, ptr @p, align 8
+  %0 = load i32, ptr @c, align 4
+  %idxprom.1.i = zext i32 %0 to i64
+  %arrayidx.1.i = getelementptr inbounds [2 x i32], ptr %a.i, i64 0, i64 %idxprom.1.i
+  store i32 50009, ptr %arrayidx.1.i, align 4
+  %add14.1.i.1 = add i32 %0, 1
+  %idxprom.1.i.1 = zext i32 %add14.1.i.1 to i64
+  %arrayidx.1.i.1 = getelementptr inbounds [2 x i32], ptr %a.i, i64 0, i64 %idxprom.1.i.1
+  store i32 50009, ptr %arrayidx.1.i.1, align 4
+  %1 = load i32, ptr %arrayidx15.i, align 4
+  %cmp16.1.i = icmp slt i32 %1, 42829
+  br i1 %cmp16.1.i, label %if.then.1.i, label %t.exit
+
+if.then.1.i:                                      ; preds = %entry
+  %2 = load ptr, ptr @l, align 8
+  store i8 0, ptr %2, align 1
+  br label %t.exit
+
+t.exit:                                           ; preds = %entry, %if.then.1.i
+  call void @llvm.lifetime.end.p0(i64 8, ptr nonnull %a.i)
+  ret i32 0
+}
+


        


More information about the llvm-commits mailing list