[ARM] More MVE compare vector splat combines for ANDs
[llvm-complete.git] / test / DebugInfo / ARM / sdag-split-arg1.ll
blob78cdc4dd4bdaeace2b9c21dca3fbb05543452d80
1 ; RUN: llc -filetype=asm %s -o -  -stop-after=livedebugvalues | FileCheck %s
2 ; This tests that transferring debug info describing the lower bits of
3 ; an extended SDNode works.
4 target triple = "thumbv6m-apple-unknown-macho"
5 define arm_aapcscc i64 @f(double %a) !dbg !5 {
6 entry:
7   %0 = bitcast double %a to i64
8   %extract.t84 = trunc i64 %0 to i32
9   tail call void @llvm.dbg.value(metadata i32 %extract.t84, metadata !8, metadata !DIExpression(DW_OP_LLVM_fragment, 0, 32)), !dbg !12
10   ; CHECK: DBG_VALUE $r0, $noreg, !6, !DIExpression(DW_OP_LLVM_fragment, 0, 32)
11   %r.sroa.0.0.insert.ext35 = zext i32 %extract.t84 to i64
12   ret i64 %r.sroa.0.0.insert.ext35
15 declare void @llvm.dbg.value(metadata, metadata, metadata)
17 !llvm.dbg.cu = !{!0}
18 !llvm.module.flags = !{!3}
20 !0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "LLVM", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, retainedTypes: !2)
21 !1 = !DIFile(filename: "f.c", directory: "/")
22 !2 = !{}
23 !3 = !{i32 2, !"Debug Info Version", i32 3}
24 !5 = distinct !DISubprogram(name: "f", scope: !1, file: !1, line: 29, type: !7, isLocal: false, isDefinition: true, scopeLine: 30, flags: DIFlagPrototyped, isOptimized: true, unit: !0, retainedNodes: !2)
25 !7 = !DISubroutineType(types: !2)
26 !8 = !DILocalVariable(name: "r", scope: !5, file: !1, line: 37, type: !11)
27 !11 = distinct !DICompositeType(tag: DW_TAG_union_type, file: !1, line: 33, size: 64, elements: !2)
28 !12 = !DILocation(line: 37, column: 12, scope: !5)