// Copyright 2020 The Android Open Source Project // // 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 // This file contains utility types and functions for VNDK / vendor snapshot. import ( "android/soong/android" ) var ( HeaderExts = []string{".h", ".hh", ".hpp", ".hxx", ".h++", ".inl", ".inc", ".ipp", ".h.generic"} ) func (m *Module) IsSnapshotLibrary() bool { if _, ok := m.linker.(snapshotLibraryInterface); ok { return true } return false } func (m *Module) SnapshotHeaders() android.Paths { if m.IsSnapshotLibrary() { return m.linker.(snapshotLibraryInterface).snapshotHeaders() } return android.Paths{} } func (m *Module) Dylib() bool { return false } func (m *Module) Rlib() bool { return false } func (m *Module) SnapshotRuntimeLibs() []string { return m.Properties.SnapshotRuntimeLibs } func (m *Module) SnapshotSharedLibs() []string { return m.Properties.SnapshotSharedLibs } func (m *Module) SnapshotStaticLibs() []string { return m.Properties.SnapshotStaticLibs } func (m *Module) SnapshotRlibs() []string { return []string{} } func (m *Module) SnapshotDylibs() []string { return []string{} } // snapshotLibraryInterface is an interface for libraries captured to VNDK / vendor snapshots. type snapshotLibraryInterface interface { libraryInterface // collectHeadersForSnapshot is called in GenerateAndroidBuildActions for snapshot aware // modules (See isSnapshotAware below). // This function should gather all headers needed for snapshot. collectHeadersForSnapshot(ctx android.ModuleContext) // snapshotHeaders should return collected headers by collectHeadersForSnapshot. // Calling snapshotHeaders before collectHeadersForSnapshot is an error. snapshotHeaders() android.Paths } var _ snapshotLibraryInterface = (*prebuiltLibraryLinker)(nil) var _ snapshotLibraryInterface = (*libraryDecorator)(nil) // snapshotMap is a helper wrapper to a map from base module name to snapshot module name. type snapshotMap struct { snapshots map[string]string } func newSnapshotMap() *snapshotMap { return &snapshotMap{ snapshots: make(map[string]string), } } func snapshotMapKey(name string, arch android.ArchType) string { return name + ":" + arch.String() } // Adds a snapshot name for given module name and architecture. // e.g. add("libbase", X86, "libbase.vndk.29.x86") func (s *snapshotMap) add(name string, arch android.ArchType, snapshot string) { s.snapshots[snapshotMapKey(name, arch)] = snapshot } // Returns snapshot name for given module name and architecture, if found. // e.g. get("libcutils", X86) => "libcutils.vndk.29.x86", true func (s *snapshotMap) get(name string, arch android.ArchType) (snapshot string, found bool) { snapshot, found = s.snapshots[snapshotMapKey(name, arch)] return snapshot, found } // ShouldCollectHeadersForSnapshot determines if the module is a possible candidate for snapshot. // If it's true, collectHeadersForSnapshot will be called in GenerateAndroidBuildActions. func ShouldCollectHeadersForSnapshot(ctx android.ModuleContext, m LinkableInterface, apexInfo android.ApexInfo) bool { if ctx.DeviceConfig().VndkVersion() != "current" && ctx.DeviceConfig().RecoverySnapshotVersion() != "current" { return false } if _, ok := isVndkSnapshotAware(ctx.DeviceConfig(), m, apexInfo); ok { return ctx.Config().VndkSnapshotBuildArtifacts() } for _, image := range []SnapshotImage{VendorSnapshotImageSingleton, RecoverySnapshotImageSingleton} { if isSnapshotAware(ctx.DeviceConfig(), m, image.IsProprietaryPath(ctx.ModuleDir(), ctx.DeviceConfig()), apexInfo, image) { return true } } return false }