Merge "Generate system stub library list at build time"
This commit is contained in:
@@ -40,6 +40,15 @@ type PackagingSpec struct {
|
|||||||
executable bool
|
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 {
|
type PackageModule interface {
|
||||||
Module
|
Module
|
||||||
packagingBase() *PackagingBase
|
packagingBase() *PackagingBase
|
||||||
|
@@ -72,6 +72,8 @@ bootstrap_go_package {
|
|||||||
"vendor_public_library.go",
|
"vendor_public_library.go",
|
||||||
|
|
||||||
"testing.go",
|
"testing.go",
|
||||||
|
|
||||||
|
"stub_library.go",
|
||||||
],
|
],
|
||||||
testSrcs: [
|
testSrcs: [
|
||||||
"cc_test.go",
|
"cc_test.go",
|
||||||
|
82
cc/stub_library.go
Normal file
82
cc/stub_library.go
Normal 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), " "))
|
||||||
|
}
|
@@ -102,6 +102,7 @@ func (l *linkerConfig) AndroidMkEntries() []android.AndroidMkEntries {
|
|||||||
entries.SetString("LOCAL_MODULE_PATH", l.installDirPath.ToMakePath().String())
|
entries.SetString("LOCAL_MODULE_PATH", l.installDirPath.ToMakePath().String())
|
||||||
entries.SetString("LOCAL_INSTALLED_MODULE_STEM", l.outputFilePath.Base())
|
entries.SetString("LOCAL_INSTALLED_MODULE_STEM", l.outputFilePath.Base())
|
||||||
entries.SetBoolIfTrue("LOCAL_UNINSTALLABLE_MODULE", !installable)
|
entries.SetBoolIfTrue("LOCAL_UNINSTALLABLE_MODULE", !installable)
|
||||||
|
entries.SetString("LINKER_CONFIG_PATH_"+l.Name(), l.OutputFile().String())
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}}
|
}}
|
||||||
|
@@ -18,8 +18,10 @@
|
|||||||
import argparse
|
import argparse
|
||||||
import collections
|
import collections
|
||||||
import json
|
import json
|
||||||
|
import os
|
||||||
|
|
||||||
import linker_config_pb2
|
import linker_config_pb2
|
||||||
|
from google.protobuf.descriptor import FieldDescriptor
|
||||||
from google.protobuf.json_format import ParseDict
|
from google.protobuf.json_format import ParseDict
|
||||||
from google.protobuf.text_format import MessageToString
|
from google.protobuf.text_format import MessageToString
|
||||||
|
|
||||||
@@ -43,6 +45,25 @@ def Print(args):
|
|||||||
print(MessageToString(pb))
|
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():
|
def GetArgParser():
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
subparsers = parser.add_subparsers()
|
subparsers = parser.add_subparsers()
|
||||||
@@ -73,6 +94,32 @@ def GetArgParser():
|
|||||||
help='Source linker configuration file in protobuf.')
|
help='Source linker configuration file in protobuf.')
|
||||||
print_proto.set_defaults(func=Print)
|
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
|
return parser
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user