mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Permit inlining functions that contain dynamic allocations now that
InlineFunction handles this case safely. This implements Transforms/Inline/dynamic_alloca_test.ll. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25288 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f0638c5f71
commit
ccca3ca85f
@ -33,16 +33,6 @@ namespace {
|
||||
// FunctionInfo - For each function, calculate the size of it in blocks and
|
||||
// instructions.
|
||||
struct FunctionInfo {
|
||||
// HasAllocas - Keep track of whether or not a function contains an alloca
|
||||
// instruction that is not in the entry block of the function. Inlining
|
||||
// this call could cause us to blow out the stack, because the stack memory
|
||||
// would never be released.
|
||||
//
|
||||
// FIXME: LLVM needs a way of dealloca'ing memory, which would make this
|
||||
// irrelevant!
|
||||
//
|
||||
bool HasAllocas;
|
||||
|
||||
// NumInsts, NumBlocks - Keep track of how large each function is, which is
|
||||
// used to estimate the code size cost of inlining it.
|
||||
unsigned NumInsts, NumBlocks;
|
||||
@ -53,7 +43,7 @@ namespace {
|
||||
// entry here.
|
||||
std::vector<ArgInfo> ArgumentWeights;
|
||||
|
||||
FunctionInfo() : HasAllocas(false), NumInsts(0), NumBlocks(0) {}
|
||||
FunctionInfo() : NumInsts(0), NumBlocks(0) {}
|
||||
|
||||
/// analyzeFunction - Fill in the current structure with information gleaned
|
||||
/// from the specified function.
|
||||
@ -148,17 +138,9 @@ void FunctionInfo::analyzeFunction(Function *F) {
|
||||
// each instruction counts as 10.
|
||||
for (Function::const_iterator BB = F->begin(), E = F->end(); BB != E; ++BB) {
|
||||
for (BasicBlock::const_iterator II = BB->begin(), E = BB->end();
|
||||
II != E; ++II) {
|
||||
if (!isa<DbgInfoIntrinsic>(II)) ++NumInsts;
|
||||
|
||||
// If there is an alloca in the body of the function, we cannot currently
|
||||
// inline the function without the risk of exploding the stack.
|
||||
if (isa<AllocaInst>(II) && BB != F->begin()) {
|
||||
HasAllocas = true;
|
||||
this->NumBlocks = this->NumInsts = 1;
|
||||
return;
|
||||
}
|
||||
}
|
||||
II != E; ++II)
|
||||
if (!isa<DbgInfoIntrinsic>(II))
|
||||
++NumInsts;
|
||||
|
||||
++NumBlocks;
|
||||
}
|
||||
@ -218,11 +200,6 @@ int SimpleInliner::getInlineCost(CallSite CS) {
|
||||
if (CalleeFI.NumBlocks == 0)
|
||||
CalleeFI.analyzeFunction(Callee);
|
||||
|
||||
// Don't inline calls to functions with allocas that are not in the entry
|
||||
// block of the function.
|
||||
if (CalleeFI.HasAllocas)
|
||||
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
|
||||
// the function will be optimizable. Currently this just looks at arguments
|
||||
|
Loading…
x
Reference in New Issue
Block a user