llvm/llvm/test/CodeGen/ARM/pacbti-indirect-tail-calls-function-flags.ll

; RUN: llc -mtriple=thumbv8.1m.main-none-none-eabi -mattr=+pacbti< %s | FileCheck %s

target datalayout = "e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64"
target triple = "thumbv8.1m.main-m.main-unknown"

; When PACBTI is enabled, indirect tail-calls must not use R12 that is used
; to store authentication code.

define void @pacbti_disabled(ptr %p) "sign-return-address"="none" {
entry:
  tail call void %p()
; CHECK: bx {{r0|r1|r2|r3|r12}}
  ret void
}

define void @pacbti_enabled(ptr %p) "sign-return-address"="all" {
entry:
  tail call void %p()
; CHECK: bx {{r0|r1|r2|r3}}
  ret void
}

define void @pacbti_disabled_force_r12(ptr %p) "sign-return-address"="none" {
entry:
  %p_r12 = tail call ptr asm "", "={r12},{r12},~{lr}"(ptr %p)
  tail call void %p_r12()
; CHECK: bx r12
  ret void
}

define void @pacbti_enabled_force_r12(ptr %p) "sign-return-address"="all" {
entry:
  %p_r12 = tail call ptr asm "", "={r12},{r12},~{lr}"(ptr %p)
  tail call void %p_r12()
; CHECK: bx {{r0|r1|r2|r3}}
  ret void
}