Merge "Generate system stub library list at build time"

This commit is contained in:
Kiyoung Kim
2020-12-02 00:28:19 +00:00
committed by Gerrit Code Review
5 changed files with 141 additions and 0 deletions

View File

@@ -40,6 +40,15 @@ type PackagingSpec struct {
executable bool
}
// Get file name of installed package
func (p *PackagingSpec) FileName() string {
if p.relPathInPackage != "" {
return filepath.Base(p.relPathInPackage)
}
return ""
}
type PackageModule interface {
Module
packagingBase() *PackagingBase

View File

@@ -72,6 +72,8 @@ bootstrap_go_package {
"vendor_public_library.go",
"testing.go",
"stub_library.go",
],
testSrcs: [
"cc_test.go",

82
cc/stub_library.go Normal file
View File

@@ -0,0 +1,82 @@
// Copyright 2020 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 (
"strings"
"android/soong/android"
)
func init() {
// Use singleton type to gather all generated soong modules.
android.RegisterSingletonType("stublibraries", stubLibrariesSingleton)
}
type stubLibraries struct {
stubLibraryMap map[string]bool
}
// Check if the module defines stub, or itself is stub
func isStubTarget(m *Module) bool {
if m.IsStubs() || m.HasStubsVariants() {
return true
}
// Library which defines LLNDK Stub is also Stub target.
// Pure LLNDK Stub target would not contain any packaging
// with target file path.
if library, ok := m.linker.(*libraryDecorator); ok {
if library.Properties.Llndk_stubs != nil {
return true
}
}
return false
}
// Get target file name to be installed from this module
func getInstalledFileName(m *Module) string {
for _, ps := range m.PackagingSpecs() {
if name := ps.FileName(); name != "" {
return name
}
}
return ""
}
func (s *stubLibraries) GenerateBuildActions(ctx android.SingletonContext) {
// Visit all generated soong modules and store stub library file names.
ctx.VisitAllModules(func(module android.Module) {
if m, ok := module.(*Module); ok {
if isStubTarget(m) {
if name := getInstalledFileName(m); name != "" {
s.stubLibraryMap[name] = true
}
}
}
})
}
func stubLibrariesSingleton() android.Singleton {
return &stubLibraries{
stubLibraryMap: make(map[string]bool),
}
}
func (s *stubLibraries) MakeVars(ctx android.MakeVarsContext) {
// Convert stub library file names into Makefile variable.
ctx.Strict("STUB_LIBRARIES", strings.Join(android.SortedStringKeys(s.stubLibraryMap), " "))
}

View File

@@ -102,6 +102,7 @@ func (l *linkerConfig) AndroidMkEntries() []android.AndroidMkEntries {
entries.SetString("LOCAL_MODULE_PATH", l.installDirPath.ToMakePath().String())
entries.SetString("LOCAL_INSTALLED_MODULE_STEM", l.outputFilePath.Base())
entries.SetBoolIfTrue("LOCAL_UNINSTALLABLE_MODULE", !installable)
entries.SetString("LINKER_CONFIG_PATH_"+l.Name(), l.OutputFile().String())
},
},
}}

View File

@@ -18,8 +18,10 @@
import argparse
import collections
import json
import os
import linker_config_pb2
from google.protobuf.descriptor import FieldDescriptor
from google.protobuf.json_format import ParseDict
from google.protobuf.text_format import MessageToString
@@ -43,6 +45,25 @@ def Print(args):
print(MessageToString(pb))
def SystemProvide(args):
pb = linker_config_pb2.LinkerConfig()
with open(args.source, 'rb') as f:
pb.ParseFromString(f.read())
libraries = args.value.split()
def IsInLibPath(lib_name):
lib_path = os.path.join(args.system, 'lib', lib_name)
lib64_path = os.path.join(args.system, 'lib64', lib_name)
return os.path.exists(lib_path) or os.path.islink(lib_path) or os.path.exists(lib64_path) or os.path.islink(lib64_path)
installed_libraries = list(filter(IsInLibPath, libraries))
for item in installed_libraries:
if item not in getattr(pb, 'provideLibs'):
getattr(pb, 'provideLibs').append(item)
with open(args.output, 'wb') as f:
f.write(pb.SerializeToString())
def GetArgParser():
parser = argparse.ArgumentParser()
subparsers = parser.add_subparsers()
@@ -73,6 +94,32 @@ def GetArgParser():
help='Source linker configuration file in protobuf.')
print_proto.set_defaults(func=Print)
system_provide_libs = subparsers.add_parser(
'systemprovide', help='Append system provide libraries into the configuration.')
system_provide_libs.add_argument(
'-s',
'--source',
required=True,
type=str,
help='Source linker configuration file in protobuf.')
system_provide_libs.add_argument(
'-o',
'--output',
required=True,
type=str,
help='Target linker configuration file to write in protobuf.')
system_provide_libs.add_argument(
'--value',
required=True,
type=str,
help='Values of the libraries to append. If there are more than one it should be separated by empty space')
system_provide_libs.add_argument(
'--system',
required=True,
type=str,
help='Path of the system image.')
system_provide_libs.set_defaults(func=SystemProvide)
return parser