1c23a780cSMin-Yih Hsu; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2c23a780cSMin-Yih Hsu; RUN: llc < %s -O2 -mtriple=m68k-linux-gnu -verify-machineinstrs \
3c23a780cSMin-Yih Hsu; RUN:              -code-model=medium -relocation-model=pic \
4c23a780cSMin-Yih Hsu; RUN:   | FileCheck %s
5c23a780cSMin-Yih Hsu
6c23a780cSMin-Yih Hsu@ptr = external global i32*
7c23a780cSMin-Yih Hsu@dst = external global i32
8c23a780cSMin-Yih Hsu@src = external global i32
9c23a780cSMin-Yih Hsu
10c23a780cSMin-Yih Hsudefine void @test0() nounwind {
11c23a780cSMin-Yih Hsu; CHECK-LABEL: test0:
12c23a780cSMin-Yih Hsu; CHECK:       ; %bb.0: ; %entry
13c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (dst@GOTPCREL,%pc), %a0
14c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (ptr@GOTPCREL,%pc), %a1
15c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %a0, (%a1)
16c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (src@GOTPCREL,%pc), %a1
17c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (%a1), (%a0)
18c23a780cSMin-Yih Hsu; CHECK-NEXT:    rts
19c23a780cSMin-Yih Hsuentry:
20c23a780cSMin-Yih Hsu    store i32* @dst, i32** @ptr
21c23a780cSMin-Yih Hsu    %tmp.s = load i32, i32* @src
22c23a780cSMin-Yih Hsu    store i32 %tmp.s, i32* @dst
23c23a780cSMin-Yih Hsu    ret void
24c23a780cSMin-Yih Hsu}
25c23a780cSMin-Yih Hsu
26c23a780cSMin-Yih Hsu@ptr2 = global i32* null
27c23a780cSMin-Yih Hsu@dst2 = global i32 0
28c23a780cSMin-Yih Hsu@src2 = global i32 0
29c23a780cSMin-Yih Hsu
30c23a780cSMin-Yih Hsudefine void @test1() nounwind {
31c23a780cSMin-Yih Hsu; CHECK-LABEL: test1:
32c23a780cSMin-Yih Hsu; CHECK:       ; %bb.0: ; %entry
33c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (dst2@GOTPCREL,%pc), %a0
34c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (ptr2@GOTPCREL,%pc), %a1
35c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %a0, (%a1)
36c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (src2@GOTPCREL,%pc), %a1
37c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (%a1), (%a0)
38c23a780cSMin-Yih Hsu; CHECK-NEXT:    rts
39c23a780cSMin-Yih Hsuentry:
40c23a780cSMin-Yih Hsu    store i32* @dst2, i32** @ptr2
41c23a780cSMin-Yih Hsu    %tmp.s = load i32, i32* @src2
42c23a780cSMin-Yih Hsu    store i32 %tmp.s, i32* @dst2
43c23a780cSMin-Yih Hsu    ret void
44c23a780cSMin-Yih Hsu}
45c23a780cSMin-Yih Hsu
46c23a780cSMin-Yih Hsudeclare i8* @malloc(i32)
47c23a780cSMin-Yih Hsu
48c23a780cSMin-Yih Hsudefine void @test2() nounwind {
49c23a780cSMin-Yih Hsu; CHECK-LABEL: test2:
50c23a780cSMin-Yih Hsu; CHECK:       ; %bb.0: ; %entry
51*657bb726SMin-Yih Hsu; CHECK-NEXT:    suba.l #4, %sp
52c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l #40, (%sp)
53c23a780cSMin-Yih Hsu; CHECK-NEXT:    jsr (malloc@PLT,%pc)
54*657bb726SMin-Yih Hsu; CHECK-NEXT:    adda.l #4, %sp
55c23a780cSMin-Yih Hsu; CHECK-NEXT:    rts
56c23a780cSMin-Yih Hsuentry:
57c23a780cSMin-Yih Hsu    %ptr = call i8* @malloc(i32 40)
58c23a780cSMin-Yih Hsu    ret void
59c23a780cSMin-Yih Hsu}
60c23a780cSMin-Yih Hsu
61c23a780cSMin-Yih Hsu@pfoo = external global void(...)*
62c23a780cSMin-Yih Hsudeclare void(...)* @afoo(...)
63c23a780cSMin-Yih Hsu
64c23a780cSMin-Yih Hsudefine void @test3() nounwind {
65c23a780cSMin-Yih Hsu; CHECK-LABEL: test3:
66c23a780cSMin-Yih Hsu; CHECK:       ; %bb.0: ; %entry
67*657bb726SMin-Yih Hsu; CHECK-NEXT:    suba.l #4, %sp
68c23a780cSMin-Yih Hsu; CHECK-NEXT:    jsr (afoo@PLT,%pc)
69c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %d0, %a0
70c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (pfoo@GOTPCREL,%pc), %a1
71c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %a0, (%a1)
72c23a780cSMin-Yih Hsu; CHECK-NEXT:    jsr (%a0)
73*657bb726SMin-Yih Hsu; CHECK-NEXT:    adda.l #4, %sp
74c23a780cSMin-Yih Hsu; CHECK-NEXT:    rts
75c23a780cSMin-Yih Hsuentry:
76c23a780cSMin-Yih Hsu    %tmp = call void(...)*(...) @afoo()
77c23a780cSMin-Yih Hsu    store void(...)* %tmp, void(...)** @pfoo
78c23a780cSMin-Yih Hsu    %tmp1 = load void(...)*, void(...)** @pfoo
79c23a780cSMin-Yih Hsu    call void(...) %tmp1()
80c23a780cSMin-Yih Hsu    ret void
81c23a780cSMin-Yih Hsu}
82c23a780cSMin-Yih Hsu
83c23a780cSMin-Yih Hsudeclare void @foo(...)
84c23a780cSMin-Yih Hsu
85c23a780cSMin-Yih Hsudefine void @test4() nounwind {
86c23a780cSMin-Yih Hsu; CHECK-LABEL: test4:
87c23a780cSMin-Yih Hsu; CHECK:       ; %bb.0: ; %entry
88*657bb726SMin-Yih Hsu; CHECK-NEXT:    suba.l #4, %sp
89c23a780cSMin-Yih Hsu; CHECK-NEXT:    jsr (foo@PLT,%pc)
90*657bb726SMin-Yih Hsu; CHECK-NEXT:    adda.l #4, %sp
91c23a780cSMin-Yih Hsu; CHECK-NEXT:    rts
92c23a780cSMin-Yih Hsuentry:
93c23a780cSMin-Yih Hsu    call void(...) @foo()
94c23a780cSMin-Yih Hsu    ret void
95c23a780cSMin-Yih Hsu}
96c23a780cSMin-Yih Hsu
97c23a780cSMin-Yih Hsu@ptr6 = internal global i32* null
98c23a780cSMin-Yih Hsu@dst6 = internal global i32 0
99c23a780cSMin-Yih Hsu@src6 = internal global i32 0
100c23a780cSMin-Yih Hsu
101c23a780cSMin-Yih Hsudefine void @test5() nounwind {
102c23a780cSMin-Yih Hsu; CHECK-LABEL: test5:
103c23a780cSMin-Yih Hsu; CHECK:       ; %bb.0: ; %entry
104c23a780cSMin-Yih Hsu; CHECK-NEXT:    lea (_GLOBAL_OFFSET_TABLE_@GOTPCREL,%pc), %a0
105c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %a0, %a1
106*657bb726SMin-Yih Hsu; CHECK-NEXT:    adda.l #dst6@GOTOFF, %a1
107c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l #ptr6@GOTOFF, %d0
108c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %a1, (0,%a0,%d0)
109c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l #src6@GOTOFF, %d0
110c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l #dst6@GOTOFF, %d1
111c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (0,%a0,%d0), (0,%a0,%d1)
112c23a780cSMin-Yih Hsu; CHECK-NEXT:    rts
113c23a780cSMin-Yih Hsuentry:
114c23a780cSMin-Yih Hsu    store i32* @dst6, i32** @ptr6
115c23a780cSMin-Yih Hsu    %tmp.s = load i32, i32* @src6
116c23a780cSMin-Yih Hsu    store i32 %tmp.s, i32* @dst6
117c23a780cSMin-Yih Hsu    ret void
118c23a780cSMin-Yih Hsu}
119c23a780cSMin-Yih Hsu
120c23a780cSMin-Yih Hsudefine void @test7(i32 %n.u) nounwind {
121c23a780cSMin-Yih Hsu; CHECK-LABEL: test7:
122c23a780cSMin-Yih Hsu; CHECK:       ; %bb.0: ; %entry
123c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l (4,%sp), %d0
124c23a780cSMin-Yih Hsu; CHECK-NEXT:    add.l #-1, %d0
125c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %d0, %d1
126c23a780cSMin-Yih Hsu; CHECK-NEXT:    sub.l #12, %d1
127c23a780cSMin-Yih Hsu; CHECK-NEXT:    bhi .LBB6_12
128c23a780cSMin-Yih Hsu; CHECK-NEXT:  ; %bb.1: ; %entry
129c23a780cSMin-Yih Hsu; CHECK-NEXT:    lea (_GLOBAL_OFFSET_TABLE_@GOTPCREL,%pc), %a0
130c23a780cSMin-Yih Hsu; CHECK-NEXT:    lsl.l #2, %d0
131c23a780cSMin-Yih Hsu; CHECK-NEXT:    move.l %a0, %a1
132*657bb726SMin-Yih Hsu; CHECK-NEXT:    adda.l #.LJTI6_0@GOTOFF, %a1
133*657bb726SMin-Yih Hsu; CHECK-NEXT:    move.l %a0, %d1
134*657bb726SMin-Yih Hsu; CHECK-NEXT:    add.l (0,%a1,%d0), %d1
135*657bb726SMin-Yih Hsu; CHECK-NEXT:    move.l %d1, %a0
136c23a780cSMin-Yih Hsu; CHECK-NEXT:    jmp (%a0)
137c23a780cSMin-Yih Hsu; CHECK-NEXT:  .LBB6_12: ; %bb2
138c23a780cSMin-Yih Hsu; CHECK-NEXT:    bra foo6@PLT ; TAILCALL
139c23a780cSMin-Yih Hsu; CHECK-NEXT:  .LBB6_3: ; %bb6
140c23a780cSMin-Yih Hsu; CHECK-NEXT:    bra foo1@PLT ; TAILCALL
141c23a780cSMin-Yih Hsu; CHECK-NEXT:  .LBB6_8: ; %bb1
142c23a780cSMin-Yih Hsu; CHECK-NEXT:    bra foo2@PLT ; TAILCALL
143c23a780cSMin-Yih Hsu; CHECK-NEXT:  .LBB6_9: ; %bb3
144c23a780cSMin-Yih Hsu; CHECK-NEXT:    bra foo3@PLT ; TAILCALL
145c23a780cSMin-Yih Hsu; CHECK-NEXT:  .LBB6_10: ; %bb4
146c23a780cSMin-Yih Hsu; CHECK-NEXT:    bra foo4@PLT ; TAILCALL
147c23a780cSMin-Yih Hsu; CHECK-NEXT:  .LBB6_14: ; %bb11
148c23a780cSMin-Yih Hsu; CHECK-NEXT:    bra foo5@PLT ; TAILCALL
149c23a780cSMin-Yih Hsuentry:
150c23a780cSMin-Yih Hsu    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 ]
151c23a780cSMin-Yih Hsubb:
152c23a780cSMin-Yih Hsu    tail call void(...) @foo1()
153c23a780cSMin-Yih Hsu    ret void
154c23a780cSMin-Yih Hsubb1:
155c23a780cSMin-Yih Hsu    tail call void(...) @foo2()
156c23a780cSMin-Yih Hsu    ret void
157c23a780cSMin-Yih Hsubb2:
158c23a780cSMin-Yih Hsu    tail call void(...) @foo6()
159c23a780cSMin-Yih Hsu    ret void
160c23a780cSMin-Yih Hsubb3:
161c23a780cSMin-Yih Hsu    tail call void(...) @foo3()
162c23a780cSMin-Yih Hsu    ret void
163c23a780cSMin-Yih Hsubb4:
164c23a780cSMin-Yih Hsu    tail call void(...) @foo4()
165c23a780cSMin-Yih Hsu    ret void
166c23a780cSMin-Yih Hsubb5:
167c23a780cSMin-Yih Hsu    tail call void(...) @foo5()
168c23a780cSMin-Yih Hsu    ret void
169c23a780cSMin-Yih Hsubb6:
170c23a780cSMin-Yih Hsu    tail call void(...) @foo1()
171c23a780cSMin-Yih Hsu    ret void
172c23a780cSMin-Yih Hsubb7:
173c23a780cSMin-Yih Hsu    tail call void(...) @foo2()
174c23a780cSMin-Yih Hsu    ret void
175c23a780cSMin-Yih Hsubb8:
176c23a780cSMin-Yih Hsu    tail call void(...) @foo6()
177c23a780cSMin-Yih Hsu    ret void
178c23a780cSMin-Yih Hsubb9:
179c23a780cSMin-Yih Hsu    tail call void(...) @foo3()
180c23a780cSMin-Yih Hsu    ret void
181c23a780cSMin-Yih Hsubb10:
182c23a780cSMin-Yih Hsu    tail call void(...) @foo4()
183c23a780cSMin-Yih Hsu    ret void
184c23a780cSMin-Yih Hsubb11:
185c23a780cSMin-Yih Hsu    tail call void(...) @foo5()
186c23a780cSMin-Yih Hsu    ret void
187c23a780cSMin-Yih Hsubb12:
188c23a780cSMin-Yih Hsu    tail call void(...) @foo6()
189c23a780cSMin-Yih Hsu    ret void
190c23a780cSMin-Yih Hsu}
191c23a780cSMin-Yih Hsu
192c23a780cSMin-Yih Hsudeclare void @foo1(...)
193c23a780cSMin-Yih Hsudeclare void @foo2(...)
194c23a780cSMin-Yih Hsudeclare void @foo6(...)
195c23a780cSMin-Yih Hsudeclare void @foo3(...)
196c23a780cSMin-Yih Hsudeclare void @foo4(...)
197c23a780cSMin-Yih Hsudeclare void @foo5(...)
198