summaryrefslogtreecommitdiff
path: root/test/CodeGen/ARM/pie.ll
blob: 1b1e6e62fda5910243a3e87546121509a4c19be4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
; RUN: llc  -mtriple=armv7-pc-linux-gnueabi -relocation-model=pic < %s | FileCheck %s

@foo = global i32 42

define i32* @get_foo() {
  ret i32* @foo
}

; Test that we only use one load. Even that is only needed because there
; doesn't seem to be pc relative relocations for movw movt.
; CHECK:      ldr     r0, .LCPI0_0
; CHECK-NEXT: .L{{.*}}:
; CHECK-NEXT: add     r0, pc, r0
; CHECK-NEXT: bx      lr

!llvm.module.flags = !{!0}

!0 = !{i32 1, !"PIE Level", i32 2}