2015-03-05 20:04:21 +00:00
|
|
|
; RUN: llc < %s -mtriple aarch64-gnu-linux | FileCheck %s
|
|
|
|
; RUN: llc < %s -mtriple arm64-apple-darwin | FileCheck %s
|
|
|
|
|
|
|
|
target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128"
|
|
|
|
|
|
|
|
; CHECK-LABEL: test_inlineasm_globaladdress:
|
|
|
|
; CHECK: b {{_?}}test_symbol
|
|
|
|
define void @test_inlineasm_globaladdress() {
|
|
|
|
call void asm sideeffect "b $0", "i"(void ()* @test_symbol)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK-LABEL: test_inlineasm_globaladdress_offset:
|
|
|
|
; CHECK: b {{_?}}test_symbol+4
|
|
|
|
define void @test_inlineasm_globaladdress_offset() {
|
2015-03-13 18:20:45 +00:00
|
|
|
call void asm sideeffect "b $0", "i"(void ()* bitcast (i8* getelementptr (i8, i8* bitcast (void ()* @test_symbol to i8*), i64 4) to void ()*))
|
2015-03-05 20:04:21 +00:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
declare void @test_symbol()
|