Add recovery image sdk trait to cc_library_headers
Allows an sdk to require that a cc_library_headers module provides a recovery image variant for the prebuilt. Previously, "recovery_available: true" would be set in the generated prebuilt snapshot for any sdk member that specified "recovery_available: true" in the source module. This change will only add that setting to the snapshot if the recovery image variant trait was explicitly requested for a member. Bug: 195754365 Test: m nothing Change-Id: I7d79ccdec843127f7852d82b4b163021e30a79a7
This commit is contained in:
@@ -60,6 +60,7 @@ bootstrap_go_package {
|
|||||||
"binary.go",
|
"binary.go",
|
||||||
"binary_sdk_member.go",
|
"binary_sdk_member.go",
|
||||||
"fuzz.go",
|
"fuzz.go",
|
||||||
|
"image_sdk_traits.go",
|
||||||
"library.go",
|
"library.go",
|
||||||
"library_headers.go",
|
"library_headers.go",
|
||||||
"library_sdk_member.go",
|
"library_sdk_member.go",
|
||||||
|
33
cc/image_sdk_traits.go
Normal file
33
cc/image_sdk_traits.go
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
// Copyright 2021 Google Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package cc
|
||||||
|
|
||||||
|
import "android/soong/android"
|
||||||
|
|
||||||
|
// This file contains support for the image variant sdk traits.
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
android.RegisterSdkMemberTrait(recoveryImageRequiredSdkTrait)
|
||||||
|
}
|
||||||
|
|
||||||
|
type imageSdkTraitStruct struct {
|
||||||
|
android.SdkMemberTraitBase
|
||||||
|
}
|
||||||
|
|
||||||
|
var recoveryImageRequiredSdkTrait android.SdkMemberTrait = &imageSdkTraitStruct{
|
||||||
|
SdkMemberTraitBase: android.SdkMemberTraitBase{
|
||||||
|
PropertyName: "recovery_image_required",
|
||||||
|
},
|
||||||
|
}
|
@@ -35,6 +35,7 @@ var headersLibrarySdkMemberType = &librarySdkMemberType{
|
|||||||
HostOsDependent: true,
|
HostOsDependent: true,
|
||||||
Traits: []android.SdkMemberTrait{
|
Traits: []android.SdkMemberTrait{
|
||||||
nativeBridgeSdkTrait,
|
nativeBridgeSdkTrait,
|
||||||
|
recoveryImageRequiredSdkTrait,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
prebuiltModuleType: "cc_prebuilt_library_headers",
|
prebuiltModuleType: "cc_prebuilt_library_headers",
|
||||||
|
@@ -133,6 +133,16 @@ func (mt *librarySdkMemberType) AddDependencies(ctx android.SdkDependencyContext
|
|||||||
imageVariations: []blueprint.Variation{{Mutator: "image", Variation: android.CoreVariation}},
|
imageVariations: []blueprint.Variation{{Mutator: "image", Variation: android.CoreVariation}},
|
||||||
targets: targets,
|
targets: targets,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// If required add additional dependencies on the image:recovery variants.
|
||||||
|
if ctx.RequiresTrait(lib, recoveryImageRequiredSdkTrait) {
|
||||||
|
memberDependencies = append(memberDependencies, memberDependency{
|
||||||
|
imageVariations: []blueprint.Variation{{Mutator: "image", Variation: android.RecoveryVariation}},
|
||||||
|
// Only add a dependency on the first target as that is the only one which will have an
|
||||||
|
// image:recovery variant.
|
||||||
|
targets: targets[:1],
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// For each dependency in the list add dependencies on the targets with the correct variations.
|
// For each dependency in the list add dependencies on the targets with the correct variations.
|
||||||
@@ -189,7 +199,7 @@ func (mt *librarySdkMemberType) AddPrebuiltModule(ctx android.SdkMemberContext,
|
|||||||
pbm.AddProperty("native_bridge_supported", true)
|
pbm.AddProperty("native_bridge_supported", true)
|
||||||
}
|
}
|
||||||
|
|
||||||
if proptools.Bool(ccModule.Properties.Recovery_available) {
|
if ctx.RequiresTrait(recoveryImageRequiredSdkTrait) {
|
||||||
pbm.AddProperty("recovery_available", true)
|
pbm.AddProperty("recovery_available", true)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -15,6 +15,7 @@
|
|||||||
package sdk
|
package sdk
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"android/soong/android"
|
"android/soong/android"
|
||||||
@@ -1771,7 +1772,6 @@ cc_prebuilt_library {
|
|||||||
prefer: false,
|
prefer: false,
|
||||||
visibility: ["//visibility:public"],
|
visibility: ["//visibility:public"],
|
||||||
apex_available: ["//apex_available:platform"],
|
apex_available: ["//apex_available:platform"],
|
||||||
recovery_available: true,
|
|
||||||
vendor_available: true,
|
vendor_available: true,
|
||||||
stl: "none",
|
stl: "none",
|
||||||
compile_multilib: "both",
|
compile_multilib: "both",
|
||||||
@@ -1806,7 +1806,6 @@ cc_prebuilt_library {
|
|||||||
visibility: ["//visibility:public"],
|
visibility: ["//visibility:public"],
|
||||||
apex_available: ["//apex_available:platform"],
|
apex_available: ["//apex_available:platform"],
|
||||||
installable: false,
|
installable: false,
|
||||||
recovery_available: true,
|
|
||||||
vendor_available: true,
|
vendor_available: true,
|
||||||
stl: "none",
|
stl: "none",
|
||||||
compile_multilib: "both",
|
compile_multilib: "both",
|
||||||
@@ -2081,6 +2080,57 @@ func TestSnapshotWithCcHeadersLibrary_DetectsNativeBridgeSpecificProperties(t *t
|
|||||||
`)
|
`)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSnapshotWithCcHeadersLibraryAndImageVariants(t *testing.T) {
|
||||||
|
testImageVariant := func(t *testing.T, property, trait string) {
|
||||||
|
result := android.GroupFixturePreparers(
|
||||||
|
cc.PrepareForTestWithCcDefaultModules,
|
||||||
|
PrepareForTestWithSdkBuildComponents,
|
||||||
|
ccTestFs.AddToFixture(),
|
||||||
|
).RunTestWithBp(t, fmt.Sprintf(`
|
||||||
|
sdk {
|
||||||
|
name: "mysdk",
|
||||||
|
native_header_libs: ["mynativeheaders"],
|
||||||
|
traits: {
|
||||||
|
%s: ["mynativeheaders"],
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
cc_library_headers {
|
||||||
|
name: "mynativeheaders",
|
||||||
|
export_include_dirs: ["myinclude"],
|
||||||
|
stl: "none",
|
||||||
|
system_shared_libs: [],
|
||||||
|
%s: true,
|
||||||
|
}
|
||||||
|
`, trait, property))
|
||||||
|
|
||||||
|
CheckSnapshot(t, result, "mysdk", "",
|
||||||
|
checkUnversionedAndroidBpContents(fmt.Sprintf(`
|
||||||
|
// This is auto-generated. DO NOT EDIT.
|
||||||
|
|
||||||
|
cc_prebuilt_library_headers {
|
||||||
|
name: "mynativeheaders",
|
||||||
|
prefer: false,
|
||||||
|
visibility: ["//visibility:public"],
|
||||||
|
apex_available: ["//apex_available:platform"],
|
||||||
|
%s: true,
|
||||||
|
stl: "none",
|
||||||
|
compile_multilib: "both",
|
||||||
|
system_shared_libs: [],
|
||||||
|
export_include_dirs: ["include/myinclude"],
|
||||||
|
}
|
||||||
|
`, property)),
|
||||||
|
checkAllCopyRules(`
|
||||||
|
myinclude/Test.h -> include/myinclude/Test.h
|
||||||
|
`),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
t.Run("recovery", func(t *testing.T) {
|
||||||
|
testImageVariant(t, "recovery_available", "recovery_image_required")
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func TestHostSnapshotWithCcHeadersLibrary(t *testing.T) {
|
func TestHostSnapshotWithCcHeadersLibrary(t *testing.T) {
|
||||||
result := testSdkWithCc(t, `
|
result := testSdkWithCc(t, `
|
||||||
sdk {
|
sdk {
|
||||||
|
Reference in New Issue
Block a user