aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/M68k/CodeModel/Large/large-pie.ll
blob: ad902528d1dd3ff76ed1ffaa19667f4f8e6e9cfc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -O0 -mtriple=m68k -verify-machineinstrs \
; RUN:              -code-model=large -relocation-model=pic \
; RUN:   | FileCheck %s

define weak void @weak_foo() {
; CHECK-LABEL: weak_foo:
; CHECK:         .cfi_startproc
; CHECK-NEXT:  ; %bb.0:
; CHECK-NEXT:    rts
  ret void
}

define weak_odr void @weak_odr_foo() {
; CHECK-LABEL: weak_odr_foo:
; CHECK:         .cfi_startproc
; CHECK-NEXT:  ; %bb.0:
; CHECK-NEXT:    rts
  ret void
}

define internal void @internal_foo() {
; CHECK-LABEL: internal_foo:
; CHECK:         .cfi_startproc
; CHECK-NEXT:  ; %bb.0:
; CHECK-NEXT:    rts
  ret void
}

declare i32 @ext_baz()

define void @foo() {
; CHECK-LABEL: foo:
; CHECK:         .cfi_startproc
; CHECK-NEXT:  ; %bb.0:
; CHECK-NEXT:    rts
  ret void
}

define void @bar() {
; CHECK-LABEL: bar:
; CHECK:         .cfi_startproc
; CHECK-NEXT:  ; %bb.0: ; %entry
; CHECK-NEXT:    suba.l #4, %sp
; CHECK-NEXT:    .cfi_def_cfa_offset -8
; CHECK-NEXT:    jsr (foo@PLT,%pc)
; CHECK-NEXT:    jsr (weak_odr_foo@PLT,%pc)
; CHECK-NEXT:    jsr (weak_foo@PLT,%pc)
; CHECK-NEXT:    jsr (internal_foo,%pc)
; CHECK-NEXT:    jsr (ext_baz@PLT,%pc)
; CHECK-NEXT:    adda.l #4, %sp
; CHECK-NEXT:    rts
entry:
  call void @foo()
  call void @weak_odr_foo()
  call void @weak_foo()
  call void @internal_foo()
  call i32 @ext_baz()
  ret void
}

; -fpie for local global data tests should be added here

!llvm.module.flags = !{!0, !1}
!0 = !{i32 1, !"PIC Level", i32 1}
!1 = !{i32 1, !"PIE Level", i32 1}