mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-25 00:33:15 +00:00
Formatting cleanups. No functionality change.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@149312 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
97cf71a517
commit
06881e8734
@ -570,8 +570,7 @@ static bool HandleCallsInBlockInlinedThroughInvoke(BasicBlock *BB,
|
|||||||
// Otherwise, create the new invoke instruction.
|
// Otherwise, create the new invoke instruction.
|
||||||
ImmutableCallSite CS(CI);
|
ImmutableCallSite CS(CI);
|
||||||
SmallVector<Value*, 8> InvokeArgs(CS.arg_begin(), CS.arg_end());
|
SmallVector<Value*, 8> InvokeArgs(CS.arg_begin(), CS.arg_end());
|
||||||
InvokeInst *II =
|
InvokeInst *II = InvokeInst::Create(CI->getCalledValue(), Split,
|
||||||
InvokeInst::Create(CI->getCalledValue(), Split,
|
|
||||||
Invoke.getOuterUnwindDest(),
|
Invoke.getOuterUnwindDest(),
|
||||||
InvokeArgs, CI->getName(), BB);
|
InvokeArgs, CI->getName(), BB);
|
||||||
II->setCallingConv(CI->getCallingConv());
|
II->setCallingConv(CI->getCallingConv());
|
||||||
@ -581,10 +580,11 @@ static bool HandleCallsInBlockInlinedThroughInvoke(BasicBlock *BB,
|
|||||||
// updates the CallGraph if present, because it uses a WeakVH.
|
// updates the CallGraph if present, because it uses a WeakVH.
|
||||||
CI->replaceAllUsesWith(II);
|
CI->replaceAllUsesWith(II);
|
||||||
|
|
||||||
Split->getInstList().pop_front(); // Delete the original call
|
// Delete the original call
|
||||||
|
Split->getInstList().pop_front();
|
||||||
|
|
||||||
// Update any PHI nodes in the exceptional block to indicate that
|
// Update any PHI nodes in the exceptional block to indicate that there is
|
||||||
// there is now a new entry in them.
|
// now a new entry in them.
|
||||||
Invoke.addIncomingPHIValuesFor(BB);
|
Invoke.addIncomingPHIValuesFor(BB);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -592,7 +592,6 @@ static bool HandleCallsInBlockInlinedThroughInvoke(BasicBlock *BB,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// HandleInlinedInvoke - If we inlined an invoke site, we need to convert calls
|
/// HandleInlinedInvoke - If we inlined an invoke site, we need to convert calls
|
||||||
/// in the body of the inlined function into invokes and turn unwind
|
/// in the body of the inlined function into invokes and turn unwind
|
||||||
/// instructions into branches to the invoke unwind dest.
|
/// instructions into branches to the invoke unwind dest.
|
||||||
@ -874,15 +873,15 @@ static void fixupLineNumbers(Function *Fn, Function::iterator FI,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// InlineFunction - This function inlines the called function into the basic
|
/// InlineFunction - This function inlines the called function into the basic
|
||||||
// block of the caller. This returns false if it is not possible to inline this
|
/// block of the caller. This returns false if it is not possible to inline
|
||||||
// call. The program is still in a well defined state if this occurs though.
|
/// this call. The program is still in a well defined state if this occurs
|
||||||
//
|
/// though.
|
||||||
// Note that this only does one level of inlining. For example, if the
|
///
|
||||||
// instruction 'call B' is inlined, and 'B' calls 'C', then the call to 'C' now
|
/// Note that this only does one level of inlining. For example, if the
|
||||||
// exists in the instruction stream. Similarly this will inline a recursive
|
/// instruction 'call B' is inlined, and 'B' calls 'C', then the call to 'C' now
|
||||||
// function by one level.
|
/// exists in the instruction stream. Similarly this will inline a recursive
|
||||||
//
|
/// function by one level.
|
||||||
bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {
|
bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {
|
||||||
Instruction *TheCall = CS.getInstruction();
|
Instruction *TheCall = CS.getInstruction();
|
||||||
LLVMContext &Context = TheCall->getContext();
|
LLVMContext &Context = TheCall->getContext();
|
||||||
@ -934,7 +933,7 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {
|
|||||||
// Find the personality function used by the landing pads of the caller. If it
|
// Find the personality function used by the landing pads of the caller. If it
|
||||||
// exists, then check to see that it matches the personality function used in
|
// exists, then check to see that it matches the personality function used in
|
||||||
// the callee.
|
// the callee.
|
||||||
if (CalleePersonality)
|
if (CalleePersonality) {
|
||||||
for (Function::const_iterator I = Caller->begin(), E = Caller->end();
|
for (Function::const_iterator I = Caller->begin(), E = Caller->end();
|
||||||
I != E; ++I)
|
I != E; ++I)
|
||||||
if (const InvokeInst *II = dyn_cast<InvokeInst>(I->getTerminator())) {
|
if (const InvokeInst *II = dyn_cast<InvokeInst>(I->getTerminator())) {
|
||||||
@ -950,6 +949,7 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Get an iterator to the last basic block in the function, which will have
|
// Get an iterator to the last basic block in the function, which will have
|
||||||
// the new function inlined after it.
|
// the new function inlined after it.
|
||||||
@ -1016,7 +1016,6 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {
|
|||||||
// block for the callee, move them to the entry block of the caller. First
|
// block for the callee, move them to the entry block of the caller. First
|
||||||
// calculate which instruction they should be inserted before. We insert the
|
// calculate which instruction they should be inserted before. We insert the
|
||||||
// instructions at the end of the current alloca list.
|
// instructions at the end of the current alloca list.
|
||||||
//
|
|
||||||
{
|
{
|
||||||
BasicBlock::iterator InsertPoint = Caller->begin()->begin();
|
BasicBlock::iterator InsertPoint = Caller->begin()->begin();
|
||||||
for (BasicBlock::iterator I = FirstNewBlock->begin(),
|
for (BasicBlock::iterator I = FirstNewBlock->begin(),
|
||||||
@ -1301,11 +1300,12 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {
|
|||||||
// If we inserted a phi node, check to see if it has a single value (e.g. all
|
// If we inserted a phi node, check to see if it has a single value (e.g. all
|
||||||
// the entries are the same or undef). If so, remove the PHI so it doesn't
|
// the entries are the same or undef). If so, remove the PHI so it doesn't
|
||||||
// block other optimizations.
|
// block other optimizations.
|
||||||
if (PHI)
|
if (PHI) {
|
||||||
if (Value *V = SimplifyInstruction(PHI, IFI.TD)) {
|
if (Value *V = SimplifyInstruction(PHI, IFI.TD)) {
|
||||||
PHI->replaceAllUsesWith(V);
|
PHI->replaceAllUsesWith(V);
|
||||||
PHI->eraseFromParent();
|
PHI->eraseFromParent();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user