; Verify the behavior of the IntelJITEventListener. ; RUN: llvm-jitlistener %s | FileCheck %s ; This test was created using the following file: ; ; 1: int foo(int a) { ; 2: return a; ; 3: } ; 4: ; 5: int bar(int a) { ; 6: if (a == 0) { ; 7: return 0; ; 8: } ; 9: return 100/a; ; 10: } ; 11: ; 12: int fubar(int a) { ; 13: switch (a) { ; 14: case 0: ; 15: return 10; ; 16: case 1: ; 17: return 20; ; 18: default: ; 19: return 30; ; 20: } ; 21: } ; ; CHECK: Method load [1]: bar, Size = {{[0-9]+}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[5,6,7,9]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[5,6,7,9]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[5,6,7,9]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[5,6,7,9]}} ; CHECK: Method load [2]: foo, Size = {{[0-9]+}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[1,2]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[1,2]}} ; CHECK: Method load [3]: fubar, Size = {{[0-9]+}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[12,13,15,17,19]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[12,13,15,17,19]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[12,13,15,17,19]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[12,13,15,17,19]}} ; CHECK: Line info @ {{[0-9]+}}: multiple.c, line {{[12,13,15,17,19]}} ; CHECK: Method unload [1] ; CHECK: Method unload [2] ; CHECK: Method unload [3] ; ModuleID = 'multiple.c' ; Function Attrs: nounwind uwtable define i32 @foo(i32 %a) #0 { entry: %a.addr = alloca i32, align 4 store i32 %a, i32* %a.addr, align 4 call void @llvm.dbg.declare(metadata i32* %a.addr, metadata !15, metadata !16), !dbg !17 %0 = load i32* %a.addr, align 4, !dbg !18 ret i32 %0, !dbg !19 } ; Function Attrs: nounwind readnone declare void @llvm.dbg.declare(metadata, metadata, metadata) #1 ; Function Attrs: nounwind uwtable define i32 @bar(i32 %a) #0 { entry: %retval = alloca i32, align 4 %a.addr = alloca i32, align 4 store i32 %a, i32* %a.addr, align 4 call void @llvm.dbg.declare(metadata i32* %a.addr, metadata !20, metadata !16), !dbg !21 %0 = load i32* %a.addr, align 4, !dbg !22 %cmp = icmp eq i32 %0, 0, !dbg !22 br i1 %cmp, label %if.then, label %if.end, !dbg !24 if.then: ; preds = %entry store i32 0, i32* %retval, !dbg !25 br label %return, !dbg !25 if.end: ; preds = %entry %1 = load i32* %a.addr, align 4, !dbg !27 %div = sdiv i32 100, %1, !dbg !28 store i32 %div, i32* %retval, !dbg !29 br label %return, !dbg !29 return: ; preds = %if.end, %if.then %2 = load i32* %retval, !dbg !30 ret i32 %2, !dbg !30 } ; Function Attrs: nounwind uwtable define i32 @fubar(i32 %a) #0 { entry: %retval = alloca i32, align 4 %a.addr = alloca i32, align 4 store i32 %a, i32* %a.addr, align 4 call void @llvm.dbg.declare(metadata i32* %a.addr, metadata !31, metadata !16), !dbg !32 %0 = load i32* %a.addr, align 4, !dbg !33 switch i32 %0, label %sw.default [ i32 0, label %sw.bb i32 1, label %sw.bb1 ], !dbg !34 sw.bb: ; preds = %entry store i32 10, i32* %retval, !dbg !35 br label %return, !dbg !35 sw.bb1: ; preds = %entry store i32 20, i32* %retval, !dbg !37 br label %return, !dbg !37 sw.default: ; preds = %entry store i32 30, i32* %retval, !dbg !38 br label %return, !dbg !38 return: ; preds = %sw.default, %sw.bb1, %sw.bb %1 = load i32* %retval, !dbg !39 ret i32 %1, !dbg !39 } attributes #0 = { nounwind uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" } attributes #1 = { nounwind readnone } !llvm.dbg.cu = !{!0} !llvm.module.flags = !{!11, !12, !13} !llvm.ident = !{!14} !0 = !{!"0x11\0012\00clang version 3.6.0 (trunk)\000\00\000\00\001", !1, !2, !2, !3, !2, !2} ; [ DW_TAG_compile_unit ] [F:\users\akaylor\llvm-s\llvm\test\JitListener/multiple.c] [DW_LANG_C99] !1 = !{!"multiple.c", !"F:\5Cusers\5Cakaylor\5Cllvm-s\5Cllvm\5Ctest\5CJitListener"} !2 = !{} !3 = !{!4, !9, !10} !4 = !{!"0x2e\00foo\00foo\00\001\000\001\000\000\00256\000\001", !1, !5, !6, null, i32 (i32)* @foo, null, null, !2} ; [ DW_TAG_subprogram ] [line 1] [def] [foo] !5 = !{!"0x29", !1} ; [ DW_TAG_file_type ] [F:\users\akaylor\llvm-s\llvm\test\JitListener/multiple.c] !6 = !{!"0x15\00\000\000\000\000\000\000", null, null, null, !7, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] !7 = !{!8, !8} !8 = !{!"0x24\00int\000\0032\0032\000\000\005", null, null} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed] !9 = !{!"0x2e\00bar\00bar\00\005\000\001\000\000\00256\000\005", !1, !5, !6, null, i32 (i32)* @bar, null, null, !2} ; [ DW_TAG_subprogram ] [line 5] [def] [bar] !10 = !{!"0x2e\00fubar\00fubar\00\0012\000\001\000\000\00256\000\0012", !1, !5, !6, null, i32 (i32)* @fubar, null, null, !2} ; [ DW_TAG_subprogram ] [line 12] [def] [fubar] !11 = !{i32 2, !"Dwarf Version", i32 4} !12 = !{i32 2, !"Debug Info Version", i32 2} !13 = !{i32 1, !"PIC Level", i32 2} !14 = !{!"clang version 3.6.0 (trunk)"} !15 = !{!"0x101\00a\0016777217\000", !4, !5, !8} ; [ DW_TAG_arg_variable ] [a] [line 1] !16 = !{!"0x102"} ; [ DW_TAG_expression ] !17 = !{i32 1, i32 13, !4, null} !18 = !{i32 2, i32 10, !4, null} !19 = !{i32 2, i32 3, !4, null} !20 = !{!"0x101\00a\0016777221\000", !9, !5, !8} ; [ DW_TAG_arg_variable ] [a] [line 5] !21 = !{i32 5, i32 13, !9, null} !22 = !{i32 6, i32 7, !23, null} !23 = !{!"0xb\006\007\000", !1, !9} ; [ DW_TAG_lexical_block ] [F:\users\akaylor\llvm-s\llvm\test\JitListener/multiple.c] !24 = !{i32 6, i32 7, !9, null} !25 = !{i32 7, i32 5, !26, null} !26 = !{!"0xb\006\0015\001", !1, !23} ; [ DW_TAG_lexical_block ] [F:\users\akaylor\llvm-s\llvm\test\JitListener/multiple.c] !27 = !{i32 9, i32 14, !9, null} !28 = !{i32 9, i32 10, !9, null} !29 = !{i32 9, i32 3, !9, null} !30 = !{i32 10, i32 1, !9, null} !31 = !{!"0x101\00a\0016777228\000", !10, !5, !8} ; [ DW_TAG_arg_variable ] [a] [line 12] !32 = !{i32 12, i32 15, !10, null} !33 = !{i32 13, i32 11, !10, null} !34 = !{i32 13, i32 3, !10, null} !35 = !{i32 15, i32 7, !36, null} !36 = !{!"0xb\0013\0014\002", !1, !10} ; [ DW_TAG_lexical_block ] [F:\users\akaylor\llvm-s\llvm\test\JitListener/multiple.c] !37 = !{i32 17, i32 7, !36, null} !38 = !{i32 19, i32 7, !36, null} !39 = !{i32 21, i32 1, !10, null}