Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / CodeGen / AArch64 / and-sink.ll
blobc84310629e5fdaa4430925a0d0cf57a03783620f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
2 ; RUN: llc -mtriple=aarch64-linux-gnu -verify-machineinstrs < %s | FileCheck %s
3 ; RUN: opt -S -passes='require<profile-summary>,function(codegenprepare)' -mtriple=aarch64-linux %s | FileCheck --check-prefix=CHECK-CGP %s
4 ; RUN: opt -S -passes='require<profile-summary>,function(codegenprepare)' -cgpp-huge-func=0 -mtriple=aarch64-linux %s | FileCheck --check-prefix=CHECK-CGP %s
6 @A = dso_local global i32 zeroinitializer
7 @B = dso_local global i32 zeroinitializer
8 @C = dso_local global i32 zeroinitializer
10 ; Test that and is sunk into cmp block to form tbz.
11 define dso_local i32 @and_sink1(i32 %a, i1 %c) {
12 ; CHECK-LABEL: and_sink1:
13 ; CHECK:       // %bb.0:
14 ; CHECK-NEXT:    tbz w1, #0, .LBB0_3
15 ; CHECK-NEXT:  // %bb.1: // %bb0
16 ; CHECK-NEXT:    adrp x8, A
17 ; CHECK-NEXT:    str wzr, [x8, :lo12:A]
18 ; CHECK-NEXT:    tbnz w0, #2, .LBB0_3
19 ; CHECK-NEXT:  // %bb.2:
20 ; CHECK-NEXT:    mov w0, #1 // =0x1
21 ; CHECK-NEXT:    ret
22 ; CHECK-NEXT:  .LBB0_3: // %bb2
23 ; CHECK-NEXT:    mov w0, wzr
24 ; CHECK-NEXT:    ret
26 ; CHECK-CGP-LABEL: @and_sink1(
27 ; CHECK-CGP-NOT: and i32
28   %and = and i32 %a, 4
29   br i1 %c, label %bb0, label %bb2
30 bb0:
31 ; CHECK-CGP-LABEL: bb0:
32 ; CHECK-CGP: and i32
33 ; CHECK-CGP-NEXT: icmp eq i32
34 ; CHECK-CGP-NEXT: store
35 ; CHECK-CGP-NEXT: br
36   %cmp = icmp eq i32 %and, 0
37   store i32 0, ptr @A
38   br i1 %cmp, label %bb1, label %bb2
39 bb1:
40   ret i32 1
41 bb2:
42   ret i32 0
45 ; Test that both 'and' and cmp get sunk to form tbz.
46 define dso_local i32 @and_sink2(i32 %a, i1 %c, i1 %c2) {
47 ; CHECK-LABEL: and_sink2:
48 ; CHECK:       // %bb.0:
49 ; CHECK-NEXT:    adrp x8, A
50 ; CHECK-NEXT:    str wzr, [x8, :lo12:A]
51 ; CHECK-NEXT:    tbz w1, #0, .LBB1_5
52 ; CHECK-NEXT:  // %bb.1: // %bb0.preheader
53 ; CHECK-NEXT:    adrp x8, B
54 ; CHECK-NEXT:    adrp x9, C
55 ; CHECK-NEXT:  .LBB1_2: // %bb0
56 ; CHECK-NEXT:    // =>This Inner Loop Header: Depth=1
57 ; CHECK-NEXT:    str wzr, [x8, :lo12:B]
58 ; CHECK-NEXT:    tbz w2, #0, .LBB1_5
59 ; CHECK-NEXT:  // %bb.3: // %bb1
60 ; CHECK-NEXT:    // in Loop: Header=BB1_2 Depth=1
61 ; CHECK-NEXT:    str wzr, [x9, :lo12:C]
62 ; CHECK-NEXT:    tbnz w0, #2, .LBB1_2
63 ; CHECK-NEXT:  // %bb.4:
64 ; CHECK-NEXT:    mov w0, #1 // =0x1
65 ; CHECK-NEXT:    ret
66 ; CHECK-NEXT:  .LBB1_5:
67 ; CHECK-NEXT:    mov w0, wzr
68 ; CHECK-NEXT:    ret
70 ; CHECK-CGP-LABEL: @and_sink2(
71 ; CHECK-CGP-NOT: and i32
72   %and = and i32 %a, 4
73   store i32 0, ptr @A
74   br i1 %c, label %bb0, label %bb3
75 bb0:
76 ; CHECK-CGP-LABEL: bb0:
77 ; CHECK-CGP-NOT: and i32
78 ; CHECK-CGP-NOT: icmp
79   %cmp = icmp eq i32 %and, 0
80   store i32 0, ptr @B
81   br i1 %c2, label %bb1, label %bb3
82 bb1:
83 ; CHECK-CGP-LABEL: bb1:
84 ; CHECK-CGP: and i32
85 ; CHECK-CGP-NEXT: icmp eq i32
86 ; CHECK-CGP-NEXT: store
87 ; CHECK-CGP-NEXT: br
88   store i32 0, ptr @C
89   br i1 %cmp, label %bb2, label %bb0
90 bb2:
91   ret i32 1
92 bb3:
93   ret i32 0
96 ; Test that 'and' is not sunk since cbz is a better alternative.
97 define dso_local i32 @and_sink3(i32 %a) {
98 ; CHECK-LABEL: and_sink3:
99 ; CHECK:       // %bb.0:
100 ; CHECK-NEXT:    adrp x8, A
101 ; CHECK-NEXT:    and w9, w0, #0x3
102 ; CHECK-NEXT:  .LBB2_1: // %bb0
103 ; CHECK-NEXT:    // =>This Inner Loop Header: Depth=1
104 ; CHECK-NEXT:    str wzr, [x8, :lo12:A]
105 ; CHECK-NEXT:    cbz w9, .LBB2_1
106 ; CHECK-NEXT:  // %bb.2: // %bb2
107 ; CHECK-NEXT:    mov w0, wzr
108 ; CHECK-NEXT:    ret
110 ; CHECK-CGP-LABEL: @and_sink3(
111 ; CHECK-CGP-NEXT: and i32
112   %and = and i32 %a, 3
113   br label %bb0
114 bb0:
115 ; CHECK-CGP-LABEL: bb0:
116 ; CHECK-CGP-NOT: and i32
117   %cmp = icmp eq i32 %and, 0
118   store i32 0, ptr @A
119   br i1 %cmp, label %bb0, label %bb2
120 bb2:
121   ret i32 0