diff options
Diffstat (limited to 'lib/CodeGen/CGBlocks.cpp')
| -rw-r--r-- | lib/CodeGen/CGBlocks.cpp | 48 | 
1 files changed, 32 insertions, 16 deletions
| diff --git a/lib/CodeGen/CGBlocks.cpp b/lib/CodeGen/CGBlocks.cpp index 72fde9dc55f1..b98460a9ddd8 100644 --- a/lib/CodeGen/CGBlocks.cpp +++ b/lib/CodeGen/CGBlocks.cpp @@ -545,6 +545,16 @@ static void computeBlockInfo(CodeGenModule &CGM, CodeGenFunction *CGF,    // multiple of alignment.    for (SmallVectorImpl<BlockLayoutChunk>::iterator           li = layout.begin(), le = layout.end(); li != le; ++li) { +    if (endAlign < li->Alignment) { +      // size may not be multiple of alignment. This can only happen with +      // an over-aligned variable. We will be adding a padding field to +      // make the size be multiple of alignment. +      CharUnits padding = li->Alignment - endAlign; +      elementTypes.push_back(llvm::ArrayType::get(CGM.Int8Ty, +                                                  padding.getQuantity())); +      blockSize += padding; +      endAlign = getLowBit(blockSize); +    }      assert(endAlign >= li->Alignment);      li->setIndex(info, elementTypes.size());      elementTypes.push_back(li->Type); @@ -782,9 +792,10 @@ llvm::Value *CodeGenFunction::EmitBlockLiteral(const CGBlockInfo &blockInfo) {        // emission.        src = LocalDeclMap.lookup(variable);        if (!src) { -        DeclRefExpr declRef(const_cast<VarDecl *>(variable), -                            /*refersToEnclosing*/ CI.isNested(), type, -                            VK_LValue, SourceLocation()); +        DeclRefExpr declRef( +            const_cast<VarDecl *>(variable), +            /*RefersToEnclosingVariableOrCapture*/ CI.isNested(), type, +            VK_LValue, SourceLocation());          src = EmitDeclRefLValue(&declRef).getAddress();        }      } @@ -853,12 +864,15 @@ llvm::Value *CodeGenFunction::EmitBlockLiteral(const CGBlockInfo &blockInfo) {        // We use one of these or the other depending on whether the        // reference is nested. -      DeclRefExpr declRef(const_cast<VarDecl*>(variable), -                          /*refersToEnclosing*/ CI.isNested(), type, -                          VK_LValue, SourceLocation()); +      DeclRefExpr declRef(const_cast<VarDecl *>(variable), +                          /*RefersToEnclosingVariableOrCapture*/ CI.isNested(), +                          type, VK_LValue, SourceLocation());        ImplicitCastExpr l2r(ImplicitCastExpr::OnStack, type, CK_LValueToRValue,                             &declRef, VK_RValue); +      // FIXME: Pass a specific location for the expr init so that the store is +      // attributed to a reasonable location - otherwise it may be attributed to +      // locations of subexpressions in the initialization.        EmitExprAsInit(&l2r, &blockFieldPseudoVar,                       MakeAddrLValue(blockField, type, align),                       /*captured by init*/ false); @@ -905,7 +919,7 @@ llvm::Type *CodeGenModule::getBlockDescriptorType() {    // };    BlockDescriptorType =      llvm::StructType::create("struct.__block_descriptor", -                             UnsignedLongTy, UnsignedLongTy, NULL); +                             UnsignedLongTy, UnsignedLongTy, nullptr);    // Now form a pointer to that.    BlockDescriptorType = llvm::PointerType::getUnqual(BlockDescriptorType); @@ -928,7 +942,7 @@ llvm::Type *CodeGenModule::getGenericBlockLiteralType() {    GenericBlockLiteralType =      llvm::StructType::create("struct.__block_literal_generic",                               VoidPtrTy, IntTy, IntTy, VoidPtrTy, -                             BlockDescPtrTy, NULL); +                             BlockDescPtrTy, nullptr);    return GenericBlockLiteralType;  } @@ -1093,6 +1107,8 @@ CodeGenFunction::GenerateBlockFunction(GlobalDecl GD,    const BlockDecl *blockDecl = blockInfo.getBlockDecl();    CurGD = GD; + +  CurEHLocation = blockInfo.getBlockExpr()->getLocEnd();    BlockInfo = &blockInfo; @@ -1162,7 +1178,7 @@ CodeGenFunction::GenerateBlockFunction(GlobalDecl GD,      Alloca->setAlignment(Align);      // Set the DebugLocation to empty, so the store is recognized as a      // frame setup instruction by llvm::DwarfDebug::beginFunction(). -    NoLocation NL(*this, Builder); +    ApplyDebugLocation NL(*this);      Builder.CreateAlignedStore(BlockPointer, Alloca, Align);      BlockPointerDbgLoc = Alloca;    } @@ -1205,8 +1221,6 @@ CodeGenFunction::GenerateBlockFunction(GlobalDecl GD,      RegionCounter Cnt = getPGORegionCounter(blockDecl->getBody());      Cnt.beginRegion(Builder);      EmitStmt(blockDecl->getBody()); -    PGO.emitInstrumentationData(); -    PGO.destroyRegionCounters();    }    // Remember where we were... @@ -1233,7 +1247,9 @@ CodeGenFunction::GenerateBlockFunction(GlobalDecl GD,          }          DI->EmitDeclareOfBlockDeclRefVariable(variable, BlockPointerDbgLoc, -                                              Builder, blockInfo); +                                              Builder, blockInfo, +                                              entry_ptr == entry->end() +                                              ? nullptr : entry_ptr);        }      }      // Recover location if it was changed in the above loop. @@ -1313,9 +1329,9 @@ CodeGenFunction::GenerateCopyHelperFunction(const CGBlockInfo &blockInfo) {                                            false,                                            false);    // Create a scope with an artificial location for the body of this function. -  ArtificialLocation AL(*this, Builder); +  ApplyDebugLocation NL(*this);    StartFunction(FD, C.VoidTy, Fn, FI, args); -  AL.Emit(); +  ArtificialLocation AL(*this);    llvm::Type *structPtrTy = blockInfo.StructureType->getPointerTo(); @@ -1484,9 +1500,9 @@ CodeGenFunction::GenerateDestroyHelperFunction(const CGBlockInfo &blockInfo) {                                            nullptr, SC_Static,                                            false, false);    // Create a scope with an artificial location for the body of this function. -  ArtificialLocation AL(*this, Builder); +  ApplyDebugLocation NL(*this);    StartFunction(FD, C.VoidTy, Fn, FI, args); -  AL.Emit(); +  ArtificialLocation AL(*this);    llvm::Type *structPtrTy = blockInfo.StructureType->getPointerTo(); | 
