xref: /llvm-project/llvm/test/DebugInfo/ARM/partial-subreg.ll (revision bf2b2f08b02d424ee70260336974fb34d8779c3e)
116aa4cf7SAdrian Prantl; RUN: llc %s -filetype=obj -o - | llvm-dwarfdump -v - | FileCheck %s
25542da4bSAdrian Prantl; This tests a fragment that partially covers subregister compositions.
35542da4bSAdrian Prantl;
45542da4bSAdrian Prantl; Our fragment is 96 bits long and lies in a 128-bit register, which
55542da4bSAdrian Prantl; in turn has to be composed out of its two 64-bit subregisters.
65542da4bSAdrian Prantl
75542da4bSAdrian Prantl; CHECK: .debug_info
85542da4bSAdrian Prantl; CHECK: DW_TAG_subprogram
95542da4bSAdrian Prantl; CHECK:   DW_AT_name {{.*}}"subscript.get"
105542da4bSAdrian Prantl; CHECK:  DW_TAG_formal_parameter
11a058736cSReid Kleckner; CHECK-NEXT: DW_AT_location [DW_FORM_sec_offset]	({{.*}}
12*9dbeca3dSDavid Stenberg; CHECK-NEXT:  [0x{{.*}}, 0x{{.*}}): DW_OP_regx D16, DW_OP_piece 0x8, DW_OP_regx D17, DW_OP_piece 0x4
13a058736cSReid Kleckner
145542da4bSAdrian Prantlsource_filename = "simd.ll"
155542da4bSAdrian Prantltarget datalayout = "e-m:o-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
165542da4bSAdrian Prantltarget triple = "armv7-apple-ios7.0"
175542da4bSAdrian Prantl
185542da4bSAdrian Prantl; Function Attrs: nounwind readnone
19abe04759SAdrian Prantldeclare void @llvm.dbg.value(metadata, metadata, metadata) #0
205542da4bSAdrian Prantl
215542da4bSAdrian Prantldefine <3 x float> @_TFV4simd8float2x3g9subscriptFSiVS_6float3(i32, <3 x float>, <3 x float>) !dbg !5 {
225542da4bSAdrian Prantlentry:
23abe04759SAdrian Prantl  tail call void @llvm.dbg.value(metadata <3 x float> %1, metadata !8, metadata !9), !dbg !10
24abe04759SAdrian Prantl  tail call void @llvm.dbg.value(metadata <3 x float> %2, metadata !8, metadata !11), !dbg !10
255542da4bSAdrian Prantl  %3 = icmp eq i32 %0, 0, !dbg !12
265542da4bSAdrian Prantl  br i1 %3, label %7, label %4, !dbg !12
275542da4bSAdrian Prantl
285542da4bSAdrian Prantl; <label>:4:                                      ; preds = %entry
295542da4bSAdrian Prantl  %5 = icmp eq i32 %0, 1, !dbg !15
305542da4bSAdrian Prantl  br i1 %5, label %7, label %6, !dbg !15
315542da4bSAdrian Prantl
325542da4bSAdrian Prantl; <label>:6:                                      ; preds = %4
335542da4bSAdrian Prantl  unreachable, !dbg !17
345542da4bSAdrian Prantl
355542da4bSAdrian Prantl; <label>:7:                                      ; preds = %4, %entry
365542da4bSAdrian Prantl  %8 = phi <3 x float> [ %1, %entry ], [ %2, %4 ], !dbg !18
375542da4bSAdrian Prantl  ret <3 x float> %8, !dbg !18
385542da4bSAdrian Prantl}
395542da4bSAdrian Prantl
405542da4bSAdrian Prantlattributes #0 = { nounwind readnone }
415542da4bSAdrian Prantl
425542da4bSAdrian Prantl!llvm.dbg.cu = !{!0}
435542da4bSAdrian Prantl!llvm.module.flags = !{!3, !4}
445542da4bSAdrian Prantl
455542da4bSAdrian Prantl!0 = distinct !DICompileUnit(language: DW_LANG_Swift, file: !1, producer: "Swift", isOptimized: false, runtimeVersion: 3, emissionKind: FullDebug, enums: !2, imports: !2)
465542da4bSAdrian Prantl!1 = !DIFile(filename: "simd.swift", directory: "/")
475542da4bSAdrian Prantl!2 = !{}
485542da4bSAdrian Prantl!3 = !{i32 2, !"Dwarf Version", i32 4}
495542da4bSAdrian Prantl!4 = !{i32 2, !"Debug Info Version", i32 3}
502c864551SShiva Chen!5 = distinct !DISubprogram(name: "subscript.get", linkageName: "_TFV4simd8float2x3g9subscriptFSiVS_6float3", scope: !6, file: !1, type: !7, isLocal: false, isDefinition: true, isOptimized: true, unit: !0, retainedNodes: !2)
515542da4bSAdrian Prantl!6 = !DICompositeType(tag: DW_TAG_structure_type, name: "float2x3", scope: !0, file: !1, line: 5824, size: 256, align: 128, elements: !2, runtimeLang: DW_LANG_Swift, identifier: "_TtV4simd8float2x3")
525542da4bSAdrian Prantl!7 = !DISubroutineType(types: !2)
535542da4bSAdrian Prantl!8 = !DILocalVariable(name: "self", arg: 2, scope: !5, file: !1, line: 5897, type: !6, flags: DIFlagArtificial)
545542da4bSAdrian Prantl!9 = !DIExpression(DW_OP_LLVM_fragment, 0, 96)
555542da4bSAdrian Prantl!10 = !DILocation(line: 5897, column: 5, scope: !5)
565542da4bSAdrian Prantl!11 = !DIExpression(DW_OP_LLVM_fragment, 96, 96)
575542da4bSAdrian Prantl!12 = !DILocation(line: 5900, column: 12, scope: !13)
585542da4bSAdrian Prantl!13 = distinct !DILexicalBlock(scope: !14, file: !1, line: 5898, column: 7)
595542da4bSAdrian Prantl!14 = distinct !DILexicalBlock(scope: !5, file: !1, line: 5897, column: 9)
605542da4bSAdrian Prantl!15 = !DILocation(line: 5902, column: 12, scope: !16)
615542da4bSAdrian Prantl!16 = distinct !DILexicalBlock(scope: !14, file: !1, line: 5898, column: 7)
625542da4bSAdrian Prantl!17 = !DILocation(line: 0, scope: !5)
635542da4bSAdrian Prantl!18 = !DILocation(line: 5906, column: 5, scope: !14)
64