Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / M68k / CodeModel / medium-static.ll
blob1a544a971d266d22cdd621d34d2dc784441752b5
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=medium -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:    move.l #dst, ptr
14 ; CHECK-NEXT:    move.l src, dst
15 ; CHECK-NEXT:    rts
16 entry:
17     store i32* @dst, i32** @ptr
18     %tmp.s = load i32, i32* @src
19     store i32 %tmp.s, i32* @dst
20     ret void
23 @ptr2 = global i32* null
24 @dst2 = global i32 0
25 @src2 = global i32 0
27 define void @test1() nounwind {
28 ; CHECK-LABEL: test1:
29 ; CHECK:       ; %bb.0: ; %entry
30 ; CHECK-NEXT:    move.l #dst2, ptr2
31 ; CHECK-NEXT:    move.l src2, dst2
32 ; CHECK-NEXT:    rts
33 entry:
34     store i32* @dst2, i32** @ptr2
35     %tmp.s = load i32, i32* @src2
36     store i32 %tmp.s, i32* @dst2
37     ret void
40 declare i8* @malloc(i32)
42 define void @test2() nounwind {
43 ; CHECK-LABEL: test2:
44 ; CHECK:       ; %bb.0: ; %entry
45 ; CHECK-NEXT:    suba.l #4, %sp
46 ; CHECK-NEXT:    move.l #40, (%sp)
47 ; CHECK-NEXT:    jsr malloc@PLT
48 ; CHECK-NEXT:    adda.l #4, %sp
49 ; CHECK-NEXT:    rts
50 entry:
51     %ptr = call i8* @malloc(i32 40)
52     ret void
55 @pfoo = external global void(...)*
56 declare void(...)* @afoo(...)
59 define void @test3() nounwind {
60 ; CHECK-LABEL: test3:
61 ; CHECK:       ; %bb.0: ; %entry
62 ; CHECK-NEXT:    suba.l #4, %sp
63 ; CHECK-NEXT:    jsr afoo@PLT
64 ; CHECK-NEXT:    move.l %a0, pfoo
65 ; CHECK-NEXT:    jsr (%a0)
66 ; CHECK-NEXT:    adda.l #4, %sp
67 ; CHECK-NEXT:    rts
68 entry:
69     %tmp = call void(...)*(...) @afoo()
70     store void(...)* %tmp, void(...)** @pfoo
71     %tmp1 = load void(...)*, void(...)** @pfoo
72     call void(...) %tmp1()
73     ret void
76 declare void @foo(...)
78 define void @test4() nounwind {
79 ; CHECK-LABEL: test4:
80 ; CHECK:       ; %bb.0: ; %entry
81 ; CHECK-NEXT:    suba.l #4, %sp
82 ; CHECK-NEXT:    jsr foo@PLT
83 ; CHECK-NEXT:    adda.l #4, %sp
84 ; CHECK-NEXT:    rts
85 entry:
86     call void(...) @foo()
87     ret void
90 @ptr6 = internal global i32* null
91 @dst6 = internal global i32 0
92 @src6 = internal global i32 0
94 define void @test5() nounwind {
95 ; CHECK-LABEL: test5:
96 ; CHECK:       ; %bb.0: ; %entry
97 ; CHECK-NEXT:    move.l #dst6, ptr6
98 ; CHECK-NEXT:    move.l src6, dst6
99 ; CHECK-NEXT:    rts
100 entry:
101     store i32* @dst6, i32** @ptr6
102     %tmp.s = load i32, i32* @src6
103     store i32 %tmp.s, i32* @dst6
104     ret void
107 define void @test7(i32 %n.u) nounwind {
108 ; CHECK-LABEL: test7:
109 ; CHECK:       ; %bb.0: ; %entry
110 ; CHECK-NEXT:    move.l (4,%sp), %d0
111 ; CHECK-NEXT:    add.l #-1, %d0
112 ; CHECK-NEXT:    move.l %d0, %d1
113 ; CHECK-NEXT:    sub.l #12, %d1
114 ; CHECK-NEXT:    bhi .LBB6_12
115 ; CHECK-NEXT:  ; %bb.1: ; %entry
116 ; CHECK-NEXT:    lsl.l #2, %d0
117 ; CHECK-NEXT:    move.l #.LJTI6_0, %a0
118 ; CHECK-NEXT:    move.l (0,%a0,%d0), %a0
119 ; CHECK-NEXT:    jmp (%a0)
120 ; CHECK-NEXT:  .LBB6_12: ; %bb2
121 ; CHECK-NEXT:    bra foo6@PLT ; TAILCALL
122 ; CHECK-NEXT:  .LBB6_3: ; %bb5
123 ; CHECK-NEXT:    bra foo5@PLT ; TAILCALL
124 ; CHECK-NEXT:  .LBB6_5: ; %bb1
125 ; CHECK-NEXT:    bra foo2@PLT ; TAILCALL
126 ; CHECK-NEXT:  .LBB6_2: ; %bb
127 ; CHECK-NEXT:    bra foo1@PLT ; TAILCALL
128 ; CHECK-NEXT:  .LBB6_9: ; %bb4
129 ; CHECK-NEXT:    bra foo4@PLT ; TAILCALL
130 ; CHECK-NEXT:  .LBB6_8: ; %bb3
131 ; CHECK-NEXT:    bra foo3@PLT ; TAILCALL
132 entry:
133     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 ]
135     tail call void(...) @foo1()
136     ret void
137 bb1:
138     tail call void(...) @foo2()
139     ret void
140 bb2:
141     tail call void(...) @foo6()
142     ret void
143 bb3:
144     tail call void(...) @foo3()
145     ret void
146 bb4:
147     tail call void(...) @foo4()
148     ret void
149 bb5:
150     tail call void(...) @foo5()
151     ret void
152 bb6:
153     tail call void(...) @foo1()
154     ret void
155 bb7:
156     tail call void(...) @foo2()
157     ret void
158 bb8:
159     tail call void(...) @foo6()
160     ret void
161 bb9:
162     tail call void(...) @foo3()
163     ret void
164 bb10:
165     tail call void(...) @foo4()
166     ret void
167 bb11:
168     tail call void(...) @foo5()
169     ret void
170 bb12:
171     tail call void(...) @foo6()
172     ret void
175 declare void @foo1(...)
176 declare void @foo2(...)
177 declare void @foo6(...)
178 declare void @foo3(...)
179 declare void @foo4(...)
180 declare void @foo5(...)