| Tim Northover | 3b0846e | 2014-05-24 12:50:23 +0000 | [diff] [blame] | 1 | ; RUN: llc -mtriple=aarch64-linux-gnu -verify-machineinstrs -relocation-model=pic %s -o - | FileCheck %s | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 2 |  | 
|  | 3 | @var = global i32 0 | 
|  | 4 |  | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 5 | define i32 @get_globalvar() { | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 6 | ; CHECK-LABEL: get_globalvar: | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 7 |  | 
| David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame^] | 8 | %val = load i32, i32* @var | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 9 | ; CHECK: adrp x[[GOTHI:[0-9]+]], :got:var | 
| Tim Northover | c398cd5 | 2014-04-14 12:50:58 +0000 | [diff] [blame] | 10 | ; CHECK: ldr x[[GOTLOC:[0-9]+]], [x[[GOTHI]], {{#?}}:got_lo12:var] | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 11 | ; CHECK: ldr w0, [x[[GOTLOC]]] | 
|  | 12 |  | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 13 | ret i32 %val | 
|  | 14 | } | 
|  | 15 |  | 
|  | 16 | define i32* @get_globalvaraddr() { | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 17 | ; CHECK-LABEL: get_globalvaraddr: | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 18 |  | 
| David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame^] | 19 | %val = load i32, i32* @var | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 20 | ; CHECK: adrp x[[GOTHI:[0-9]+]], :got:var | 
| Tim Northover | c398cd5 | 2014-04-14 12:50:58 +0000 | [diff] [blame] | 21 | ; CHECK: ldr x0, [x[[GOTHI]], {{#?}}:got_lo12:var] | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 22 |  | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 23 | ret i32* @var | 
|  | 24 | } | 
|  | 25 |  | 
|  | 26 | @hiddenvar = hidden global i32 0 | 
|  | 27 |  | 
|  | 28 | define i32 @get_hiddenvar() { | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 29 | ; CHECK-LABEL: get_hiddenvar: | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 30 |  | 
| David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame^] | 31 | %val = load i32, i32* @hiddenvar | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 32 | ; CHECK: adrp x[[HI:[0-9]+]], hiddenvar | 
| Tim Northover | c398cd5 | 2014-04-14 12:50:58 +0000 | [diff] [blame] | 33 | ; CHECK: ldr w0, [x[[HI]], {{#?}}:lo12:hiddenvar] | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 34 |  | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 35 | ret i32 %val | 
|  | 36 | } | 
|  | 37 |  | 
|  | 38 | define i32* @get_hiddenvaraddr() { | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 39 | ; CHECK-LABEL: get_hiddenvaraddr: | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 40 |  | 
| David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame^] | 41 | %val = load i32, i32* @hiddenvar | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 42 | ; CHECK: adrp [[HI:x[0-9]+]], hiddenvar | 
| Tim Northover | c398cd5 | 2014-04-14 12:50:58 +0000 | [diff] [blame] | 43 | ; CHECK: add x0, [[HI]], {{#?}}:lo12:hiddenvar | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 44 |  | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 45 | ret i32* @hiddenvar | 
|  | 46 | } | 
|  | 47 |  | 
|  | 48 | define void()* @get_func() { | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 49 | ; CHECK-LABEL: get_func: | 
| Tim Northover | e0e3aef | 2013-01-31 12:12:40 +0000 | [diff] [blame] | 50 |  | 
|  | 51 | ret void()* bitcast(void()*()* @get_func to void()*) | 
|  | 52 | ; CHECK: adrp x[[GOTHI:[0-9]+]], :got:get_func | 
| Tim Northover | c398cd5 | 2014-04-14 12:50:58 +0000 | [diff] [blame] | 53 | ; CHECK: ldr x0, [x[[GOTHI]], {{#?}}:got_lo12:get_func] | 
| Stephen Lin | f799e3f | 2013-07-13 20:38:47 +0000 | [diff] [blame] | 54 | } |