r236335 - InstrProf: Fix a coverage crash where a macro begins in an unreachable block
Justin Bogner
mail at justinbogner.com
Fri May 1 12:23:34 PDT 2015
Author: bogner
Date: Fri May 1 14:23:34 2015
New Revision: 236335
URL: http://llvm.org/viewvc/llvm-project?rev=236335&view=rev
Log:
InstrProf: Fix a coverage crash where a macro begins in an unreachable block
Added:
cfe/trunk/test/CoverageMapping/unreachable-macro.c
Modified:
cfe/trunk/lib/CodeGen/CoverageMappingGen.cpp
Modified: cfe/trunk/lib/CodeGen/CoverageMappingGen.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CoverageMappingGen.cpp?rev=236335&r1=236334&r2=236335&view=diff
==============================================================================
--- cfe/trunk/lib/CodeGen/CoverageMappingGen.cpp (original)
+++ cfe/trunk/lib/CodeGen/CoverageMappingGen.cpp Fri May 1 14:23:34 2015
@@ -447,7 +447,10 @@ struct CounterCoverageMappingBuilder
/// This should be used after visiting any statements in non-source order.
void adjustForOutOfOrderTraversal(SourceLocation EndLoc) {
MostRecentLocation = EndLoc;
- if (MostRecentLocation == getEndOfFileOrMacro(MostRecentLocation))
+ // Avoid adding duplicate regions if we have a completed region on the top
+ // of the stack and are adjusting to the end of a virtual file.
+ if (getRegion().hasEndLoc() &&
+ MostRecentLocation == getEndOfFileOrMacro(MostRecentLocation))
MostRecentLocation = getIncludeOrExpansionLoc(MostRecentLocation);
}
Added: cfe/trunk/test/CoverageMapping/unreachable-macro.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CoverageMapping/unreachable-macro.c?rev=236335&view=auto
==============================================================================
--- cfe/trunk/test/CoverageMapping/unreachable-macro.c (added)
+++ cfe/trunk/test/CoverageMapping/unreachable-macro.c Fri May 1 14:23:34 2015
@@ -0,0 +1,15 @@
+// RUN: %clang_cc1 -fprofile-instr-generate -fcoverage-mapping -dump-coverage-mapping -emit-llvm-only %s | FileCheck %s
+
+#define WHILE while (0) {}
+
+// CHECK: counters_in_macro_following_unreachable
+void counters_in_macro_following_unreachable() {
+ // CHECK-NEXT: File 0, [[@LINE-1]]:48 -> {{[0-9]+}}:2 = #0
+ return;
+ // CHECK-NEXT: Expansion,File 0, [[@LINE+2]]:3 -> [[@LINE+2]]:8 = 0
+ // CHECK-NEXT: File 0, [[@LINE+1]]:8 -> [[@LINE+2]]:2 = 0
+ WHILE
+}
+// CHECK-NEXT: File 1, 3:15 -> 3:27 = 0
+// CHECK-NEXT: File 1, 3:22 -> 3:23 = #1
+// CHECK-NEXT: File 1, 3:25 -> 3:27 = #1
More information about the cfe-commits
mailing list