1 ; RUN: llc < %s -asm-verbose=false -march=x86-64 -use-unknown-locations | FileCheck %s
3 ; The divide instruction does not have a debug location. CodeGen should
4 ; represent this in the debug information. This is checked by a check
5 ; for a label between the code for the add and the code for the divide,
6 ; which indicates that the add's location doesn't spill over unto the
9 ; CHECK: leal (%rdi,%rsi), %eax
12 ; CHECK-NEXT: idivl %r8d
14 ; CHECK-NEXT: addl %ecx, %eax
18 define i32 @foo(i32 %w, i32 %x, i32 %y, i32 %z) nounwind {
20 %a = add i32 %w, %x, !dbg !8
22 %c = add i32 %b, %z, !dbg !8
26 !0 = metadata !{i32 524545, metadata !1, metadata !"x", metadata !2, i32 1, metadata !6} ; [ DW_TAG_arg_variable ]
27 !1 = metadata !{i32 524334, i32 0, metadata !2, metadata !"foo", metadata !"foo", metadata !"foo", metadata !2, i32 1, metadata !4, i1 false, i1 true, i32 0, i32 0, null, i1 false, i1 false} ; [ DW_TAG_subprogram ]
28 !2 = metadata !{i32 524329, metadata !"test.c", metadata !"/dir", metadata !3} ; [ DW_TAG_file_type ]
29 !3 = metadata !{i32 524305, i32 0, i32 12, metadata !"test.c", metadata !".", metadata !"producer", i1 true, i1 false, metadata !"", i32 0} ; [ DW_TAG_compile_unit ]
30 !4 = metadata !{i32 524309, metadata !2, metadata !"", metadata !2, i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !5, i32 0, null} ; [ DW_TAG_subroutine_type ]
31 !5 = metadata !{metadata !6}
32 !6 = metadata !{i32 524324, metadata !2, metadata !"int", metadata !2, i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ]
33 !7 = metadata !{i32 524299, metadata !1, i32 1, i32 30} ; [ DW_TAG_lexical_block ]
34 !8 = metadata !{i32 4, i32 3, metadata !7, null}