| # RUN: llc %s --start-after=livedebugvalues --filetype=obj -o - \ |
| # RUN: | llvm-dwarfdump - --name=test-var -o - | FileCheck %s |
| |
| # Test that when an entry value expression appears in a DBG_VALUE_LIST, we are |
| # able to produce a valid entry value location in DWARF. |
| |
| # CHECK: DW_OP_entry_value(DW_OP_reg14 R14), DW_OP_plus_uconst 0x10, DW_OP_plus_uconst 0x10, DW_OP_deref |
| |
| --- | |
| source_filename = "test.ll" |
| target datalayout = "e-m:o-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128" |
| target triple = "x86_64-apple-macosx12.1.0" |
| |
| declare void @llvm.dbg.value(metadata, metadata, metadata) |
| |
| define swifttailcc void @blah(ptr swiftasync %0) !dbg !15 { |
| %use = getelementptr i8, ptr %0, i64 9 |
| call void @llvm.dbg.value(metadata ptr %0, metadata !18, metadata !DIExpression(DW_OP_LLVM_entry_value, 1, DW_OP_plus_uconst, 16, DW_OP_plus_uconst, 16, DW_OP_deref, DW_OP_deref)), !dbg !22 |
| %use1 = load i32, ptr null, align 4, !dbg !27 |
| %use2 = sext i32 %use1 to i64 |
| %use3 = getelementptr i8, ptr null, i64 %use2 |
| store ptr %use3, ptr %0, align 8 |
| ret void |
| } |
| |
| !llvm.module.flags = !{!0} |
| !llvm.dbg.cu = !{!1} |
| |
| !0 = !{i32 2, !"Debug Info Version", i32 3} |
| !1 = distinct !DICompileUnit(language: DW_LANG_Swift, file: !2, producer: "blah", isOptimized: true, flags: "blah", runtimeVersion: 5, emissionKind: FullDebug, globals: !3, imports: !9, sysroot: "blah", sdk: "blah") |
| !2 = !DIFile(filename: "blah", directory: "blah") |
| !3 = !{!4, !10} |
| !4 = !DIGlobalVariableExpression(var: !5, expr: !DIExpression()) |
| !5 = distinct !DIGlobalVariable(name: "blah", linkageName: "blah", scope: !6, file: !2, line: 49, type: !7, isLocal: true, isDefinition: true) |
| !6 = !DIModule(scope: null, name: "blah", includePath: "blah") |
| !7 = !DIDerivedType(tag: DW_TAG_const_type, baseType: !8) |
| !8 = !DICompositeType(tag: DW_TAG_structure_type, name: "blah", scope: !6, file: !2, size: 64, elements: !9, runtimeLang: DW_LANG_Swift, identifier: "blah") |
| !9 = !{} |
| !10 = !DIGlobalVariableExpression(var: !11, expr: !DIExpression()) |
| !11 = distinct !DIGlobalVariable(name: "blah", linkageName: "blah", scope: !6, file: !2, line: 44, type: !12, isLocal: false, isDefinition: true) |
| !12 = !DIDerivedType(tag: DW_TAG_const_type, baseType: !13) |
| !13 = !DICompositeType(tag: DW_TAG_structure_type, name: "blah", scope: !14, file: !2, size: 64, elements: !9, runtimeLang: DW_LANG_Swift, identifier: "blah") |
| !14 = !DIModule(scope: null, name: "blah", configMacros: "blah", includePath: "blah") |
| !15 = distinct !DISubprogram(name: "blah", linkageName: "blah", scope: !16, file: !2, line: 115, type: !17, scopeLine: 117, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !1, retainedNodes: !9, thrownTypes: !9) |
| !16 = !DICompositeType(tag: DW_TAG_structure_type, name: "blah", scope: !6, file: !2, elements: !9, runtimeLang: DW_LANG_Swift, identifier: "blah") |
| !17 = !DISubroutineType(types: !9) |
| !18 = !DILocalVariable(name: "test-var", arg: 1, scope: !19, file: !2, line: 95, type: !21, flags: DIFlagArtificial) |
| !19 = distinct !DISubprogram(name: "blah", linkageName: "blah", scope: !16, file: !2, line: 95, type: !20, scopeLine: 95, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !1, retainedNodes: !9) |
| !20 = distinct !DISubroutineType(types: !9) |
| !21 = !DIDerivedType(tag: DW_TAG_const_type, baseType: !16) |
| !22 = !DILocation(line: 95, column: 9, scope: !19, inlinedAt: !23) |
| !23 = distinct !DILocation(line: 0, scope: !24, inlinedAt: !25) |
| !24 = distinct !DISubprogram(name: "blah", linkageName: "blah", scope: !16, file: !2, type: !20, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !1) |
| !25 = distinct !DILocation(line: 121, column: 36, scope: !26) |
| !26 = distinct !DILexicalBlock(scope: !15, file: !2, line: 116, column: 7) |
| !27 = !DILocation(line: 0, scope: !28, inlinedAt: !23) |
| !28 = !DILexicalBlockFile(scope: !19, file: !2, discriminator: 0) |
| |
| ... |
| --- |
| name: blah |
| alignment: 16 |
| tracksRegLiveness: true |
| debugInstrRef: true |
| tracksDebugUserValues: true |
| registers: [] |
| liveins: |
| - { reg: '$r14', virtual-reg: '' } |
| frameInfo: |
| maxAlignment: 1 |
| body: | |
| bb.0 (%ir-block.1): |
| liveins: $r14 |
| |
| DBG_PHI $r14, 1 |
| DBG_INSTR_REF !18, !DIExpression(DW_OP_LLVM_arg, 0, DW_OP_LLVM_entry_value, 1, DW_OP_plus_uconst, 16, DW_OP_plus_uconst, 16, DW_OP_deref, DW_OP_deref), dbg-instr-ref(1, 0), debug-location !22 |
| DBG_VALUE_LIST !18, !DIExpression(DW_OP_LLVM_arg, 0, DW_OP_LLVM_entry_value, 1, DW_OP_plus_uconst, 16, DW_OP_plus_uconst, 16, DW_OP_deref, DW_OP_deref), $r14, debug-location !DILocation(line: 0, scope: !19, inlinedAt: !23) |
| renamable $rax = MOVSX64rm32 $noreg, 1, $noreg, 0, $noreg, debug-location !27 :: (load (s32) from `ptr null`) |
| MOV64mr killed renamable $r14, 1, $noreg, 0, $noreg, killed renamable $rax :: (store (s64) into %ir.0) |
| RETI64 8 |
| |
| ... |