2015-01-14 05:10:44 +08:00
|
|
|
; RUN: llvm-as < %s | llvm-dis | FileCheck %s
|
|
|
|
; RUN: verify-uselistorder %s
|
|
|
|
|
[IR] Add a boolean field in DILocation to know if a line must covered or not
Summary:
Some lines have a hit counter where they should not have one.
For example, in C++, some cleanup is adding at the end of a scope represented by a '}'.
So such a line has a hit counter where a user expects to not have one.
The goal of the patch is to add this information in DILocation which is used to get the covered lines in GCOVProfiling.cpp.
A following patch in clang will add this information when generating IR (https://reviews.llvm.org/D49916).
Reviewers: marco-c, davidxl, vsk, javed.absar, rnk
Reviewed By: rnk
Subscribers: eraman, xur, danielcdh, aprantl, rnk, dblaikie, #debug-info, vsk, llvm-commits, sylvestre.ledru
Tags: #debug-info
Differential Revision: https://reviews.llvm.org/D49915
llvm-svn: 342631
2018-09-20 16:53:06 +08:00
|
|
|
; CHECK: !named = !{!0, !2, !3, !3, !4, !4, !5, !5, !6, !7, !8}
|
|
|
|
!named = !{!0, !2, !3, !4, !5, !6, !7, !8, !9, !10, !11}
|
2015-01-14 05:10:44 +08:00
|
|
|
|
[IR] Add a boolean field in DILocation to know if a line must covered or not
Summary:
Some lines have a hit counter where they should not have one.
For example, in C++, some cleanup is adding at the end of a scope represented by a '}'.
So such a line has a hit counter where a user expects to not have one.
The goal of the patch is to add this information in DILocation which is used to get the covered lines in GCOVProfiling.cpp.
A following patch in clang will add this information when generating IR (https://reviews.llvm.org/D49916).
Reviewers: marco-c, davidxl, vsk, javed.absar, rnk
Reviewed By: rnk
Subscribers: eraman, xur, danielcdh, aprantl, rnk, dblaikie, #debug-info, vsk, llvm-commits, sylvestre.ledru
Tags: #debug-info
Differential Revision: https://reviews.llvm.org/D49915
llvm-svn: 342631
2018-09-20 16:53:06 +08:00
|
|
|
!llvm.module.flags = !{!12}
|
2016-04-15 23:57:41 +08:00
|
|
|
!llvm.dbg.cu = !{!1}
|
2016-04-04 10:11:34 +08:00
|
|
|
|
2015-08-29 04:26:49 +08:00
|
|
|
; CHECK: !0 = distinct !DISubprogram(
|
2016-04-15 23:57:41 +08:00
|
|
|
!0 = distinct !DISubprogram(unit: !1)
|
|
|
|
; CHECK: !1 = distinct !DICompileUnit
|
|
|
|
!1 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang",
|
|
|
|
file: !2,
|
|
|
|
isOptimized: true, flags: "-O2",
|
|
|
|
splitDebugFilename: "abc.debug", emissionKind: 2)
|
|
|
|
; CHECK: !2 = !DIFile
|
|
|
|
!2 = !DIFile(filename: "path/to/file", directory: "/path/to/dir")
|
2015-01-14 05:10:44 +08:00
|
|
|
|
2016-04-15 23:57:41 +08:00
|
|
|
; CHECK-NEXT: !3 = !DILocation(line: 3, column: 7, scope: !0)
|
|
|
|
!3 = !DILocation(line: 3, column: 7, scope: !0)
|
|
|
|
!4 = !DILocation(scope: !0, column: 7, line: 3)
|
2015-01-14 05:10:44 +08:00
|
|
|
|
2016-04-15 23:57:41 +08:00
|
|
|
; CHECK-NEXT: !4 = !DILocation(line: 3, column: 7, scope: !0, inlinedAt: !3)
|
|
|
|
!5 = !DILocation(scope: !0, inlinedAt: !3, column: 7, line: 3)
|
|
|
|
!6 = !DILocation(column: 7, line: 3, scope: !0, inlinedAt: !3)
|
2015-01-14 05:10:44 +08:00
|
|
|
|
2016-04-15 23:57:41 +08:00
|
|
|
; CHECK-NEXT: !5 = !DILocation(line: 0, scope: !0)
|
|
|
|
!7 = !DILocation(scope: !0)
|
|
|
|
!8 = !DILocation(scope: !0, column: 0, line: 0)
|
2015-01-17 01:33:08 +08:00
|
|
|
|
2016-04-15 23:57:41 +08:00
|
|
|
; CHECK-NEXT: !6 = !DILocation(line: 4294967295, column: 65535, scope: !0)
|
|
|
|
!9 = !DILocation(line: 4294967295, column: 65535, scope: !0)
|
2016-04-04 10:11:34 +08:00
|
|
|
|
[IR] Add a boolean field in DILocation to know if a line must covered or not
Summary:
Some lines have a hit counter where they should not have one.
For example, in C++, some cleanup is adding at the end of a scope represented by a '}'.
So such a line has a hit counter where a user expects to not have one.
The goal of the patch is to add this information in DILocation which is used to get the covered lines in GCOVProfiling.cpp.
A following patch in clang will add this information when generating IR (https://reviews.llvm.org/D49916).
Reviewers: marco-c, davidxl, vsk, javed.absar, rnk
Reviewed By: rnk
Subscribers: eraman, xur, danielcdh, aprantl, rnk, dblaikie, #debug-info, vsk, llvm-commits, sylvestre.ledru
Tags: #debug-info
Differential Revision: https://reviews.llvm.org/D49915
llvm-svn: 342631
2018-09-20 16:53:06 +08:00
|
|
|
!10 = !DILocation(scope: !0, column: 0, line: 0, isImplicitCode: true)
|
|
|
|
!11 = !DILocation(scope: !0, column: 0, line: 1, isImplicitCode: false)
|
|
|
|
; CHECK-NEXT: !7 = !DILocation(line: 0, scope: !0, isImplicitCode: true)
|
|
|
|
; CHECK-NEXT: !8 = !DILocation(line: 1, scope: !0)
|
|
|
|
|
|
|
|
!12 = !{i32 2, !"Debug Info Version", i32 3}
|