; Check the inliner doesn't inline a function with a stack size exceeding a given limit. ; RUN: opt < %s -passes=inline -S | FileCheck --check-prefixes=ALL,UNLIMITED %s ; RUN: opt < %s -passes=inline -S -inline-max-stacksize=256 | FileCheck --check-prefixes=ALL,LIMITED %s declare void @init(ptr) define internal i32 @foo() { %1 = alloca [65 x i32], align 16 call void @init(ptr %1) %2 = load i32, ptr %1, align 4 ret i32 %2 } define i32 @barNoAttr() { %1 = call i32 @foo() ret i32 %1 ; ALL: define {{.*}}@barNoAttr ; ALL-NOT: define ; UNLIMITED-NOT: call {{.*}}@foo ; LIMITED: call {{.*}}@foo } ; Check that, under the imposed limit, baz() inlines bar(), but not foo(). define i32 @bazNoAttr() { %1 = call i32 @barNoAttr() ret i32 %1 ; ALL: define {{.*}}@baz ; UNLIMITED-NOT: call {{.*}}@barNoAttr ; UNLIMITED-NOT: call {{.*}}@foo ; LIMITED-NOT: call {{.*}}@barNoAttr ; LIMITED: call {{.*}}@foo } ; Check that the function attribute prevents inlining of foo(). define i32 @barAttr() #0 { %1 = call i32 @foo() ret i32 %1 ; ALL: define {{.*}}@barAttr ; ALL-NOT: define ; ALL: call {{.*}}@foo } ; Check that the commandline option overrides the function attribute. define i32 @bazAttr() #1 { %1 = call i32 @barAttr() ret i32 %1 ; ALL: define {{.*}}@bazAttr ; UNLIMITED-NOT: call {{.*}}@barAttr ; UNLIMITED-NOT: call {{.*}}@foo ; LIMITED: call {{.*}}@foo } attributes #0 = { "inline-max-stacksize"="256" } attributes #1 = { "inline-max-stacksize"="512" }