Include libprofile-extras to all coverage variants
Bug: http://b/128524141 Include libprofile-extras (defined in system/extras/toolchain-extras) to all modules that need a coverage variant. Also add '-uinit_profile_extras' when linking with coverage. This causes the setup code in libprofile-extras to be linked into binaries/libraries with coverage enabled. We add the static library to the non-coverage variants as well but is a no-op for them (since the '-u...' flag is not added for them). Adding this dependency creates several circular dependencies since coverage variants were being created for other module types that never had any compilation or linking done during the build. This change stops creating coverage variants for toolchain_library, cc_prebuilt_library_*, cc_library_headers module types (by adding a function to the linker interface to specify whether native coverage is enabled). Test: m NATIVE_COVERAGE=true COVERAGE_PATHS=* Test: blueline_coverage target in internal branch (using forrest) Change-Id: I5db876eb953639a55ba007248dd24e497f987730
This commit is contained in:
@@ -42,6 +42,23 @@ func (cov *coverage) props() []interface{} {
|
||||
}
|
||||
|
||||
func (cov *coverage) deps(ctx BaseModuleContext, deps Deps) Deps {
|
||||
if cov.Properties.NeedCoverageBuild {
|
||||
// Link libprofile-extras/libprofile-extras_ndk when coverage
|
||||
// variant is required. This is a no-op unless coverage is
|
||||
// actually enabled during linking, when
|
||||
// '-uinit_profile_extras' is added (in flags()) to force the
|
||||
// setup code in libprofile-extras be linked into the
|
||||
// binary/library.
|
||||
//
|
||||
// We cannot narrow it further to only the 'cov' variant since
|
||||
// the mutator hasn't run (and we don't have the 'cov' variant
|
||||
// yet).
|
||||
if !ctx.useSdk() {
|
||||
deps.LateStaticLibs = append(deps.LateStaticLibs, "libprofile-extras")
|
||||
} else {
|
||||
deps.LateStaticLibs = append(deps.LateStaticLibs, "libprofile-extras_ndk")
|
||||
}
|
||||
}
|
||||
return deps
|
||||
}
|
||||
|
||||
@@ -96,6 +113,9 @@ func (cov *coverage) flags(ctx ModuleContext, flags Flags) Flags {
|
||||
|
||||
if cov.linkCoverage {
|
||||
flags.LdFlags = append(flags.LdFlags, "--coverage")
|
||||
|
||||
// Force linking of constructor/setup code in libprofile-extras
|
||||
flags.LdFlags = append(flags.LdFlags, "-uinit_profile_extras")
|
||||
}
|
||||
|
||||
return flags
|
||||
@@ -113,10 +133,8 @@ func (cov *coverage) begin(ctx BaseModuleContext) {
|
||||
if ctx.Host() {
|
||||
// TODO(dwillemsen): because of -nodefaultlibs, we must depend on libclang_rt.profile-*.a
|
||||
// Just turn off for now.
|
||||
} else if ctx.isStubs() {
|
||||
// Do not enable coverage for platform stub libraries
|
||||
} else if ctx.isNDKStubLibrary() {
|
||||
// Do not enable coverage for NDK stub libraries
|
||||
} else if !ctx.nativeCoverage() {
|
||||
// Native coverage is not supported for this module type.
|
||||
} else {
|
||||
// Check if Native_coverage is set to false. This property defaults to true.
|
||||
needCoverageVariant = BoolDefault(cov.Properties.Native_coverage, true)
|
||||
|
Reference in New Issue
Block a user