Author: rtrieu Date: Mon Oct 22 18:26:28 2018 New Revision: 344987 URL: http://llvm.org/viewvc/llvm-project?rev=344987&view=rev Log: [CodeGen] Attach InlineHint to more functions
For instantiated functions, search the template pattern to see if it marked inline to determine if InlineHint attribute should be added to the function. Added: cfe/trunk/test/CodeGenCXX/inline-template-hint.cpp Modified: cfe/trunk/lib/CodeGen/CodeGenModule.cpp Modified: cfe/trunk/lib/CodeGen/CodeGenModule.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CodeGenModule.cpp?rev=344987&r1=344986&r2=344987&view=diff ============================================================================== --- cfe/trunk/lib/CodeGen/CodeGenModule.cpp (original) +++ cfe/trunk/lib/CodeGen/CodeGenModule.cpp Mon Oct 22 18:26:28 2018 @@ -1299,9 +1299,19 @@ void CodeGenModule::SetLLVMFunctionAttri // Otherwise, propagate the inline hint attribute and potentially use its // absence to mark things as noinline. if (auto *FD = dyn_cast<FunctionDecl>(D)) { - if (any_of(FD->redecls(), [&](const FunctionDecl *Redecl) { - return Redecl->isInlineSpecified(); - })) { + // Search function and template pattern redeclarations for inline. + auto CheckForInline = [](const FunctionDecl *FD) { + auto CheckRedeclForInline = [](const FunctionDecl *Redecl) { + return Redecl->isInlineSpecified(); + }; + if (any_of(FD->redecls(), CheckRedeclForInline)) + return true; + const FunctionDecl *Pattern = FD->getTemplateInstantiationPattern(); + if (!Pattern) + return false; + return any_of(Pattern->redecls(), CheckRedeclForInline); + }; + if (CheckForInline(FD)) { B.addAttribute(llvm::Attribute::InlineHint); } else if (CodeGenOpts.getInlining() == CodeGenOptions::OnlyHintInlining && Added: cfe/trunk/test/CodeGenCXX/inline-template-hint.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/inline-template-hint.cpp?rev=344987&view=auto ============================================================================== --- cfe/trunk/test/CodeGenCXX/inline-template-hint.cpp (added) +++ cfe/trunk/test/CodeGenCXX/inline-template-hint.cpp Mon Oct 22 18:26:28 2018 @@ -0,0 +1,34 @@ +// RUN: %clang_cc1 %s -std=c++11 -triple=x86_64-linux -O2 \ +// RUN: -finline-functions -emit-llvm -disable-llvm-passes -o - \ +// RUN: | FileCheck -allow-deprecated-dag-overlap %s \ +// RUN: --check-prefix=CHECK --check-prefix=SUITABLE +// RUN: %clang_cc1 %s -std=c++11 -triple=x86_64-linux -O2 \ +// RUN: -finline-hint-functions -emit-llvm -disable-llvm-passes -o - \ +// RUN: | FileCheck -allow-deprecated-dag-overlap %s \ +// RUN: --check-prefix=CHECK --check-prefix=HINTED +// RUN: %clang_cc1 %s -std=c++11 -triple=x86_64-linux -O2 \ +// RUN: -fno-inline -emit-llvm -disable-llvm-passes -o - \ +// RUN: | FileCheck -allow-deprecated-dag-overlap %s \ +// RUN: --check-prefix=CHECK --check-prefix=NOINLINE + +struct A { + inline void int_run(int); + + template <class T> + inline void template_run(T); +}; + +// CHECK: @_ZN1A7int_runEi({{.*}}) [[ATTR:#[0-9]+]] +void A::int_run(int) {} +// CHECK: @_ZN1A12template_runIiEEvT_({{.*}}) [[ATTR]] +template <typename T> +void A::template_run(T) {} + +void bar() { + A().int_run(1); + A().template_run(1); +} + +// SUITABLE: attributes [[ATTR]] = { {{.*}}inlinehint{{.*}} } +// HINTED: attributes [[ATTR]] = { {{.*}}inlinehint{{.*}} } +// NOINLINE: attributes [[ATTR]] = { {{.*}}noinline{{.*}} } _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits