summaryrefslogtreecommitdiff
path: root/test/CodeGen/AArch64
diff options
context:
space:
mode:
authorTim Northover <Tim.Northover@arm.com>2013-02-28 14:36:31 +0000
committerTim Northover <Tim.Northover@arm.com>2013-02-28 14:36:31 +0000
commit6ff20f205b2aa126b268bcada9920f56715161be (patch)
treeeee57d62d7c938a0dbe738a9be3297f7d0334f6e /test/CodeGen/AArch64
parent5366ab21f4595d0e3888b2d23f38469da2465b8d (diff)
downloadllvm-6ff20f205b2aa126b268bcada9920f56715161be.tar.gz
llvm-6ff20f205b2aa126b268bcada9920f56715161be.tar.bz2
llvm-6ff20f205b2aa126b268bcada9920f56715161be.tar.xz
AArch64: be more careful resorting to inefficient addressing for weak vars.
If an otherwise weak var is actually defined in this unit, it can't be undefined at runtime so we can use normal global variable sequences (ADRP/ADD) to access it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@176259 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/AArch64')
-rw-r--r--test/CodeGen/AArch64/extern-weak.ll8
1 files changed, 8 insertions, 0 deletions
diff --git a/test/CodeGen/AArch64/extern-weak.ll b/test/CodeGen/AArch64/extern-weak.ll
index f358243bc6..3d3d867681 100644
--- a/test/CodeGen/AArch64/extern-weak.ll
+++ b/test/CodeGen/AArch64/extern-weak.ll
@@ -24,4 +24,12 @@ define i32* @bar() {
; CHECK: ldr [[BASE:x[0-9]+]], [{{x[0-9]+}}, #:lo12:.LCPI1_0]
; CHECK: add x0, [[BASE]], #20
ret i32* %addr
+}
+
+@defined_weak_var = internal unnamed_addr global i32 0
+
+define i32* @wibble() {
+ ret i32* @defined_weak_var
+; CHECK: adrp [[BASE:x[0-9]+]], defined_weak_var
+; CHECK: add x0, [[BASE]], #:lo12:defined_weak_var
} \ No newline at end of file