summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Blaikie <dblaikie@gmail.com>2014-12-09 21:32:00 +0000
committerDavid Blaikie <dblaikie@gmail.com>2014-12-09 21:32:00 +0000
commit93e9cf8aa43545d5ebe7ea10642eb19ec458554d (patch)
treef4367845f9e5530b652bc77ab9a7e1abaabcc21d
parentb31fba1613d98e6f3bb4fc2a906f52effa7b631a (diff)
downloadbcm5719-llvm-93e9cf8aa43545d5ebe7ea10642eb19ec458554d.tar.gz
bcm5719-llvm-93e9cf8aa43545d5ebe7ea10642eb19ec458554d.zip
DebugInfo: Correct location for compound complex assignment
llvm-svn: 223835
-rw-r--r--clang/lib/CodeGen/CGExprComplex.cpp3
-rw-r--r--clang/test/CodeGenCXX/debug-info-line.cpp15
2 files changed, 14 insertions, 4 deletions
diff --git a/clang/lib/CodeGen/CGExprComplex.cpp b/clang/lib/CodeGen/CGExprComplex.cpp
index 7b7da17a3fd..2732d40093e 100644
--- a/clang/lib/CodeGen/CGExprComplex.cpp
+++ b/clang/lib/CodeGen/CGExprComplex.cpp
@@ -869,8 +869,7 @@ EmitCompoundAssignLValue(const CompoundAssignOperator *E,
// Truncate the result and store it into the LHS lvalue.
if (LHSTy->isAnyComplexType()) {
ComplexPairTy ResVal = EmitComplexToComplexCast(Result, OpInfo.Ty, LHSTy);
- // FIXME
- EmitStoreOfComplex(ResVal, LHS, /*isInit*/ false, SourceLocation());
+ EmitStoreOfComplex(ResVal, LHS, /*isInit*/ false, E->getLocStart());
Val = RValue::getComplex(ResVal);
} else {
llvm::Value *ResVal =
diff --git a/clang/test/CodeGenCXX/debug-info-line.cpp b/clang/test/CodeGenCXX/debug-info-line.cpp
index c8e98cbc67f..f87a24c5b3d 100644
--- a/clang/test/CodeGenCXX/debug-info-line.cpp
+++ b/clang/test/CodeGenCXX/debug-info-line.cpp
@@ -33,15 +33,26 @@ foo::foo()
(complex_src()) {
}
+// skip C1
+// CHECK-LABEL: define
+
// CHECK-LABEL: define
void f2() {
#line 300
- * // CHECK: store float {{.*}} !dbg [[DBG_F2_COMPLEX:!.*]]
+ * // CHECK: store float {{.*}} !dbg [[DBG_F2:!.*]]
complex_sink() = complex_src();
}
+// CHECK-LABEL: define
+void f3() {
+#line 400
+ * // CHECK: store float {{.*}} !dbg [[DBG_F3:!.*]]
+ complex_sink() += complex_src();
+}
+
// CHECK: [[DBG_F1]] = metadata !{i32 100,
// CHECK: [[DBG_FOO_VALUE]] = metadata !{i32 200,
// CHECK: [[DBG_FOO_REF]] = metadata !{i32 202,
// CHECK: [[DBG_FOO_COMPLEX]] = metadata !{i32 204,
-// CHECK: [[DBG_F2_COMPLEX]] = metadata !{i32 300,
+// CHECK: [[DBG_F2]] = metadata !{i32 300,
+// CHECK: [[DBG_F3]] = metadata !{i32 400,
OpenPOWER on IntegriCloud