aboutsummaryrefslogtreecommitdiffstats
path: root/Android.bp
diff options
context:
space:
mode:
authorDan Willemsen <dwillemsen@google.com>2017-02-09 16:16:31 -0800
committerDan Willemsen <dwillemsen@google.com>2017-02-14 13:05:48 -0800
commit581341d4f2752a1f2823173167d30ddb30db5932 (patch)
treec8a4413cdc0a81ca2d934442d71b55a6e5abfec9 /Android.bp
parente13374d3c1e33176ac229317505c5e2b4d8d5240 (diff)
downloadbuild_soong-581341d4f2752a1f2823173167d30ddb30db5932.tar.gz
build_soong-581341d4f2752a1f2823173167d30ddb30db5932.tar.bz2
build_soong-581341d4f2752a1f2823173167d30ddb30db5932.zip
Native Coverage support in Soong (gcov)
This is configured the same as make -- a global NATIVE_COVERAGE=true flag to allow native coverage, then COVERAGE_PATHS=path1,path2,... to turn it on for certain paths. There are .gcnodir files exported to Make and saved in $OUT/coverage/... files which are `ar` archives containing all of the compiler-produced .gcno files for a particular executable / shared library. Unlike the Make implementation, this only passes links the helper library (automatically through --coverage) when one of the object files or static libraries being used actually has coverage enabled. Host support is currently disabled, since we set -nodefaultlibs, which prevents libclang_rt.profile-*.a from being picked up automatically. Bug: 32749731 Test: NATIVE_COVERAGE=true COVERAGE_PATHS=system/core/libcutils m -j libbacktrace libutils tombstoned $OUT/coverage/system/lib*/libcutils.gcnodir looks correct (self) $OUT/coverage/system/lib*/libbacktrace.gcnodir looks correct (static) $OUT/coverage/system/lib*/libutils.gcnodir doesn't exist (shared) $OUT/coverage/system/bin/tombstoned.gcnodir looks correct (executable) Test: NATIVE_COVERAGE=true COVERAGE_PATHS=external/libcxxabi m -j libc++ Confirm that $OUT/coverage/system/lib*/libc++.gcnodir looks correct (whole_static_libs) Change-Id: I48aaa0ba8d76e50e9c2d1151421c0c6dc8ed79a9
Diffstat (limited to 'Android.bp')
-rw-r--r--Android.bp1
1 files changed, 1 insertions, 0 deletions
diff --git a/Android.bp b/Android.bp
index 90566a4b..74da7c18 100644
--- a/Android.bp
+++ b/Android.bp
@@ -118,6 +118,7 @@ bootstrap_go_package {
"cc/builder.go",
"cc/cc.go",
"cc/check.go",
+ "cc/coverage.go",
"cc/gen.go",
"cc/makevars.go",
"cc/prebuilt.go",