r228855 - Fix PR19351. While building up a composite type it is important to use
David Blaikie
dblaikie at gmail.com
Wed Feb 11 10:21:53 PST 2015
On Wed, Feb 11, 2015 at 9:45 AM, Adrian Prantl <aprantl at apple.com> wrote:
> Author: adrian
> Date: Wed Feb 11 11:45:15 2015
> New Revision: 228855
>
> URL: http://llvm.org/viewvc/llvm-project?rev=228855&view=rev
> Log:
> Fix PR19351. While building up a composite type it is important to use
> a non-uniqueable temporary node that is only turned into a permanent
> unique or distinct node after it is finished.
> Otherwise an intermediate node may get accidentally uniqued with another
> node as illustrated by the testcase.
>
Awesome - thanks!
>
> Paired commit with LLVM.
>
> Added:
> cfe/trunk/test/CodeGen/debug-info-same-line.c
> Modified:
> cfe/trunk/lib/CodeGen/CGDebugInfo.cpp
>
> Modified: cfe/trunk/lib/CodeGen/CGDebugInfo.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGDebugInfo.cpp?rev=228855&r1=228854&r2=228855&view=diff
>
> ==============================================================================
> --- cfe/trunk/lib/CodeGen/CGDebugInfo.cpp (original)
> +++ cfe/trunk/lib/CodeGen/CGDebugInfo.cpp Wed Feb 11 11:45:15 2015
> @@ -621,6 +621,21 @@ static SmallString<256> getUniqueTagType
> return FullName;
> }
>
> +static llvm::dwarf::Tag getTagForRecord(const RecordDecl *RD) {
> + llvm::dwarf::Tag Tag;
> + if (RD->isStruct() || RD->isInterface())
> + Tag = llvm::dwarf::DW_TAG_structure_type;
> + else if (RD->isUnion())
> + Tag = llvm::dwarf::DW_TAG_union_type;
> + else {
> + // FIXME: This could be a struct type giving a default visibility
> different
> + // than C++ class type, but needs llvm metadata changes first.
> + assert(RD->isClass());
> + Tag = llvm::dwarf::DW_TAG_class_type;
> + }
> + return Tag;
> +}
> +
> // Creates a forward declaration for a RecordDecl in the given context.
> llvm::DICompositeType
> CGDebugInfo::getOrCreateRecordFwdDecl(const RecordType *Ty,
> @@ -632,20 +647,12 @@ CGDebugInfo::getOrCreateRecordFwdDecl(co
> unsigned Line = getLineNumber(RD->getLocation());
> StringRef RDName = getClassName(RD);
>
> - llvm::dwarf::Tag Tag;
> - if (RD->isStruct() || RD->isInterface())
> - Tag = llvm::dwarf::DW_TAG_structure_type;
> - else if (RD->isUnion())
> - Tag = llvm::dwarf::DW_TAG_union_type;
> - else {
> - assert(RD->isClass());
> - Tag = llvm::dwarf::DW_TAG_class_type;
> - }
>
> // Create the type.
> SmallString<256> FullName = getUniqueTagTypeName(Ty, CGM, TheCU);
> - llvm::DICompositeType RetTy = DBuilder.createReplaceableForwardDecl(
> - Tag, RDName, Ctx, DefUnit, Line, 0, 0, 0, FullName);
> + llvm::DICompositeType RetTy = DBuilder.createReplaceableCompositeType(
> + getTagForRecord(RD), RDName, Ctx, DefUnit, Line, 0, 0, 0,
> + llvm::DIDescriptor::FlagFwdDecl, FullName);
> ReplaceMap.emplace_back(
> std::piecewise_construct, std::make_tuple(Ty),
> std::make_tuple(static_cast<llvm::Metadata *>(RetTy)));
> @@ -1567,7 +1574,8 @@ llvm::DIType CGDebugInfo::CreateTypeDefi
> assert(FwdDecl.isCompositeType() &&
> "The debug type of a RecordType should be a
> llvm::DICompositeType");
>
> - if (FwdDecl.isForwardDecl())
> + const RecordDecl *D = RD->getDefinition();
> + if (!D || !D->isCompleteDefinition())
> return FwdDecl;
>
> if (const CXXRecordDecl *CXXDecl = dyn_cast<CXXRecordDecl>(RD))
> @@ -1602,6 +1610,10 @@ llvm::DIType CGDebugInfo::CreateTypeDefi
> llvm::DIArray Elements = DBuilder.getOrCreateArray(EltTys);
> DBuilder.replaceArrays(FwdDecl, Elements);
>
> + if (FwdDecl->isTemporary())
> + FwdDecl = llvm::DICompositeType(llvm::MDNode::replaceWithPermanent(
> + llvm::TempMDNode(FwdDecl.get())));
> +
> RegionMap[Ty->getDecl()].reset(FwdDecl);
> return FwdDecl;
> }
> @@ -1653,7 +1665,7 @@ llvm::DIType CGDebugInfo::CreateType(con
> // debug type since we won't be able to lay out the entire type.
> ObjCInterfaceDecl *Def = ID->getDefinition();
> if (!Def || !Def->getImplementation()) {
> - llvm::DIType FwdDecl = DBuilder.createReplaceableForwardDecl(
> + llvm::DIType FwdDecl = DBuilder.createReplaceableCompositeType(
> llvm::dwarf::DW_TAG_structure_type, ID->getName(), TheCU,
> DefUnit, Line,
> RuntimeLang);
> ObjCInterfaceCache.push_back(ObjCInterfaceCacheEntry(Ty, FwdDecl,
> Unit));
> @@ -1933,9 +1945,9 @@ llvm::DIType CGDebugInfo::CreateEnumType
> llvm::DIFile DefUnit = getOrCreateFile(ED->getLocation());
> unsigned Line = getLineNumber(ED->getLocation());
> StringRef EDName = ED->getName();
> - llvm::DIType RetTy = DBuilder.createReplaceableForwardDecl(
> + llvm::DIType RetTy = DBuilder.createReplaceableCompositeType(
> llvm::dwarf::DW_TAG_enumeration_type, EDName, EDContext, DefUnit,
> Line,
> - 0, Size, Align, FullName);
> + 0, Size, Align, llvm::DIDescriptor::FlagFwdDecl, FullName);
> ReplaceMap.emplace_back(
> std::piecewise_construct, std::make_tuple(Ty),
> std::make_tuple(static_cast<llvm::Metadata *>(RetTy)));
> @@ -2249,19 +2261,8 @@ llvm::DICompositeType CGDebugInfo::Creat
>
> SmallString<256> FullName = getUniqueTagTypeName(Ty, CGM, TheCU);
>
> - if (RD->isUnion())
> - RealDecl = DBuilder.createUnionType(RDContext, RDName, DefUnit, Line,
> Size,
> - Align, 0, llvm::DIArray(), 0,
> FullName);
> - else if (RD->isClass()) {
> - // FIXME: This could be a struct type giving a default visibility
> different
> - // than C++ class type, but needs llvm metadata changes first.
> - RealDecl = DBuilder.createClassType(
> - RDContext, RDName, DefUnit, Line, Size, Align, 0, 0,
> llvm::DIType(),
> - llvm::DIArray(), llvm::DIType(), llvm::DIArray(), FullName);
> - } else
> - RealDecl = DBuilder.createStructType(
> - RDContext, RDName, DefUnit, Line, Size, Align, 0, llvm::DIType(),
> - llvm::DIArray(), 0, llvm::DIType(), FullName);
> + RealDecl = DBuilder.createReplaceableCompositeType(getTagForRecord(RD),
> + RDName, RDContext, DefUnit, Line, 0, Size, Align, 0, FullName);
>
> RegionMap[Ty->getDecl()].reset(RealDecl);
> TypeCache[QualType(Ty, 0).getAsOpaquePtr()].reset(RealDecl);
>
> Added: cfe/trunk/test/CodeGen/debug-info-same-line.c
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/debug-info-same-line.c?rev=228855&view=auto
>
> ==============================================================================
> --- cfe/trunk/test/CodeGen/debug-info-same-line.c (added)
> +++ cfe/trunk/test/CodeGen/debug-info-same-line.c Wed Feb 11 11:45:15 2015
> @@ -0,0 +1,7 @@
> +// RUN: %clang_cc1 -triple x86_64-apple-darwin -emit-llvm %s -g -o - |
> FileCheck %s
> +// Here two temporary nodes are identical (but should not get uniqued)
> while
> +// building the full debug type.
> +typedef struct { long x; } foo; typedef struct { foo *x; } bar;
> +// CHECK: [ DW_TAG_structure_type ] [line 4, size 64,
> +// CHECK: [ DW_TAG_structure_type ] [line 4, size 64,
> +bar b;
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20150211/75741e1b/attachment.html>
More information about the cfe-commits
mailing list