[FuncSpec] Consider small noinline functions for specialisation

Small functions with size under a given threshold are not
considered for specialisaion on the presumption that they
are easy to inline. This does not apply to `noinline`
functions, though.

Reviewed By: ChuanqiXu

Differential Revision: https://reviews.llvm.org/D135862
This commit is contained in:
Momchil Velikov 2022-10-25 18:56:31 +01:00
parent b5d5813762
commit c47739b45c
2 changed files with 38 additions and 5 deletions

View File

@ -552,11 +552,9 @@ private:
// inlined so that we shouldn't specialize it.
if (Metrics.notDuplicatable || !Metrics.NumInsts.isValid() ||
(!ForceFunctionSpecialization &&
Metrics.NumInsts < SmallFunctionThreshold)) {
InstructionCost C{};
C.setInvalid();
return C;
}
!F->hasFnAttribute(Attribute::NoInline) &&
Metrics.NumInsts < SmallFunctionThreshold))
return InstructionCost::getInvalid();
// Otherwise, set the specialization cost to be the cost of all the
// instructions in the function and penalty for specializing more functions.

View File

@ -0,0 +1,35 @@
; RUN: opt -S --passes=function-specialization < %s | FileCheck %s
define dso_local i32 @p0(i32 noundef %x) {
entry:
%add = add nsw i32 %x, 1
ret i32 %add
}
define dso_local i32 @p1(i32 noundef %x) {
entry:
%sub = add nsw i32 %x, -1
ret i32 %sub
}
define internal fastcc i32 @f(i32 noundef %x, ptr nocapture noundef readonly %p) noinline {
entry:
%call = tail call i32 %p(i32 noundef %x)
%add = add nsw i32 %call, %x
ret i32 %add
}
define dso_local i32 @g0(i32 noundef %x) {
entry:
%call = tail call fastcc i32 @f(i32 noundef %x, ptr noundef nonnull @p0)
ret i32 %call
}
define dso_local i32 @g1(i32 noundef %x) {
entry:
%call = tail call fastcc i32 @f(i32 noundef %x, ptr noundef nonnull @p1)
ret i32 %call
}
; Check that a noinline function is specialized, even if it's small.
; CHECK: @f.1
; CHECK: @f.2