; 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
}