[PATCH] D19708: [CGDebugInfo] Generate debug info for member calls in the context of the callee expression
Hal Finkel via cfe-commits
cfe-commits at lists.llvm.org
Thu Apr 28 20:42:06 PDT 2016
hfinkel created this revision.
hfinkel added reviewers: rsmith, aprantl, dexonsmith, dblaikie, echristo.
hfinkel added a subscriber: cfe-commits.
Herald added subscribers: joker.eph, mcrosier.
We currently generate debug info for member calls in the context of the call expression. For member calls, this has an odd effect, which becomes especially obvious when generating source locations for optimizer-feedback remarks regarding inlining.
Given this:
$ cat -n /tmp/i.cpp
1 void ext();
2
3 struct Bar {
4 void bar() { ext(); }
5 };
6
7 struct Foo {
8 Bar *b;
9
10 Bar *foo() { return b; }
11 };
12
13 void test(Foo *f) {
14 f->foo()->bar();
15 }
$ clang -g /tmp/i.cpp -S -emit-llvm -o -
define void @_Z4testP3Foo(%struct.Foo* %f) #0 !dbg !6 {
...
%call = call %struct.Bar* @_ZN3Foo3fooEv(%struct.Foo* %0), !dbg !27
call void @_ZN3Bar3barEv(%struct.Bar* %call), !dbg !28
...
!27 = !DILocation(line: 14, column: 3, scope: !6)
!28 = !DILocation(line: 14, column: 3, scope: !29)
but we want instead for the calls to point to the callee expressions (foo() and bar() in this case). With this change, that's what happens.
Fixes PR27567.
http://reviews.llvm.org/D19708
Files:
lib/CodeGen/CGExprCXX.cpp
test/CodeGenCXX/debug-info-member-call.cpp
Index: test/CodeGenCXX/debug-info-member-call.cpp
===================================================================
--- /dev/null
+++ test/CodeGenCXX/debug-info-member-call.cpp
@@ -0,0 +1,24 @@
+// RUN: %clang_cc1 -triple x86_64-unknown_unknown -emit-llvm -debug-info-kind=standalone -dwarf-column-info %s -o - | FileCheck %s
+void ext();
+
+struct Bar {
+ void bar() { ext(); }
+};
+
+struct Foo {
+ Bar *b;
+
+ Bar *foo() { return b; }
+};
+
+void test(Foo *f) {
+ f->foo()->bar();
+}
+
+// CHECK-LABEL: @_Z4testP3Foo
+// CHECK: call {{.*}} @_ZN3Foo3fooEv{{.*}}, !dbg ![[CALL1LOC:.*]]
+// CHECK: call void @_ZN3Bar3barEv{{.*}}, !dbg ![[CALL2LOC:.*]]
+
+// CHECK: ![[CALL1LOC]] = !DILocation(line: [[LINE:[0-9]+]], column: 6,
+// CHECK: ![[CALL2LOC]] = !DILocation(line: [[LINE]], column: 13,
+
Index: lib/CodeGen/CGExprCXX.cpp
===================================================================
--- lib/CodeGen/CGExprCXX.cpp
+++ lib/CodeGen/CGExprCXX.cpp
@@ -107,6 +107,10 @@
ReturnValueSlot ReturnValue) {
const Expr *callee = CE->getCallee()->IgnoreParens();
+ // The debug information for the call instruction should point to the callee
+ // expression.
+ ApplyDebugLocation DL(*this, callee);
+
if (isa<BinaryOperator>(callee))
return EmitCXXMemberPointerCallExpr(CE, ReturnValue);
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D19708.55524.patch
Type: text/x-patch
Size: 1359 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20160429/45fc6b63/attachment.bin>
More information about the cfe-commits
mailing list