two-cus-from-same-file.ll 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. ; For http://llvm.org/bugs/show_bug.cgi?id=12942
  2. ; There are two CUs coming from /tmp/foo.c in this module. Make sure it doesn't
  3. ; blow llc up and produces something reasonable.
  4. ;
  5. ; REQUIRES: object-emission
  6. ; RUN: %llc_dwarf %s -o %t -filetype=obj -O0
  7. ; RUN: llvm-dwarfdump -debug-info %t | FileCheck %s
  8. ; ModuleID = 'test.bc'
  9. @str = private unnamed_addr constant [4 x i8] c"FOO\00"
  10. @str1 = private unnamed_addr constant [6 x i8] c"Main!\00"
  11. define void @foo() nounwind !dbg !5 {
  12. entry:
  13. %puts = tail call i32 @puts(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @str, i32 0, i32 0)), !dbg !23
  14. ret void, !dbg !25
  15. }
  16. declare i32 @puts(i8* nocapture) nounwind
  17. define i32 @main(i32 %argc, i8** nocapture %argv) nounwind !dbg !12 {
  18. entry:
  19. tail call void @llvm.dbg.value(metadata i32 %argc, metadata !21, metadata !DIExpression()), !dbg !26
  20. ; Avoid talking about the pointer size in debug info because that's target dependent
  21. tail call void @llvm.dbg.value(metadata i8** %argv, metadata !22, metadata !DIExpression(DW_OP_deref, DW_OP_deref)), !dbg !27
  22. %puts = tail call i32 @puts(i8* getelementptr inbounds ([6 x i8], [6 x i8]* @str1, i32 0, i32 0)), !dbg !28
  23. tail call void @foo() nounwind, !dbg !30
  24. ret i32 0, !dbg !31
  25. }
  26. declare void @llvm.dbg.value(metadata, metadata, metadata) nounwind readnone
  27. !llvm.dbg.cu = !{!0, !9}
  28. !llvm.module.flags = !{!33}
  29. !0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.2 (trunk 156513)", isOptimized: true, emissionKind: FullDebug, file: !32, enums: !1, retainedTypes: !1, globals: !1, imports: !1)
  30. !1 = !{}
  31. !5 = distinct !DISubprogram(name: "foo", line: 5, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !0, scopeLine: 5, file: !32, scope: !6, type: !7, retainedNodes: !1)
  32. !6 = !DIFile(filename: "foo.c", directory: "/tmp")
  33. !7 = !DISubroutineType(types: !8)
  34. !8 = !{null}
  35. !9 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.2 (trunk 156513)", isOptimized: true, emissionKind: FullDebug, file: !32, enums: !1, retainedTypes: !1, globals: !1, imports: !1)
  36. !12 = distinct !DISubprogram(name: "main", line: 11, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !9, scopeLine: 11, file: !32, scope: !6, type: !13, retainedNodes: !19)
  37. !13 = !DISubroutineType(types: !14)
  38. !14 = !{!15, !15, !18}
  39. !15 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
  40. !18 = !DIBasicType(tag: DW_TAG_base_type, name: "char", size: 8, align: 8, encoding: DW_ATE_signed_char)
  41. !19 = !{!21, !22}
  42. !21 = !DILocalVariable(name: "argc", line: 11, arg: 1, scope: !12, file: !6, type: !15)
  43. !22 = !DILocalVariable(name: "argv", line: 11, arg: 2, scope: !12, file: !6, type: !18)
  44. !23 = !DILocation(line: 6, column: 3, scope: !24)
  45. !24 = distinct !DILexicalBlock(line: 5, column: 16, file: !32, scope: !5)
  46. !25 = !DILocation(line: 7, column: 1, scope: !24)
  47. !26 = !DILocation(line: 11, column: 14, scope: !12)
  48. !27 = !DILocation(line: 11, column: 26, scope: !12)
  49. !28 = !DILocation(line: 12, column: 3, scope: !29)
  50. !29 = distinct !DILexicalBlock(line: 11, column: 34, file: !32, scope: !12)
  51. !30 = !DILocation(line: 13, column: 3, scope: !29)
  52. !31 = !DILocation(line: 14, column: 3, scope: !29)
  53. !32 = !DIFile(filename: "foo.c", directory: "/tmp")
  54. ; This test is simple to be cross platform (many targets don't yet have
  55. ; sufficiently good DWARF emission and/or dumping)
  56. ; CHECK: {{DW_TAG_compile_unit}}
  57. ; CHECK: {{foo\.c}}
  58. !33 = !{i32 1, !"Debug Info Version", i32 3}