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:
Leny Kholodov 2016-09-06 10:48:04 +00:00
parent 5fcc4185f5
commit 80c047d2c4
2 changed files with 40 additions and 34 deletions

View File

@ -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.

View File

@ -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,