diff options
Diffstat (limited to 'contrib/llvm/lib/Transforms/Utils/InlineFunction.cpp')
| -rw-r--r-- | contrib/llvm/lib/Transforms/Utils/InlineFunction.cpp | 78 | 
1 files changed, 56 insertions, 22 deletions
| diff --git a/contrib/llvm/lib/Transforms/Utils/InlineFunction.cpp b/contrib/llvm/lib/Transforms/Utils/InlineFunction.cpp index 8416170d9032..d5b382e55e5c 100644 --- a/contrib/llvm/lib/Transforms/Utils/InlineFunction.cpp +++ b/contrib/llvm/lib/Transforms/Utils/InlineFunction.cpp @@ -449,11 +449,8 @@ static bool HandleCallsInBlockInlinedThroughInvoke(BasicBlock *BB,        for (unsigned i = 2, e = Outer->getNumArgOperands(); i != e; ++i)          NewSelector.push_back(Outer->getArgOperand(i)); -      CallInst *NewInner = CallInst::Create(Inner->getCalledValue(), -                                            NewSelector.begin(), -                                            NewSelector.end(), -                                            "", -                                            Inner); +      CallInst *NewInner = +        IRBuilder<>(Inner).CreateCall(Inner->getCalledValue(), NewSelector);        // No need to copy attributes, calling convention, etc.        NewInner->takeName(Inner);        Inner->replaceAllUsesWith(NewInner); @@ -489,8 +486,7 @@ static bool HandleCallsInBlockInlinedThroughInvoke(BasicBlock *BB,      InvokeInst *II =        InvokeInst::Create(CI->getCalledValue(), Split,                           Invoke.getOuterUnwindDest(), -                         InvokeArgs.begin(), InvokeArgs.end(), -                         CI->getName(), BB); +                         InvokeArgs, CI->getName(), BB);      II->setCallingConv(CI->getCallingConv());      II->setAttributes(CI->getAttributes()); @@ -664,7 +660,7 @@ static Value *HandleByValArgument(Value *Arg, Instruction *TheCall,    LLVMContext &Context = Arg->getContext(); -  const Type *VoidPtrTy = Type::getInt8PtrTy(Context); +  Type *VoidPtrTy = Type::getInt8PtrTy(Context);    // Create the alloca.  If we have TargetData, use nice alignment.    unsigned Align = 1; @@ -681,10 +677,10 @@ static Value *HandleByValArgument(Value *Arg, Instruction *TheCall,    Value *NewAlloca = new AllocaInst(AggTy, 0, Align, Arg->getName(),                                       &*Caller->begin()->begin());    // Emit a memcpy. -  const Type *Tys[3] = {VoidPtrTy, VoidPtrTy, Type::getInt64Ty(Context)}; +  Type *Tys[3] = {VoidPtrTy, VoidPtrTy, Type::getInt64Ty(Context)};    Function *MemCpyFn = Intrinsic::getDeclaration(Caller->getParent(),                                                   Intrinsic::memcpy,  -                                                 Tys, 3); +                                                 Tys);    Value *DestCast = new BitCastInst(NewAlloca, VoidPtrTy, "tmp", TheCall);    Value *SrcCast = new BitCastInst(Arg, VoidPtrTy, "tmp", TheCall); @@ -703,7 +699,7 @@ static Value *HandleByValArgument(Value *Arg, Instruction *TheCall,      ConstantInt::get(Type::getInt32Ty(Context), 1),      ConstantInt::getFalse(Context) // isVolatile    }; -  CallInst::Create(MemCpyFn, CallArgs, CallArgs+5, "", TheCall); +  IRBuilder<>(TheCall).CreateCall(MemCpyFn, CallArgs);    // Uses of the argument in the function should use our new alloca    // instead. @@ -734,17 +730,52 @@ static bool hasLifetimeMarkers(AllocaInst *AI) {    if (AI->getType() == Int8PtrTy)      return isUsedByLifetimeMarker(AI); -  // Do a scan to find all the bitcasts to i8*. +  // Do a scan to find all the casts to i8*.    for (Value::use_iterator I = AI->use_begin(), E = AI->use_end(); I != E;         ++I) {      if (I->getType() != Int8PtrTy) continue; -    if (!isa<BitCastInst>(*I)) continue; +    if (I->stripPointerCasts() != AI) continue;      if (isUsedByLifetimeMarker(*I))        return true;    }    return false;  } +/// updateInlinedAtInfo - Helper function used by fixupLineNumbers to recursively +/// update InlinedAtEntry of a DebugLoc. +static DebugLoc updateInlinedAtInfo(const DebugLoc &DL,  +                                    const DebugLoc &InlinedAtDL, +                                    LLVMContext &Ctx) { +  if (MDNode *IA = DL.getInlinedAt(Ctx)) { +    DebugLoc NewInlinedAtDL  +      = updateInlinedAtInfo(DebugLoc::getFromDILocation(IA), InlinedAtDL, Ctx); +    return DebugLoc::get(DL.getLine(), DL.getCol(), DL.getScope(Ctx), +                         NewInlinedAtDL.getAsMDNode(Ctx)); +  } +                                              +  return DebugLoc::get(DL.getLine(), DL.getCol(), DL.getScope(Ctx), +                       InlinedAtDL.getAsMDNode(Ctx)); +} + + +/// fixupLineNumbers - Update inlined instructions' line numbers to  +/// to encode location where these instructions are inlined. +static void fixupLineNumbers(Function *Fn, Function::iterator FI, +                              Instruction *TheCall) { +  DebugLoc TheCallDL = TheCall->getDebugLoc(); +  if (TheCallDL.isUnknown()) +    return; + +  for (; FI != Fn->end(); ++FI) { +    for (BasicBlock::iterator BI = FI->begin(), BE = FI->end(); +         BI != BE; ++BI) { +      DebugLoc DL = BI->getDebugLoc(); +      if (!DL.isUnknown()) +        BI->setDebugLoc(updateInlinedAtInfo(DL, TheCallDL, BI->getContext())); +    } +  } +} +  // 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  // call.  The program is still in a well defined state if this occurs though. @@ -847,6 +878,9 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {      // Update the callgraph if requested.      if (IFI.CG)        UpdateCallGraphAfterInlining(CS, FirstNewBlock, VMap, IFI); + +    // Update inlined instructions' line number information. +    fixupLineNumbers(Caller, FirstNewBlock, TheCall);    }    // If there are any alloca instructions in the block that used to be the entry @@ -920,13 +954,13 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {      Function *StackRestore=Intrinsic::getDeclaration(M,Intrinsic::stackrestore);      // Insert the llvm.stacksave. -    CallInst *SavedPtr = CallInst::Create(StackSave, "savedstack", -                                          FirstNewBlock->begin()); +    CallInst *SavedPtr = IRBuilder<>(FirstNewBlock, FirstNewBlock->begin()) +      .CreateCall(StackSave, "savedstack");      // Insert a call to llvm.stackrestore before any return instructions in the      // inlined function.      for (unsigned i = 0, e = Returns.size(); i != e; ++i) { -      CallInst::Create(StackRestore, SavedPtr, "", Returns[i]); +      IRBuilder<>(Returns[i]).CreateCall(StackRestore, SavedPtr);      }      // Count the number of StackRestore calls we insert. @@ -938,7 +972,7 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {        for (Function::iterator BB = FirstNewBlock, E = Caller->end();             BB != E; ++BB)          if (UnwindInst *UI = dyn_cast<UnwindInst>(BB->getTerminator())) { -          CallInst::Create(StackRestore, SavedPtr, "", UI); +          IRBuilder<>(UI).CreateCall(StackRestore, SavedPtr);            ++NumStackRestores;          }      } @@ -1098,15 +1132,15 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {          TheCall->replaceAllUsesWith(Returns[0]->getReturnValue());      } +    // Update PHI nodes that use the ReturnBB to use the AfterCallBB. +    BasicBlock *ReturnBB = Returns[0]->getParent(); +    ReturnBB->replaceAllUsesWith(AfterCallBB); +      // Splice the code from the return block into the block that it will return      // to, which contains the code that was after the call. -    BasicBlock *ReturnBB = Returns[0]->getParent();      AfterCallBB->getInstList().splice(AfterCallBB->begin(),                                        ReturnBB->getInstList()); -    // Update PHI nodes that use the ReturnBB to use the AfterCallBB. -    ReturnBB->replaceAllUsesWith(AfterCallBB); -      // Delete the return instruction now and empty ReturnBB now.      Returns[0]->eraseFromParent();      ReturnBB->eraseFromParent(); @@ -1126,8 +1160,8 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI) {    // Splice the code entry block into calling block, right before the    // unconditional branch. -  OrigBB->getInstList().splice(Br, CalleeEntry->getInstList());    CalleeEntry->replaceAllUsesWith(OrigBB);  // Update PHI nodes +  OrigBB->getInstList().splice(Br, CalleeEntry->getInstList());    // Remove the unconditional branch.    OrigBB->getInstList().erase(Br); | 
