1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 12:12:47 +01:00
llvm-mirror/test/Transforms/Inline/inline_noprofile.ll
Nick Desaulniers fd64c3a741 [Inline] prevent inlining on noprofile mismatch
Similar to
commit bc044a88ee3c ("[Inline] prevent inlining on stack protector mismatch")

The noprofile function attribute is meant to prevent compiler
instrumentation from being inserted into a function. Inlining may defeat
the developer's intent. If the caller and callee don't either BOTH have
the attribute or BOTH lack the attribute, suppress inline substitution.

This matches behavior being proposed in GCC:
https://gcc.gnu.org/pipermail/gcc-patches/2021-June/573511.html
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=80223

Add LangRef entry for noprofile fn attr, similar to text added in D93422
and D104944.

Reviewed By: MaskRay, melver, phosek

Differential Revision: https://reviews.llvm.org/D104810
2021-06-29 10:32:03 -07:00

45 lines
1.5 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt -passes=inline %s -S -pass-remarks-missed=inline 2>&1 | FileCheck %s --check-prefixes=CHECK,CHECK-INLINE
; RUN: opt -passes=always-inline %s -S | FileCheck %s
; Test that we don't inline when caller and callee don't have matching
; noprofile fn attrs.
; CHECK-INLINE: profile not inlined into profile_caller because it should never be inlined (cost=never): conflicting attributes
; CHECK-INLINE: noprofile not inlined into noprofile_caller because it should never be inlined (cost=never): conflicting attributes
define i32 @profile() { ret i32 42 }
define i32 @noprofile() noprofile { ret i32 43 }
define i32 @profile_aa() alwaysinline { ret i32 44 }
define i32 @noprofile_aa() noprofile alwaysinline { ret i32 45 }
define i32 @profile_caller() noprofile {
; CHECK-LABEL: @profile_caller(
; CHECK-NEXT: [[TMP1:%.*]] = call i32 @profile()
; CHECK-NEXT: ret i32 44
;
call i32 @profile()
%2 = call i32 @profile_aa()
ret i32 %2
}
define i32 @noprofile_caller() {
; CHECK-LABEL: @noprofile_caller(
; CHECK-NEXT: [[TMP1:%.*]] = call i32 @noprofile()
; CHECK-NEXT: ret i32 45
;
call i32 @noprofile()
%2 = call i32 @noprofile_aa()
ret i32 %2
}
; Test that we do inline when caller and callee don't have matching
; noprofile fn attrs, when CallInst is alwaysinline.
define i32 @aa_callsite() {
; CHECK-INLINE-LABEL: @aa_callsite(
; CHECK-INLINE-NEXT: ret i32 43
;
%1 = call i32 @noprofile() alwaysinline
ret i32 %1
}