Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / M68k / CodeModel / small-static.ll
blob6ab9a7b61e4411de55cd67a3afd29d16276ae38f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -O2 -mtriple=m68k -verify-machineinstrs \
3 ; RUN:              -code-model=small -relocation-model=static \
4 ; RUN:   | FileCheck %s
6 @ptr = external global i32*
7 @dst = external global i32
8 @src = external global i32
10 define void @test0() nounwind {
11 ; CHECK-LABEL: test0:
12 ; CHECK:       ; %bb.0: ; %entry
13 ; CHECK-NEXT:    lea (dst,%pc), %a0
14 ; CHECK-NEXT:    move.l %a0, (ptr,%pc)
15 ; CHECK-NEXT:    move.l (src,%pc), (dst,%pc)
16 ; CHECK-NEXT:    rts
17 entry:
18     store i32* @dst, i32** @ptr
19     %tmp.s = load i32, i32* @src
20     store i32 %tmp.s, i32* @dst
21     ret void
24 @ptr2 = global i32* null
25 @dst2 = global i32 0
26 @src2 = global i32 0
28 define void @test1() nounwind {
29 ; CHECK-LABEL: test1:
30 ; CHECK:       ; %bb.0: ; %entry
31 ; CHECK-NEXT:    lea (dst2,%pc), %a0
32 ; CHECK-NEXT:    move.l %a0, (ptr2,%pc)
33 ; CHECK-NEXT:    move.l (src2,%pc), (dst2,%pc)
34 ; CHECK-NEXT:    rts
35 entry:
36     store i32* @dst2, i32** @ptr2
37     %tmp.s = load i32, i32* @src2
38     store i32 %tmp.s, i32* @dst2
39     ret void
42 declare i8* @malloc(i32)
44 define void @test2() nounwind {
45 ; CHECK-LABEL: test2:
46 ; CHECK:       ; %bb.0: ; %entry
47 ; CHECK-NEXT:    suba.l #4, %sp
48 ; CHECK-NEXT:    move.l #40, (%sp)
49 ; CHECK-NEXT:    jsr malloc@PLT
50 ; CHECK-NEXT:    adda.l #4, %sp
51 ; CHECK-NEXT:    rts
52 entry:
53     %ptr = call i8* @malloc(i32 40)
54     ret void
57 @pfoo = external global void(...)*
58 declare void(...)* @afoo(...)
60 define void @test3() nounwind {
61 ; CHECK-LABEL: test3:
62 ; CHECK:       ; %bb.0: ; %entry
63 ; CHECK-NEXT:    suba.l #4, %sp
64 ; CHECK-NEXT:    jsr afoo@PLT
65 ; CHECK-NEXT:    move.l %a0, (pfoo,%pc)
66 ; CHECK-NEXT:    jsr (%a0)
67 ; CHECK-NEXT:    adda.l #4, %sp
68 ; CHECK-NEXT:    rts
69 entry:
70     %tmp = call void(...)*(...) @afoo()
71     store void(...)* %tmp, void(...)** @pfoo
72     %tmp1 = load void(...)*, void(...)** @pfoo
73     call void(...) %tmp1()
74     ret void
77 declare void @foo(...)
79 define void @test4() nounwind {
80 ; CHECK-LABEL: test4:
81 ; CHECK:       ; %bb.0: ; %entry
82 ; CHECK-NEXT:    suba.l #4, %sp
83 ; CHECK-NEXT:    jsr foo@PLT
84 ; CHECK-NEXT:    adda.l #4, %sp
85 ; CHECK-NEXT:    rts
86 entry:
87     call void(...) @foo()
88     ret void
91 @ptr6 = internal global i32* null
92 @dst6 = internal global i32 0
93 @src6 = internal global i32 0
95 define void @test5() nounwind {
96 ; CHECK-LABEL: test5:
97 ; CHECK:       ; %bb.0: ; %entry
98 ; CHECK-NEXT:    lea (dst6,%pc), %a0
99 ; CHECK-NEXT:    move.l %a0, (ptr6,%pc)
100 ; CHECK-NEXT:    move.l (src6,%pc), (dst6,%pc)
101 ; CHECK-NEXT:    rts
102 entry:
103     store i32* @dst6, i32** @ptr6
104     %tmp.s = load i32, i32* @src6
105     store i32 %tmp.s, i32* @dst6
106     ret void
109 define void @test7(i32 %n.u) nounwind {
110 ; CHECK-LABEL: test7:
111 ; CHECK:       ; %bb.0: ; %entry
112 ; CHECK-NEXT:    move.l (4,%sp), %d0
113 ; CHECK-NEXT:    add.l #-1, %d0
114 ; CHECK-NEXT:    move.l %d0, %d1
115 ; CHECK-NEXT:    sub.l #12, %d1
116 ; CHECK-NEXT:    bhi .LBB6_12
117 ; CHECK-NEXT:  ; %bb.1: ; %entry
118 ; CHECK-NEXT:    lsl.l #2, %d0
119 ; CHECK-NEXT:    lea (.LJTI6_0,%pc), %a0
120 ; CHECK-NEXT:    move.l (0,%a0,%d0), %a0
121 ; CHECK-NEXT:    jmp (%a0)
122 ; CHECK-NEXT:  .LBB6_12: ; %bb2
123 ; CHECK-NEXT:    bra foo6@PLT ; TAILCALL
124 ; CHECK-NEXT:  .LBB6_3: ; %bb5
125 ; CHECK-NEXT:    bra foo5@PLT ; TAILCALL
126 ; CHECK-NEXT:  .LBB6_5: ; %bb1
127 ; CHECK-NEXT:    bra foo2@PLT ; TAILCALL
128 ; CHECK-NEXT:  .LBB6_2: ; %bb
129 ; CHECK-NEXT:    bra foo1@PLT ; TAILCALL
130 ; CHECK-NEXT:  .LBB6_9: ; %bb4
131 ; CHECK-NEXT:    bra foo4@PLT ; TAILCALL
132 ; CHECK-NEXT:  .LBB6_8: ; %bb3
133 ; CHECK-NEXT:    bra foo3@PLT ; TAILCALL
134 entry:
135     switch i32 %n.u, label %bb12 [i32 1, label %bb i32 2, label %bb6 i32 4, label %bb7 i32 5, label %bb8 i32 6, label %bb10 i32 7, label %bb1 i32 8, label %bb3 i32 9, label %bb4 i32 10, label %bb9 i32 11, label %bb2 i32 12, label %bb5 i32 13, label %bb11 ]
137     tail call void(...) @foo1()
138     ret void
139 bb1:
140     tail call void(...) @foo2()
141     ret void
142 bb2:
143     tail call void(...) @foo6()
144     ret void
145 bb3:
146     tail call void(...) @foo3()
147     ret void
148 bb4:
149     tail call void(...) @foo4()
150     ret void
151 bb5:
152     tail call void(...) @foo5()
153     ret void
154 bb6:
155     tail call void(...) @foo1()
156     ret void
157 bb7:
158     tail call void(...) @foo2()
159     ret void
160 bb8:
161     tail call void(...) @foo6()
162     ret void
163 bb9:
164     tail call void(...) @foo3()
165     ret void
166 bb10:
167     tail call void(...) @foo4()
168     ret void
169 bb11:
170     tail call void(...) @foo5()
171     ret void
172 bb12:
173     tail call void(...) @foo6()
174     ret void
177 declare void @foo1(...)
178 declare void @foo2(...)
179 declare void @foo6(...)
180 declare void @foo3(...)
181 declare void @foo4(...)
182 declare void @foo5(...)