llvm/llvm/test/Transforms/Inline/inline_noprofile.ll

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