[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / AArch64 / addr-of-ret-addr.ll
bloba6bc36441b115472dc152b2425362cddd3e97607
1 ; RUN: llc < %s -frame-pointer=all -mtriple=arm64-windows | FileCheck %s
3 ; Test generated from C code:
4 ; #include <stdarg.h>
5 ; void *foo() {
6 ;   return _AddressOfReturnAddress();
7 ; }
8 ; int bar(int x(va_list, void*), ...) {
9 ;   va_list y;
10 ;   va_start(y, x);
11 ;   return x(y, _AddressOfReturnAddress()) + 1;
12 ; }
14 declare void @llvm.va_start(i8*)
15 declare i8* @llvm.addressofreturnaddress()
17 define dso_local i8* @"foo"() {
18 entry:
19   %0 = call i8* @llvm.addressofreturnaddress()
20   ret i8* %0
22 ; CHECK-LABEL: foo
23 ; CHECK: stp x29, x30, [sp, #-16]!
24 ; CHECK: mov x29, sp
25 ; CHECK: add x0, x29, #8
26 ; CHECK: ldp x29, x30, [sp], #16
29 define dso_local i32 @"bar"(i32 (i8*, i8*)* %x, ...) {
30 entry:
31   %x.addr = alloca i32 (i8*, i8*)*, align 8
32   %y = alloca i8*, align 8
33   store i32 (i8*, i8*)* %x, i32 (i8*, i8*)** %x.addr, align 8
34   %y1 = bitcast i8** %y to i8*
35   call void @llvm.va_start(i8* %y1)
36   %0 = load i32 (i8*, i8*)*, i32 (i8*, i8*)** %x.addr, align 8
37   %1 = call i8* @llvm.addressofreturnaddress()
38   %2 = load i8*, i8** %y, align 8
39   %call = call i32 %0(i8* %2, i8* %1)
40   %add = add nsw i32 %call, 1
41   ret i32 %add
43 ; CHECK-LABEL: bar
44 ; CHECK: sub sp, sp, #96
45 ; CHECK: stp x29, x30, [sp, #16]
46 ; CHECK: add x29, sp, #16
47 ; CHECK: stp x1, x2, [x29, #24]
48 ; CHECK: add x1, x29, #8
49 ; CHECK: ldp x29, x30, [sp, #16]
50 ; CHECK: add sp, sp, #96