xref: /llvm-project/llvm/test/Transforms/MemCpyOpt/process_store.ll (revision a11faeed446882a81e79d780125d93e7199df645)
1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2; RUN: opt < %s -S -passes=memcpyopt -verify-memoryssa | FileCheck %s
3
4target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
5target triple = "x86_64-unknown-linux-gnu"
6
7@b = common dso_local local_unnamed_addr global i32 0, align 4
8@a = common dso_local local_unnamed_addr global i32 0, align 4
9
10declare dso_local i32 @f1()
11
12; Do not crash due to store first in BB.
13define dso_local void @f2() {
14; CHECK-LABEL: @f2(
15; CHECK-NEXT:  for.end:
16; CHECK-NEXT:    [[TMP0:%.*]] = load i32, ptr @b, align 4
17; CHECK-NEXT:    ret void
18; CHECK:       for.body:
19; CHECK-NEXT:    store i32 [[TMP1:%.*]], ptr @a, align 4
20; CHECK-NEXT:    [[CALL:%.*]] = call i32 @f1()
21; CHECK-NEXT:    [[CMP:%.*]] = icmp sge i32 [[CALL]], 0
22; CHECK-NEXT:    [[TMP1]] = load i32, ptr @b, align 4
23; CHECK-NEXT:    br label [[FOR_BODY:%.*]]
24;
25for.end:
26  %0 = load i32, ptr @b, align 4
27  ret void
28
29for.body:
30  store i32 %1, ptr @a, align 4
31  %call = call i32 @f1()
32  %cmp = icmp sge i32 %call, 0
33  %1 = load i32, ptr @b, align 4
34  br label %for.body
35}
36
37; Do not crash due to call not before store in BB.
38define dso_local void @f3() {
39; CHECK-LABEL: @f3(
40; CHECK-NEXT:  for.end:
41; CHECK-NEXT:    [[TMP0:%.*]] = load i32, ptr @b, align 4
42; CHECK-NEXT:    ret void
43; CHECK:       for.body:
44; CHECK-NEXT:    [[T:%.*]] = add i32 [[T2:%.*]], 1
45; CHECK-NEXT:    store i32 [[TMP1:%.*]], ptr @a, align 4
46; CHECK-NEXT:    [[CALL:%.*]] = call i32 @f1()
47; CHECK-NEXT:    [[CMP:%.*]] = icmp sge i32 [[CALL]], 0
48; CHECK-NEXT:    [[TMP1]] = load i32, ptr @b, align 4
49; CHECK-NEXT:    [[T2]] = xor i32 [[T]], 5
50; CHECK-NEXT:    br label [[FOR_BODY:%.*]]
51;
52for.end:
53  %0 = load i32, ptr @b, align 4
54  ret void
55
56for.body:
57  %t = add i32 %t2, 1
58  store i32 %1, ptr @a, align 4
59  %call = call i32 @f1()
60  %cmp = icmp sge i32 %call, 0
61  %1 = load i32, ptr @b, align 4
62  %t2 = xor i32 %t, 5
63  br label %for.body
64}
65