mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
Handle "always inline" note during inline cost analysis.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55712 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5e06010462
commit
67243399dd
@ -140,12 +140,7 @@ bool Inliner::runOnSCC(const std::vector<CallGraphNode*> &SCC) {
|
||||
int InlineCost = getInlineCost(CS);
|
||||
float FudgeFactor = getInlineFudgeFactor(CS);
|
||||
|
||||
Function *Fn = CS.getCalledFunction();
|
||||
bool AlwaysInline = false;
|
||||
if (Fn && (Fn->getNotes() & FN_NOTE_AlwaysInline))
|
||||
AlwaysInline = true;
|
||||
if (!AlwaysInline
|
||||
&& InlineCost >= (int)(InlineThreshold * FudgeFactor)) {
|
||||
if (InlineCost >= (int)(InlineThreshold * FudgeFactor)) {
|
||||
DOUT << " NOT Inlining: cost=" << InlineCost
|
||||
<< ", Call: " << *CS.getInstruction();
|
||||
} else {
|
||||
|
@ -221,6 +221,9 @@ int InlineCostAnalyzer::getInlineCost(CallSite CS,
|
||||
// If we should never inline this, return a huge cost.
|
||||
if (CalleeFI.NeverInline)
|
||||
return 2000000000;
|
||||
|
||||
if (Callee->getNotes() & FN_NOTE_AlwaysInline)
|
||||
return -2000000000;
|
||||
|
||||
// Add to the inline quality for properties that make the call valuable to
|
||||
// inline. This includes factors that indicate that the result of inlining
|
||||
|
Loading…
x
Reference in New Issue
Block a user