Files
clang-p2996/llvm/test/Transforms/Inline/inline-cost-dead-users.ll
Erik Desjardins 11c8efd4db [Inline] Introduce Constant::hasOneLiveUse, use it instead of hasOneUse in inline cost model (PR51667)
Otherwise, inlining costs may be pessimized by dead constants.

Fixes https://bugs.llvm.org/show_bug.cgi?id=51667.

Reviewed By: mtrofin, aeubanks

Differential Revision: https://reviews.llvm.org/D109294
2021-10-07 08:33:25 -07:00

33 lines
961 B
LLVM

; Test to ensure that the inlining cost model isn't tripped up by dead constant users.
; In this case, the call to g via a bitcasted function pointer is canonicalized to
; a direct call to g with bitcasted arguments, leaving the original bitcast
; as a dead use of g.
; RUN: opt < %s -instcombine -inline -pass-remarks=inline -S 2>&1 \
; RUN: | FileCheck %s
; Inline costs of f and g should be the same.
; CHECK: 'f' inlined into 'h' with (cost=[[EXPECTED_COST:.+]], threshold={{.+}})
; CHECK: 'g' inlined into 'h' with (cost=[[EXPECTED_COST]], threshold={{.+}})
%0 = type { i64, i64, i64 }
%1 = type { i64, i64, i64 }
define internal void @f(%0* align 8 %a) unnamed_addr {
start:
ret void
}
define internal void @g(%0* align 8 %a) unnamed_addr {
start:
ret void
}
define void @h(%0* align 8 %a, %1* align 8 %b) unnamed_addr {
start:
call void @f(%0* align 8 %a)
call void bitcast (void (%0*)* @g to void (%1*)*)(%1* align 8 %b)
ret void
}