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