summaryrefslogtreecommitdiff
path: root/test/CodeGen/AArch64/blockaddress.ll
blob: a7de51d4581aa9d23eeb578dbe3dca7f76854247 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
; RUN: llc -march=aarch64 -verify-machineinstrs < %s | FileCheck %s

@addr = global i8* null

define void @test_blockaddress() {
; CHECK: test_blockaddress:
  store volatile i8* blockaddress(@test_blockaddress, %block), i8** @addr
  %val = load volatile i8** @addr
  indirectbr i8* %val, [label %block]
; CHECK: adrp [[DEST_HI:x[0-9]+]], [[DEST_LBL:.Ltmp[0-9]+]]
; CHECK: add [[DEST:x[0-9]+]], [[DEST_HI]], #:lo12:[[DEST_LBL]]
; CHECK: str [[DEST]],
; CHECK: ldr [[NEWDEST:x[0-9]+]]
; CHECK: br [[NEWDEST]]

block:
  ret void
}