diff options
| author | Peter Collingbourne <peter@pcc.me.uk> | 2015-03-25 17:44:49 +0000 |
|---|---|---|
| committer | Peter Collingbourne <peter@pcc.me.uk> | 2015-03-25 17:44:49 +0000 |
| commit | b736065f782a36f594a4b3ae1ed28f854fab2fc4 (patch) | |
| tree | fa1d038dbed0ab2ed2f9a9398cce174eda25fdbf /llvm/test/DebugInfo | |
| parent | 2f8f019daf0fc3cee5df09988d7a9121bdcbf4c9 (diff) | |
| download | bcm5719-llvm-b736065f782a36f594a4b3ae1ed28f854fab2fc4.tar.gz bcm5719-llvm-b736065f782a36f594a4b3ae1ed28f854fab2fc4.zip | |
DebugInfo: Permit DW_TAG_structure_type, DW_TAG_member, DW_TAG_typedef tags with empty file names.
Some languages, such as Go, have pre-defined structure types (e.g. "string"
is essentially a pointer/length pair) or pre-defined "typedef" types
(e.g. "error" is essentially a typedef for a specific interface type).
Such types do not have associated source location, so a Go frontend would
be correct not to associate a file name with such types.
This change relaxes the DIType verifier to permit unlocated types with
these tags.
Differential Revision: http://reviews.llvm.org/D8588
llvm-svn: 233200
Diffstat (limited to 'llvm/test/DebugInfo')
| -rw-r--r-- | llvm/test/DebugInfo/X86/missing-file-line.ll | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/llvm/test/DebugInfo/X86/missing-file-line.ll b/llvm/test/DebugInfo/X86/missing-file-line.ll new file mode 100644 index 00000000000..2e84b8affeb --- /dev/null +++ b/llvm/test/DebugInfo/X86/missing-file-line.ll @@ -0,0 +1,61 @@ +; REQUIRES: object-emission + +; RUN: llc -mtriple=x86_64-linux-gnu -filetype=obj %s -o - | llvm-dwarfdump -debug-dump=all - > %t +; RUN: FileCheck --check-prefix=CHECK1 %s < %t +; RUN: FileCheck --check-prefix=CHECK2 %s < %t +; RUN: FileCheck --check-prefix=CHECK3 %s < %t + +; Test that we accept and generate DWARF entities for DW_TAG_structure_type, +; DW_TAG_member and DW_TAG_typedef with no source location. These can come up +; in some languages with predefined types. + +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" +target triple = "x86_64-unknown-linux-gnu" + +%struct.S = type { %struct.S* } + +define void @f() { + %x = alloca %struct.S, align 8 + ; CHECK1: DW_TAG_structure_type + ; CHECK1-NOT: DW_AT_decl_file + ; CHECK1-NOT: DW_AT_decl_line + ; CHECK1: {{DW_TAG|NULL}} + + ; CHECK2: DW_TAG_member + ; CHECK2-NOT: DW_AT_decl_file + ; CHECK2-NOT: DW_AT_decl_line + ; CHECK2: {{DW_TAG|NULL}} + + ; CHECK3: DW_TAG_typedef + ; CHECK3-NOT: DW_AT_decl_file + ; CHECK3-NOT: DW_AT_decl_line + ; CHECK3: {{DW_TAG|NULL}} + call void @llvm.dbg.declare(metadata %struct.S* %x, metadata !10, metadata !16), !dbg !17 + ret void, !dbg !18 +} + +declare void @llvm.dbg.declare(metadata, metadata, metadata) #1 + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!7, !8} +!llvm.ident = !{!9} + +!0 = !MDCompileUnit(language: DW_LANG_C99, file: !1, producer: "clang", isOptimized: false, runtimeVersion: 0, emissionKind: 1, enums: !2, retainedTypes: !2, subprograms: !3, globals: !2, imports: !2) +!1 = !MDFile(filename: "file.c", directory: "/dir") +!2 = !{} +!3 = !{!4} +!4 = !MDSubprogram(name: "f", scope: !1, file: !1, line: 7, type: !5, isLocal: false, isDefinition: true, scopeLine: 7, isOptimized: false, function: void ()* @f, variables: !2) +!5 = !MDSubroutineType(types: !6) +!6 = !{null} +!7 = !{i32 2, !"Dwarf Version", i32 4} +!8 = !{i32 2, !"Debug Info Version", i32 3} +!9 = !{!"clang"} +!10 = !MDLocalVariable(tag: DW_TAG_auto_variable, name: "x", scope: !4, file: !1, line: 8, type: !11) +!11 = !MDDerivedType(tag: DW_TAG_typedef, name: "SS", baseType: !12) +!12 = !MDCompositeType(tag: DW_TAG_structure_type, name: "S", size: 64, align: 64, elements: !13) +!13 = !{!14} +!14 = !MDDerivedType(tag: DW_TAG_member, name: "s", scope: !12, baseType: !15, size: 64, align: 64) +!15 = !MDDerivedType(tag: DW_TAG_pointer_type, baseType: !12, size: 64, align: 64) +!16 = !MDExpression() +!17 = !MDLocation(line: 8, column: 6, scope: !4) +!18 = !MDLocation(line: 9, column: 1, scope: !4) |

