From: Devang Patel Date: Fri, 6 Nov 2009 18:24:05 +0000 (+0000) Subject: Tolerate invalid derived type. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=5ebfa2d181dccee5e23421a41910a7a1851d358e;p=oota-llvm.git Tolerate invalid derived type. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@86269 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/DebugInfo.cpp b/lib/Analysis/DebugInfo.cpp index 7c1cc35ee9d..24b5ad44f28 100644 --- a/lib/Analysis/DebugInfo.cpp +++ b/lib/Analysis/DebugInfo.cpp @@ -409,6 +409,10 @@ uint64_t DIDerivedType::getOriginalTypeSize() const { Tag == dwarf::DW_TAG_const_type || Tag == dwarf::DW_TAG_volatile_type || Tag == dwarf::DW_TAG_restrict_type) { DIType BaseType = getTypeDerivedFrom(); + // If this type is not derived from any type then take conservative + // approach. + if (BaseType.isNull()) + return getSizeInBits(); if (BaseType.isDerivedType()) return DIDerivedType(BaseType.getNode()).getOriginalTypeSize(); else diff --git a/test/DebugInfo/2009-11-06-InvalideDerivedType.ll b/test/DebugInfo/2009-11-06-InvalideDerivedType.ll new file mode 100644 index 00000000000..73211bb2635 --- /dev/null +++ b/test/DebugInfo/2009-11-06-InvalideDerivedType.ll @@ -0,0 +1,13 @@ +; RUN: llc %s -o /dev/null +%struct._t = type { i32 } + +@s1 = common global %struct._t zeroinitializer, align 4 ; <%struct._t*> [#uses=0] + +!llvm.dbg.gv = !{!0} + +!0 = metadata !{i32 458804, i32 0, metadata !1, metadata !"s1", metadata !"s1", metadata !"s1", metadata !1, i32 3, metadata !2, i1 false, i1 true, %struct._t* @s1}; [DW_TAG_variable ] +!1 = metadata !{i32 458769, i32 0, i32 12, metadata !"t.c", metadata !"/tmp", metadata !"clang 1.1", i1 true, i1 false, metadata !"", i32 0}; [DW_TAG_compile_unit ] +!2 = metadata !{i32 458771, metadata !1, metadata !"_t", metadata !1, i32 1, i64 32, i64 32, i64 0, i32 0, null, metadata !3, i32 0}; [DW_TAG_structure_type ] +!3 = metadata !{metadata !4} +!4 = metadata !{i32 458765, metadata !1, metadata !"j", metadata !1, i32 2, i64 32, i64 32, i64 0, i32 0, metadata !5}; [DW_TAG_member ] +!5 = metadata !{i32 458790, metadata !1, metadata !"", null, i32 0, i64 0, i64 0, i64 0, i32 0, null}; [DW_TAG_const_type ]