forked from OSchip/llvm-project
DebugInfo: use llvm::DINode::DIFlags type for debug info flags
Use llvm::DINode::DIFlags type (strongly typed enum) for debug flags instead of unsigned int to avoid problems on platforms with sizeof(int) < 4: we already have flags with values > (1 << 16). Patch by: Victor Leschuk <vleschuk@gmail.com> Differential Revision: https://reviews.llvm.org/D23767 llvm-svn: 280701
This commit is contained in:
parent
5fcc4185f5
commit
80c047d2c4
|
@ -497,12 +497,12 @@ llvm::DIType *CGDebugInfo::CreateType(const BuiltinType *BT) {
|
||||||
|
|
||||||
ObjTy =
|
ObjTy =
|
||||||
DBuilder.createStructType(TheCU, "objc_object", getOrCreateMainFile(),
|
DBuilder.createStructType(TheCU, "objc_object", getOrCreateMainFile(),
|
||||||
0, 0, 0, 0, nullptr, llvm::DINodeArray());
|
0, 0, 0, llvm::DINode::FlagZero, nullptr, llvm::DINodeArray());
|
||||||
|
|
||||||
DBuilder.replaceArrays(
|
DBuilder.replaceArrays(
|
||||||
ObjTy,
|
ObjTy,
|
||||||
DBuilder.getOrCreateArray(&*DBuilder.createMemberType(
|
DBuilder.getOrCreateArray(&*DBuilder.createMemberType(
|
||||||
ObjTy, "isa", getOrCreateMainFile(), 0, Size, 0, 0, 0, ISATy)));
|
ObjTy, "isa", getOrCreateMainFile(), 0, Size, 0, 0, llvm::DINode::FlagZero, ISATy)));
|
||||||
return ObjTy;
|
return ObjTy;
|
||||||
}
|
}
|
||||||
case BuiltinType::ObjCSel: {
|
case BuiltinType::ObjCSel: {
|
||||||
|
@ -787,7 +787,7 @@ llvm::DIType *CGDebugInfo::CreateType(const BlockPointerType *Ty,
|
||||||
Elements = DBuilder.getOrCreateArray(EltTys);
|
Elements = DBuilder.getOrCreateArray(EltTys);
|
||||||
EltTys.clear();
|
EltTys.clear();
|
||||||
|
|
||||||
unsigned Flags = llvm::DINode::FlagAppleBlock;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagAppleBlock;
|
||||||
unsigned LineNo = 0;
|
unsigned LineNo = 0;
|
||||||
|
|
||||||
auto *EltTy =
|
auto *EltTy =
|
||||||
|
@ -813,7 +813,7 @@ llvm::DIType *CGDebugInfo::CreateType(const BlockPointerType *Ty,
|
||||||
FieldAlign = CGM.getContext().getTypeAlign(Ty);
|
FieldAlign = CGM.getContext().getTypeAlign(Ty);
|
||||||
EltTys.push_back(DBuilder.createMemberType(Unit, "__descriptor", nullptr, LineNo,
|
EltTys.push_back(DBuilder.createMemberType(Unit, "__descriptor", nullptr, LineNo,
|
||||||
FieldSize, FieldAlign, FieldOffset,
|
FieldSize, FieldAlign, FieldOffset,
|
||||||
0, DescTy));
|
llvm::DINode::FlagZero, DescTy));
|
||||||
|
|
||||||
FieldOffset += FieldSize;
|
FieldOffset += FieldSize;
|
||||||
Elements = DBuilder.getOrCreateArray(EltTys);
|
Elements = DBuilder.getOrCreateArray(EltTys);
|
||||||
|
@ -917,14 +917,14 @@ llvm::DIType *CGDebugInfo::CreateType(const FunctionType *Ty,
|
||||||
}
|
}
|
||||||
|
|
||||||
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(EltTys);
|
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(EltTys);
|
||||||
return DBuilder.createSubroutineType(EltTypeArray, 0,
|
return DBuilder.createSubroutineType(EltTypeArray, llvm::DINode::FlagZero,
|
||||||
getDwarfCC(Ty->getCallConv()));
|
getDwarfCC(Ty->getCallConv()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Convert an AccessSpecifier into the corresponding DINode flag.
|
/// Convert an AccessSpecifier into the corresponding DINode flag.
|
||||||
/// As an optimization, return 0 if the access specifier equals the
|
/// As an optimization, return 0 if the access specifier equals the
|
||||||
/// default for the containing type.
|
/// default for the containing type.
|
||||||
static unsigned getAccessFlag(AccessSpecifier Access, const RecordDecl *RD) {
|
static llvm::DINode::DIFlags getAccessFlag(AccessSpecifier Access, const RecordDecl *RD) {
|
||||||
AccessSpecifier Default = clang::AS_none;
|
AccessSpecifier Default = clang::AS_none;
|
||||||
if (RD && RD->isClass())
|
if (RD && RD->isClass())
|
||||||
Default = clang::AS_private;
|
Default = clang::AS_private;
|
||||||
|
@ -932,7 +932,7 @@ static unsigned getAccessFlag(AccessSpecifier Access, const RecordDecl *RD) {
|
||||||
Default = clang::AS_public;
|
Default = clang::AS_public;
|
||||||
|
|
||||||
if (Access == Default)
|
if (Access == Default)
|
||||||
return 0;
|
return llvm::DINode::FlagZero;
|
||||||
|
|
||||||
switch (Access) {
|
switch (Access) {
|
||||||
case clang::AS_private:
|
case clang::AS_private:
|
||||||
|
@ -942,7 +942,7 @@ static unsigned getAccessFlag(AccessSpecifier Access, const RecordDecl *RD) {
|
||||||
case clang::AS_public:
|
case clang::AS_public:
|
||||||
return llvm::DINode::FlagPublic;
|
return llvm::DINode::FlagPublic;
|
||||||
case clang::AS_none:
|
case clang::AS_none:
|
||||||
return 0;
|
return llvm::DINode::FlagZero;
|
||||||
}
|
}
|
||||||
llvm_unreachable("unexpected access enumerator");
|
llvm_unreachable("unexpected access enumerator");
|
||||||
}
|
}
|
||||||
|
@ -968,7 +968,7 @@ llvm::DIType *CGDebugInfo::createBitFieldType(const FieldDecl *BitFieldDecl,
|
||||||
uint64_t StorageOffsetInBits =
|
uint64_t StorageOffsetInBits =
|
||||||
CGM.getContext().toBits(BitFieldInfo.StorageOffset);
|
CGM.getContext().toBits(BitFieldInfo.StorageOffset);
|
||||||
uint64_t OffsetInBits = StorageOffsetInBits + BitFieldInfo.Offset;
|
uint64_t OffsetInBits = StorageOffsetInBits + BitFieldInfo.Offset;
|
||||||
unsigned Flags = getAccessFlag(BitFieldDecl->getAccess(), RD);
|
llvm::DINode::DIFlags Flags = getAccessFlag(BitFieldDecl->getAccess(), RD);
|
||||||
return DBuilder.createBitFieldMemberType(
|
return DBuilder.createBitFieldMemberType(
|
||||||
RecordTy, Name, File, Line, SizeInBits, AlignInBits, OffsetInBits,
|
RecordTy, Name, File, Line, SizeInBits, AlignInBits, OffsetInBits,
|
||||||
StorageOffsetInBits, Flags, DebugType);
|
StorageOffsetInBits, Flags, DebugType);
|
||||||
|
@ -993,7 +993,7 @@ CGDebugInfo::createFieldType(StringRef name, QualType type, SourceLocation loc,
|
||||||
AlignInBits = TI.Align;
|
AlignInBits = TI.Align;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned flags = getAccessFlag(AS, RD);
|
llvm::DINode::DIFlags flags = getAccessFlag(AS, RD);
|
||||||
return DBuilder.createMemberType(scope, name, file, line, SizeInBits,
|
return DBuilder.createMemberType(scope, name, file, line, SizeInBits,
|
||||||
AlignInBits, offsetInBits, flags, debugType);
|
AlignInBits, offsetInBits, flags, debugType);
|
||||||
}
|
}
|
||||||
|
@ -1060,7 +1060,7 @@ CGDebugInfo::CreateRecordStaticField(const VarDecl *Var, llvm::DIType *RecordTy,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned Flags = getAccessFlag(Var->getAccess(), RD);
|
llvm::DINode::DIFlags Flags = getAccessFlag(Var->getAccess(), RD);
|
||||||
llvm::DIDerivedType *GV = DBuilder.createStaticMemberType(
|
llvm::DIDerivedType *GV = DBuilder.createStaticMemberType(
|
||||||
RecordTy, VName, VUnit, LineNumber, VTy, Flags, C);
|
RecordTy, VName, VUnit, LineNumber, VTy, Flags, C);
|
||||||
StaticDataMemberCache[Var->getCanonicalDecl()].reset(GV);
|
StaticDataMemberCache[Var->getCanonicalDecl()].reset(GV);
|
||||||
|
@ -1203,7 +1203,7 @@ llvm::DISubroutineType *CGDebugInfo::getOrCreateInstanceMethodType(
|
||||||
|
|
||||||
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(Elts);
|
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(Elts);
|
||||||
|
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
if (Func->getExtProtoInfo().RefQualifier == RQ_LValue)
|
if (Func->getExtProtoInfo().RefQualifier == RQ_LValue)
|
||||||
Flags |= llvm::DINode::FlagLValueReference;
|
Flags |= llvm::DINode::FlagLValueReference;
|
||||||
if (Func->getExtProtoInfo().RefQualifier == RQ_RValue)
|
if (Func->getExtProtoInfo().RefQualifier == RQ_RValue)
|
||||||
|
@ -1254,7 +1254,7 @@ llvm::DISubprogram *CGDebugInfo::CreateCXXMemberFunction(
|
||||||
llvm::DIType *ContainingType = nullptr;
|
llvm::DIType *ContainingType = nullptr;
|
||||||
unsigned Virtuality = 0;
|
unsigned Virtuality = 0;
|
||||||
unsigned VIndex = 0;
|
unsigned VIndex = 0;
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
int ThisAdjustment = 0;
|
int ThisAdjustment = 0;
|
||||||
|
|
||||||
if (Method->isVirtual()) {
|
if (Method->isVirtual()) {
|
||||||
|
@ -1367,7 +1367,7 @@ void CGDebugInfo::CollectCXXBases(const CXXRecordDecl *RD, llvm::DIFile *Unit,
|
||||||
llvm::DIType *RecordTy) {
|
llvm::DIType *RecordTy) {
|
||||||
const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(RD);
|
const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(RD);
|
||||||
for (const auto &BI : RD->bases()) {
|
for (const auto &BI : RD->bases()) {
|
||||||
unsigned BFlags = 0;
|
llvm::DINode::DIFlags BFlags = llvm::DINode::FlagZero;
|
||||||
uint64_t BaseOffset;
|
uint64_t BaseOffset;
|
||||||
|
|
||||||
const auto *Base =
|
const auto *Base =
|
||||||
|
@ -1952,7 +1952,7 @@ llvm::DIType *CGDebugInfo::CreateTypeDefinition(const ObjCInterfaceType *Ty,
|
||||||
uint64_t Size = CGM.getContext().getTypeSize(Ty);
|
uint64_t Size = CGM.getContext().getTypeSize(Ty);
|
||||||
uint64_t Align = CGM.getContext().getTypeAlign(Ty);
|
uint64_t Align = CGM.getContext().getTypeAlign(Ty);
|
||||||
|
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
if (ID->getImplementation())
|
if (ID->getImplementation())
|
||||||
Flags |= llvm::DINode::FlagObjcClassComplete;
|
Flags |= llvm::DINode::FlagObjcClassComplete;
|
||||||
|
|
||||||
|
@ -1978,7 +1978,7 @@ llvm::DIType *CGDebugInfo::CreateTypeDefinition(const ObjCInterfaceType *Ty,
|
||||||
if (!SClassTy)
|
if (!SClassTy)
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
llvm::DIType *InhTag = DBuilder.createInheritance(RealDecl, SClassTy, 0, 0);
|
llvm::DIType *InhTag = DBuilder.createInheritance(RealDecl, SClassTy, 0, llvm::DINode::FlagZero);
|
||||||
EltTys.push_back(InhTag);
|
EltTys.push_back(InhTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2060,7 +2060,7 @@ llvm::DIType *CGDebugInfo::CreateTypeDefinition(const ObjCInterfaceType *Ty,
|
||||||
FieldOffset = RL.getFieldOffset(FieldNo);
|
FieldOffset = RL.getFieldOffset(FieldNo);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
if (Field->getAccessControl() == ObjCIvarDecl::Protected)
|
if (Field->getAccessControl() == ObjCIvarDecl::Protected)
|
||||||
Flags = llvm::DINode::FlagProtected;
|
Flags = llvm::DINode::FlagProtected;
|
||||||
else if (Field->getAccessControl() == ObjCIvarDecl::Private)
|
else if (Field->getAccessControl() == ObjCIvarDecl::Private)
|
||||||
|
@ -2191,7 +2191,7 @@ llvm::DIType *CGDebugInfo::CreateType(const RValueReferenceType *Ty,
|
||||||
|
|
||||||
llvm::DIType *CGDebugInfo::CreateType(const MemberPointerType *Ty,
|
llvm::DIType *CGDebugInfo::CreateType(const MemberPointerType *Ty,
|
||||||
llvm::DIFile *U) {
|
llvm::DIFile *U) {
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
uint64_t Size = 0;
|
uint64_t Size = 0;
|
||||||
|
|
||||||
if (!Ty->isIncompleteType()) {
|
if (!Ty->isIncompleteType()) {
|
||||||
|
@ -2591,8 +2591,8 @@ llvm::DICompositeType *CGDebugInfo::CreateLimitedType(const RecordType *Ty) {
|
||||||
SmallString<256> FullName = getUniqueTagTypeName(Ty, CGM, TheCU);
|
SmallString<256> FullName = getUniqueTagTypeName(Ty, CGM, TheCU);
|
||||||
|
|
||||||
llvm::DICompositeType *RealDecl = DBuilder.createReplaceableCompositeType(
|
llvm::DICompositeType *RealDecl = DBuilder.createReplaceableCompositeType(
|
||||||
getTagForRecord(RD), RDName, RDContext, DefUnit, Line, 0, Size, Align, 0,
|
getTagForRecord(RD), RDName, RDContext, DefUnit, Line, 0, Size, Align,
|
||||||
FullName);
|
llvm::DINode::FlagZero, FullName);
|
||||||
|
|
||||||
// Elements of composite types usually have back to the type, creating
|
// Elements of composite types usually have back to the type, creating
|
||||||
// uniquing cycles. Distinct nodes are more efficient.
|
// uniquing cycles. Distinct nodes are more efficient.
|
||||||
|
@ -2657,7 +2657,8 @@ llvm::DIType *CGDebugInfo::CreateMemberType(llvm::DIFile *Unit, QualType FType,
|
||||||
uint64_t FieldSize = CGM.getContext().getTypeSize(FType);
|
uint64_t FieldSize = CGM.getContext().getTypeSize(FType);
|
||||||
unsigned FieldAlign = CGM.getContext().getTypeAlign(FType);
|
unsigned FieldAlign = CGM.getContext().getTypeAlign(FType);
|
||||||
llvm::DIType *Ty = DBuilder.createMemberType(Unit, Name, Unit, 0, FieldSize,
|
llvm::DIType *Ty = DBuilder.createMemberType(Unit, Name, Unit, 0, FieldSize,
|
||||||
FieldAlign, *Offset, 0, FieldTy);
|
FieldAlign, *Offset,
|
||||||
|
llvm::DINode::FlagZero, FieldTy);
|
||||||
*Offset += FieldSize;
|
*Offset += FieldSize;
|
||||||
return Ty;
|
return Ty;
|
||||||
}
|
}
|
||||||
|
@ -2667,7 +2668,7 @@ void CGDebugInfo::collectFunctionDeclProps(GlobalDecl GD, llvm::DIFile *Unit,
|
||||||
StringRef &LinkageName,
|
StringRef &LinkageName,
|
||||||
llvm::DIScope *&FDContext,
|
llvm::DIScope *&FDContext,
|
||||||
llvm::DINodeArray &TParamsArray,
|
llvm::DINodeArray &TParamsArray,
|
||||||
unsigned &Flags) {
|
llvm::DINode::DIFlags &Flags) {
|
||||||
const auto *FD = cast<FunctionDecl>(GD.getDecl());
|
const auto *FD = cast<FunctionDecl>(GD.getDecl());
|
||||||
Name = getFunctionName(FD);
|
Name = getFunctionName(FD);
|
||||||
// Use mangled name as linkage name for C/C++ functions.
|
// Use mangled name as linkage name for C/C++ functions.
|
||||||
|
@ -2751,7 +2752,7 @@ llvm::DISubprogram *
|
||||||
CGDebugInfo::getFunctionForwardDeclaration(const FunctionDecl *FD) {
|
CGDebugInfo::getFunctionForwardDeclaration(const FunctionDecl *FD) {
|
||||||
llvm::DINodeArray TParamsArray;
|
llvm::DINodeArray TParamsArray;
|
||||||
StringRef Name, LinkageName;
|
StringRef Name, LinkageName;
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
SourceLocation Loc = FD->getLocation();
|
SourceLocation Loc = FD->getLocation();
|
||||||
llvm::DIFile *Unit = getOrCreateFile(Loc);
|
llvm::DIFile *Unit = getOrCreateFile(Loc);
|
||||||
llvm::DIScope *DContext = Unit;
|
llvm::DIScope *DContext = Unit;
|
||||||
|
@ -2905,7 +2906,8 @@ llvm::DISubroutineType *CGDebugInfo::getOrCreateFunctionType(const Decl *D,
|
||||||
Elts.push_back(DBuilder.createUnspecifiedParameter());
|
Elts.push_back(DBuilder.createUnspecifiedParameter());
|
||||||
|
|
||||||
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(Elts);
|
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(Elts);
|
||||||
return DBuilder.createSubroutineType(EltTypeArray, 0, getDwarfCC(CC));
|
return DBuilder.createSubroutineType(EltTypeArray, llvm::DINode::FlagZero,
|
||||||
|
getDwarfCC(CC));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle variadic function types; they need an additional
|
// Handle variadic function types; they need an additional
|
||||||
|
@ -2919,7 +2921,8 @@ llvm::DISubroutineType *CGDebugInfo::getOrCreateFunctionType(const Decl *D,
|
||||||
EltTys.push_back(getOrCreateType(ParamType, F));
|
EltTys.push_back(getOrCreateType(ParamType, F));
|
||||||
EltTys.push_back(DBuilder.createUnspecifiedParameter());
|
EltTys.push_back(DBuilder.createUnspecifiedParameter());
|
||||||
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(EltTys);
|
llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(EltTys);
|
||||||
return DBuilder.createSubroutineType(EltTypeArray, 0, getDwarfCC(CC));
|
return DBuilder.createSubroutineType(EltTypeArray, llvm::DINode::FlagZero,
|
||||||
|
getDwarfCC(CC));
|
||||||
}
|
}
|
||||||
|
|
||||||
return cast<llvm::DISubroutineType>(getOrCreateType(FnType, F));
|
return cast<llvm::DISubroutineType>(getOrCreateType(FnType, F));
|
||||||
|
@ -2937,7 +2940,7 @@ void CGDebugInfo::EmitFunctionStart(GlobalDecl GD, SourceLocation Loc,
|
||||||
const Decl *D = GD.getDecl();
|
const Decl *D = GD.getDecl();
|
||||||
bool HasDecl = (D != nullptr);
|
bool HasDecl = (D != nullptr);
|
||||||
|
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
llvm::DIFile *Unit = getOrCreateFile(Loc);
|
llvm::DIFile *Unit = getOrCreateFile(Loc);
|
||||||
llvm::DIScope *FDContext = Unit;
|
llvm::DIScope *FDContext = Unit;
|
||||||
llvm::DINodeArray TParamsArray;
|
llvm::DINodeArray TParamsArray;
|
||||||
|
@ -3010,7 +3013,7 @@ void CGDebugInfo::EmitFunctionDecl(GlobalDecl GD, SourceLocation Loc,
|
||||||
if (!D)
|
if (!D)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
llvm::DIFile *Unit = getOrCreateFile(Loc);
|
llvm::DIFile *Unit = getOrCreateFile(Loc);
|
||||||
llvm::DIScope *FDContext = getDeclContextDescriptor(D);
|
llvm::DIScope *FDContext = getDeclContextDescriptor(D);
|
||||||
llvm::DINodeArray TParamsArray;
|
llvm::DINodeArray TParamsArray;
|
||||||
|
@ -3167,13 +3170,14 @@ llvm::DIType *CGDebugInfo::EmitTypeForVarWithBlocksAttr(const VarDecl *VD,
|
||||||
|
|
||||||
*XOffset = FieldOffset;
|
*XOffset = FieldOffset;
|
||||||
FieldTy = DBuilder.createMemberType(Unit, VD->getName(), Unit, 0, FieldSize,
|
FieldTy = DBuilder.createMemberType(Unit, VD->getName(), Unit, 0, FieldSize,
|
||||||
FieldAlign, FieldOffset, 0, FieldTy);
|
FieldAlign, FieldOffset,
|
||||||
|
llvm::DINode::FlagZero, FieldTy);
|
||||||
EltTys.push_back(FieldTy);
|
EltTys.push_back(FieldTy);
|
||||||
FieldOffset += FieldSize;
|
FieldOffset += FieldSize;
|
||||||
|
|
||||||
llvm::DINodeArray Elements = DBuilder.getOrCreateArray(EltTys);
|
llvm::DINodeArray Elements = DBuilder.getOrCreateArray(EltTys);
|
||||||
|
|
||||||
unsigned Flags = llvm::DINode::FlagBlockByrefStruct;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagBlockByrefStruct;
|
||||||
|
|
||||||
return DBuilder.createStructType(Unit, "", Unit, 0, FieldOffset, 0, Flags,
|
return DBuilder.createStructType(Unit, "", Unit, 0, FieldOffset, 0, Flags,
|
||||||
nullptr, Elements);
|
nullptr, Elements);
|
||||||
|
@ -3213,7 +3217,7 @@ void CGDebugInfo::EmitDeclare(const VarDecl *VD, llvm::Value *Storage,
|
||||||
Column = getColumnNumber(VD->getLocation());
|
Column = getColumnNumber(VD->getLocation());
|
||||||
}
|
}
|
||||||
SmallVector<int64_t, 9> Expr;
|
SmallVector<int64_t, 9> Expr;
|
||||||
unsigned Flags = 0;
|
llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
|
||||||
if (VD->isImplicit())
|
if (VD->isImplicit())
|
||||||
Flags |= llvm::DINode::FlagArtificial;
|
Flags |= llvm::DINode::FlagArtificial;
|
||||||
// If this is the first argument and it is implicit then
|
// If this is the first argument and it is implicit then
|
||||||
|
@ -3516,7 +3520,8 @@ void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
|
||||||
fieldType = DBuilder.createPointerType(fieldType, PtrInfo.Width);
|
fieldType = DBuilder.createPointerType(fieldType, PtrInfo.Width);
|
||||||
fieldType =
|
fieldType =
|
||||||
DBuilder.createMemberType(tunit, name, tunit, line, PtrInfo.Width,
|
DBuilder.createMemberType(tunit, name, tunit, line, PtrInfo.Width,
|
||||||
PtrInfo.Align, offsetInBits, 0, fieldType);
|
PtrInfo.Align, offsetInBits,
|
||||||
|
llvm::DINode::FlagZero, fieldType);
|
||||||
} else {
|
} else {
|
||||||
fieldType = createFieldType(name, variable->getType(), loc, AS_public,
|
fieldType = createFieldType(name, variable->getType(), loc, AS_public,
|
||||||
offsetInBits, tunit, tunit);
|
offsetInBits, tunit, tunit);
|
||||||
|
@ -3533,11 +3538,12 @@ void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
|
||||||
llvm::DIType *type = DBuilder.createStructType(
|
llvm::DIType *type = DBuilder.createStructType(
|
||||||
tunit, typeName.str(), tunit, line,
|
tunit, typeName.str(), tunit, line,
|
||||||
CGM.getContext().toBits(block.BlockSize),
|
CGM.getContext().toBits(block.BlockSize),
|
||||||
CGM.getContext().toBits(block.BlockAlign), 0, nullptr, fieldsArray);
|
CGM.getContext().toBits(block.BlockAlign), llvm::DINode::FlagZero,
|
||||||
|
nullptr, fieldsArray);
|
||||||
type = DBuilder.createPointerType(type, CGM.PointerWidthInBits);
|
type = DBuilder.createPointerType(type, CGM.PointerWidthInBits);
|
||||||
|
|
||||||
// Get overall information about the block.
|
// Get overall information about the block.
|
||||||
unsigned flags = llvm::DINode::FlagArtificial;
|
llvm::DINode::DIFlags flags = llvm::DINode::FlagArtificial;
|
||||||
auto *scope = cast<llvm::DILocalScope>(LexicalBlockStack.back());
|
auto *scope = cast<llvm::DILocalScope>(LexicalBlockStack.back());
|
||||||
|
|
||||||
// Create the descriptor for the parameter.
|
// Create the descriptor for the parameter.
|
||||||
|
|
|
@ -518,7 +518,7 @@ private:
|
||||||
StringRef &Name, StringRef &LinkageName,
|
StringRef &Name, StringRef &LinkageName,
|
||||||
llvm::DIScope *&FDContext,
|
llvm::DIScope *&FDContext,
|
||||||
llvm::DINodeArray &TParamsArray,
|
llvm::DINodeArray &TParamsArray,
|
||||||
unsigned &Flags);
|
llvm::DINode::DIFlags &Flags);
|
||||||
|
|
||||||
/// Collect various properties of a VarDecl.
|
/// Collect various properties of a VarDecl.
|
||||||
void collectVarDeclProps(const VarDecl *VD, llvm::DIFile *&Unit,
|
void collectVarDeclProps(const VarDecl *VD, llvm::DIFile *&Unit,
|
||||||
|
|
Loading…
Reference in New Issue