[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / AArch64 / sign-return-address-tailcall.ll
blobec04e553cac6e376e4cb09ab929d7f23ed577449
1 ; RUN: llc -mtriple=aarch64 -asm-verbose=0 < %s | FileCheck -DAUTIASP="hint #29" --check-prefixes=COMMON %s
2 ; RUN: llc -mtriple=aarch64 -asm-verbose=0 -aarch64-authenticated-lr-check-method=load                   < %s | FileCheck -DAUTIASP="hint #29" --check-prefixes=COMMON,LDR %s
3 ; RUN: llc -mtriple=aarch64 -asm-verbose=0 -aarch64-authenticated-lr-check-method=high-bits-notbi        < %s | FileCheck -DAUTIASP="hint #29" --check-prefixes=COMMON,BITS-NOTBI,BRK %s
4 ; RUN: llc -mtriple=aarch64 -asm-verbose=0 -aarch64-authenticated-lr-check-method=xpac-hint              < %s | FileCheck -DAUTIASP="hint #29" -DXPACLRI="hint #7" --check-prefixes=COMMON,XPAC,BRK %s
5 ; RUN: llc -mtriple=aarch64 -asm-verbose=0 -aarch64-authenticated-lr-check-method=xpac-hint -mattr=v8.3a < %s | FileCheck -DAUTIASP="autiasp"  -DXPACLRI="xpaclri" --check-prefixes=COMMON,XPAC,BRK %s
7 define i32 @tailcall_direct() "sign-return-address"="non-leaf" {
8 ; COMMON-LABEL: tailcall_direct:
9 ; COMMON:         str x30, [sp, #-16]!
10 ; COMMON:         ldr x30, [sp], #16
12 ; COMMON-NEXT:    [[AUTIASP]]
14 ; LDR-NEXT:       ldr w16, [x30]
16 ; BITS-NOTBI-NEXT: eor x16, x30, x30, lsl #1
17 ; BITS-NOTBI-NEXT: tbnz x16, #62, .[[FAIL:LBB[_0-9]+]]
19 ; XPAC-NEXT:      mov x16, x30
20 ; XPAC-NEXT:      [[XPACLRI]]
21 ; XPAC-NEXT:      cmp x16, x30
22 ; XPAC-NEXT:      b.ne .[[FAIL:LBB[_0-9]+]]
24 ; COMMON-NEXT:    b callee
25 ; BRK-NEXT:     .[[FAIL]]:
26 ; BRK-NEXT:       brk #0xc471
27   tail call void asm sideeffect "", "~{lr}"()
28   %call = tail call i32 @callee()
29   ret i32 %call
32 define i32 @tailcall_indirect(ptr %fptr) "sign-return-address"="non-leaf" {
33 ; COMMON-LABEL: tailcall_indirect:
34 ; COMMON:         str x30, [sp, #-16]!
35 ; COMMON:         ldr x30, [sp], #16
37 ; COMMON-NEXT:    [[AUTIASP]]
39 ; LDR-NEXT:       ldr w16, [x30]
41 ; BITS-NOTBI-NEXT: eor x16, x30, x30, lsl #1
42 ; BITS-NOTBI-NEXT: tbnz x16, #62, .[[FAIL:LBB[_0-9]+]]
44 ; XPAC-NEXT:      mov x16, x30
45 ; XPAC-NEXT:      [[XPACLRI]]
46 ; XPAC-NEXT:      cmp x16, x30
47 ; XPAC-NEXT:      b.ne .[[FAIL:LBB[_0-9]+]]
49 ; COMMON-NEXT:    br x0
50 ; BRK-NEXT:     .[[FAIL]]:
51 ; BRK-NEXT:       brk #0xc471
52   tail call void asm sideeffect "", "~{lr}"()
53   %call = tail call i32 %fptr()
54   ret i32 %call
57 define i32 @tailcall_direct_noframe() "sign-return-address"="non-leaf" {
58 ; COMMON-LABEL: tailcall_direct_noframe:
59 ; COMMON-NEXT:    .cfi_startproc
60 ; COMMON-NEXT:    b callee
61   %call = tail call i32 @callee()
62   ret i32 %call
65 define i32 @tailcall_indirect_noframe(ptr %fptr) "sign-return-address"="non-leaf" {
66 ; COMMON-LABEL: tailcall_indirect_noframe:
67 ; COMMON-NEXT:    .cfi_startproc
68 ; COMMON-NEXT:    br x0
69   %call = tail call i32 %fptr()
70   ret i32 %call
73 define i32 @tailcall_direct_noframe_sign_all() "sign-return-address"="all" {
74 ; COMMON-LABEL: tailcall_direct_noframe_sign_all:
75 ; COMMON-NOT:     str{{.*}}x30
76 ; COMMON-NOT:     ldr{{.*}}x30
78 ; COMMON:         [[AUTIASP]]
80 ; LDR-NEXT:       ldr w16, [x30]
82 ; BITS-NOTBI-NEXT: eor x16, x30, x30, lsl #1
83 ; BITS-NOTBI-NEXT: tbnz x16, #62, .[[FAIL:LBB[_0-9]+]]
85 ; XPAC-NEXT:      mov x16, x30
86 ; XPAC-NEXT:      [[XPACLRI]]
87 ; XPAC-NEXT:      cmp x16, x30
88 ; XPAC-NEXT:      b.ne .[[FAIL:LBB[_0-9]+]]
90 ; COMMON-NEXT:    b callee
91 ; BRK-NEXT:     .[[FAIL]]:
92 ; BRK-NEXT:       brk #0xc471
93   %call = tail call i32 @callee()
94   ret i32 %call
97 define i32 @tailcall_indirect_noframe_sign_all(ptr %fptr) "sign-return-address"="all" {
98 ; COMMON-LABEL: tailcall_indirect_noframe_sign_all:
99 ; COMMON-NOT:     str{{.*}}x30
100 ; COMMON-NOT:     ldr{{.*}}x30
102 ; COMMON:         [[AUTIASP]]
104 ; LDR-NEXT:       ldr w16, [x30]
106 ; BITS-NOTBI-NEXT: eor x16, x30, x30, lsl #1
107 ; BITS-NOTBI-NEXT: tbnz x16, #62, .[[FAIL:LBB[_0-9]+]]
109 ; XPAC-NEXT:      mov x16, x30
110 ; XPAC-NEXT:      [[XPACLRI]]
111 ; XPAC-NEXT:      cmp x16, x30
112 ; XPAC-NEXT:      b.ne .[[FAIL:LBB[_0-9]+]]
114 ; COMMON-NEXT:    br x0
115 ; BRK-NEXT:     .[[FAIL]]:
116 ; BRK-NEXT:       brk #0xc471
117   %call = tail call i32 %fptr()
118   ret i32 %call
121 declare i32 @callee()