diff options
| author | Reid Kleckner <reid@kleckner.net> | 2014-09-02 18:42:44 +0000 | 
|---|---|---|
| committer | Reid Kleckner <reid@kleckner.net> | 2014-09-02 18:42:44 +0000 | 
| commit | 0b2bccc3cd831f74d051d5ce9e8a157ff7f28d12 (patch) | |
| tree | 7143725e28fe7dffbac1409e3162725da7744117 /llvm/lib | |
| parent | 965de3050f4b82a190f8ee0f11d1478d6cfce4d8 (diff) | |
| download | bcm5719-llvm-0b2bccc3cd831f74d051d5ce9e8a157ff7f28d12.tar.gz bcm5719-llvm-0b2bccc3cd831f74d051d5ce9e8a157ff7f28d12.zip | |
CodeGen: Handle va_start in the entry block
Also fix a small copy-paste bug in X86ISelLowering where Chain should
have been used in place of DAG.getEntryToken().
Fixes PR20828.
llvm-svn: 216929
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp | 40 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 4 | 
2 files changed, 18 insertions, 26 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp b/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp index ff8d3ad1501..1f58d7c301f 100644 --- a/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp @@ -75,34 +75,26 @@ void FunctionLoweringInfo::set(const Function &fn, MachineFunction &mf,    // instruction values that are used outside of the block that defines    // them.    Function::const_iterator BB = Fn->begin(), EB = Fn->end(); -  for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I != E; ++I) -    if (const AllocaInst *AI = dyn_cast<AllocaInst>(I)) { -      // Don't fold inalloca allocas or other dynamic allocas into the initial -      // stack frame allocation, even if they are in the entry block. -      if (!AI->isStaticAlloca()) -        continue; - -      if (const ConstantInt *CUI = dyn_cast<ConstantInt>(AI->getArraySize())) { -        Type *Ty = AI->getAllocatedType(); -        uint64_t TySize = TLI->getDataLayout()->getTypeAllocSize(Ty); -        unsigned Align = -          std::max((unsigned)TLI->getDataLayout()->getPrefTypeAlignment(Ty), -                   AI->getAlignment()); - -        TySize *= CUI->getZExtValue();   // Get total allocated size. -        if (TySize == 0) TySize = 1; // Don't create zero-sized stack objects. - -        StaticAllocaMap[AI] = -          MF->getFrameInfo()->CreateStackObject(TySize, Align, false, AI); -      } -    } -    for (; BB != EB; ++BB)      for (BasicBlock::const_iterator I = BB->begin(), E = BB->end();           I != E; ++I) { -      // Look for dynamic allocas.        if (const AllocaInst *AI = dyn_cast<AllocaInst>(I)) { -        if (!AI->isStaticAlloca()) { +        // Static allocas can be folded into the initial stack frame adjustment. +        if (AI->isStaticAlloca()) { +          const ConstantInt *CUI = cast<ConstantInt>(AI->getArraySize()); +          Type *Ty = AI->getAllocatedType(); +          uint64_t TySize = TLI->getDataLayout()->getTypeAllocSize(Ty); +          unsigned Align = +            std::max((unsigned)TLI->getDataLayout()->getPrefTypeAlignment(Ty), +                     AI->getAlignment()); + +          TySize *= CUI->getZExtValue();   // Get total allocated size. +          if (TySize == 0) TySize = 1; // Don't create zero-sized stack objects. + +          StaticAllocaMap[AI] = +            MF->getFrameInfo()->CreateStackObject(TySize, Align, false, AI); + +        } else {            unsigned Align = std::max(                (unsigned)TLI->getDataLayout()->getPrefTypeAlignment(                  AI->getAllocatedType()), diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index 1c10691250c..43e4ffeb963 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -2547,11 +2547,11 @@ X86TargetLowering::LowerFormalArguments(SDValue Chain,      for (MCPhysReg Reg : ArgGPRs.slice(NumIntRegs)) {        unsigned GPR = MF.addLiveIn(Reg, &X86::GR64RegClass);        LiveGPRs.push_back( -          DAG.getCopyFromReg(DAG.getEntryNode(), dl, GPR, MVT::i64)); +          DAG.getCopyFromReg(Chain, dl, GPR, MVT::i64));      }      if (!ArgXMMs.empty()) {        unsigned AL = MF.addLiveIn(X86::AL, &X86::GR8RegClass); -      ALVal = DAG.getCopyFromReg(DAG.getEntryNode(), dl, AL, MVT::i8); +      ALVal = DAG.getCopyFromReg(Chain, dl, AL, MVT::i8);        for (MCPhysReg Reg : ArgXMMs.slice(NumXMMRegs)) {          unsigned XMMReg = MF.addLiveIn(Reg, &X86::VR128RegClass);          LiveXMMRegs.push_back( | 

