[sanitizer-coverage] make sure coverage flags are not passed to clang if the driver...
authorKostya Serebryany <kcc@google.com>
Mon, 18 Apr 2016 21:30:17 +0000 (21:30 +0000)
committerKostya Serebryany <kcc@google.com>
Mon, 18 Apr 2016 21:30:17 +0000 (21:30 +0000)
llvm-svn: 266673

clang/lib/Driver/SanitizerArgs.cpp
clang/test/Driver/fsanitize-coverage.c

index 1703710..ff9a0b4 100644 (file)
@@ -482,6 +482,8 @@ SanitizerArgs::SanitizerArgs(const ToolChain &TC,
       if ((CoverageFeatures & CoverageTracePC) ||
           (AllAddedKinds & SupportsCoverage)) {
         Arg->claim();
+      } else {
+        CoverageFeatures = 0;
       }
     } else if (Arg->getOption().matches(options::OPT_fno_sanitize_coverage)) {
       Arg->claim();
index 19b4af4..a13b530 100644 (file)
@@ -35,6 +35,7 @@
 // RUN: %clang -target x86_64-linux-gnu -fsanitize=thread   -fsanitize-coverage=func %s -### 2>&1 | FileCheck %s --check-prefix=CHECK-SANITIZE-COVERAGE-UNUSED
 // RUN: %clang -target x86_64-linux-gnu                     -fsanitize-coverage=func %s -### 2>&1 | FileCheck %s --check-prefix=CHECK-SANITIZE-COVERAGE-UNUSED
 // CHECK-SANITIZE-COVERAGE-UNUSED: argument unused during compilation: '-fsanitize-coverage=func'
+// CHECK-SANITIZE-COVERAGE-UNUSED-NOT: -fsanitize-coverage-type=1
 
 // RUN: %clang -target x86_64-linux-gnu -fsanitize=address -fsanitize-coverage=func -fno-sanitize=address %s -### 2>&1 | FileCheck %s --check-prefix=CHECK-SANITIZE-COVERAGE-SAN-DISABLED
 // CHECK-SANITIZE-COVERAGE-SAN-DISABLED-NOT: argument unused