diff options
author | Devang Patel <dpatel@apple.com> | 2010-03-09 21:32:27 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2010-03-09 21:32:27 +0000 |
commit | 4f26205ba8a596e06b5111ca8eb796bfe7c55737 (patch) | |
tree | 445ef73270efaeb5f22f5ada4d076f46ef5bc8be | |
parent | 3dde457b949bdd11cbb891c1047d2b6c243c0ab6 (diff) | |
download | bcm5719-llvm-4f26205ba8a596e06b5111ca8eb796bfe7c55737.tar.gz bcm5719-llvm-4f26205ba8a596e06b5111ca8eb796bfe7c55737.zip |
More then one anonymous aggregates on one line creates chaos when MDNode uniquness is combined with RAUW operation. Right solution is to avoid using RAUW.
This fixes PR 6554.
llvm-svn: 98083
-rw-r--r-- | clang/lib/CodeGen/CGDebugInfo.cpp | 8 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGDebugInfo.h | 6 | ||||
-rw-r--r-- | clang/test/CodeGenCXX/2010-03-09-AnonAggregate.cpp | 12 |
3 files changed, 19 insertions, 7 deletions
diff --git a/clang/lib/CodeGen/CGDebugInfo.cpp b/clang/lib/CodeGen/CGDebugInfo.cpp index 892669299c6..02e5d07d6af 100644 --- a/clang/lib/CodeGen/CGDebugInfo.cpp +++ b/clang/lib/CodeGen/CGDebugInfo.cpp @@ -37,7 +37,7 @@ using namespace clang::CodeGen; CGDebugInfo::CGDebugInfo(CodeGenModule &CGM) : CGM(CGM), DebugFactory(CGM.getModule()), - BlockLiteralGenericSet(false) { + FwdDeclCount(0), BlockLiteralGenericSet(false) { CreateCompileUnit(); } @@ -774,12 +774,12 @@ llvm::DIType CGDebugInfo::CreateType(const RecordType *Ty, // A RD->getName() is not unique. However, the debug info descriptors // are uniqued so use type name to ensure uniquness. - std::string STy = QualType(Ty, 0).getAsString(); + char *FwdDeclName = (char *)alloca(65); + sprintf(FwdDeclName, "fwd.type.%d", FwdDeclCount++); llvm::DIDescriptor FDContext = getContextDescriptor(dyn_cast<Decl>(RD->getDeclContext()), Unit); llvm::DICompositeType FwdDecl = - DebugFactory.CreateCompositeType(Tag, FDContext, - STy.c_str(), + DebugFactory.CreateCompositeType(Tag, FDContext, FwdDeclName, DefUnit, Line, 0, 0, 0, 0, llvm::DIType(), llvm::DIArray()); diff --git a/clang/lib/CodeGen/CGDebugInfo.h b/clang/lib/CodeGen/CGDebugInfo.h index f71f3626be0..47a46204834 100644 --- a/clang/lib/CodeGen/CGDebugInfo.h +++ b/clang/lib/CodeGen/CGDebugInfo.h @@ -45,11 +45,11 @@ class CGDebugInfo { CodeGenModule &CGM; llvm::DIFactory DebugFactory; llvm::DICompileUnit TheCU; - SourceLocation CurLoc, PrevLoc; - llvm::DIType VTablePtrType; - + /// FwdDeclCount - This counter is used to ensure unique names for forward + /// record decls. + unsigned FwdDeclCount; /// TypeCache - Cache of previously constructed Types. // FIXME: Eliminate this map. Be careful of iterator invalidation. diff --git a/clang/test/CodeGenCXX/2010-03-09-AnonAggregate.cpp b/clang/test/CodeGenCXX/2010-03-09-AnonAggregate.cpp new file mode 100644 index 00000000000..99883d82636 --- /dev/null +++ b/clang/test/CodeGenCXX/2010-03-09-AnonAggregate.cpp @@ -0,0 +1,12 @@ +// RUN: %clang_cc1 -g -S -o %t %s +// PR: 6554 +// More then one anonymous aggregates on one line creates chaos when MDNode uniquness is +// combined with RAUW operation. +// This test case causes crashes if malloc is configured to trip buffer overruns. +class MO { + + union { struct { union { int BA; } Val; int Offset; } OffsetedInfo; } Contents; + +}; + +class MO m; |