forked from OSchip/llvm-project
19 lines
568 B
LLVM
19 lines
568 B
LLVM
; RUN: llc -verify-machineinstrs -mtriple=aarch64-none-linux-gnu < %s | FileCheck %s
|
|
@var = global void()* zeroinitializer
|
|
|
|
declare void @bar()
|
|
|
|
define void @foo() {
|
|
; CHECK: foo:
|
|
%func = load void()** @var
|
|
|
|
; Calling a function encourages @foo to use a callee-saved register,
|
|
; which makes it a natural choice for the tail call itself. But we don't
|
|
; want that: the final "br xN" has to use a temporary or argument
|
|
; register.
|
|
call void @bar()
|
|
|
|
tail call void %func()
|
|
; CHECK: br {{x([0-79]|1[0-8])}}
|
|
ret void
|
|
} |