Add support for Rust C libraries.
Adds the ability for rust modules to be compiled as C libraries, and allows cc modules to depend on these rust-generated modules. This also means that soong-rust should not have any dependencies on soong-cc aside from what's required for testing. There's a couple small fixes included as well: - A bug in libNameFromFilePath that caused issues when library's had "lib" in their name. - VariantName is removed from rust library MutatedProperties since this was unused. Bug: 140726209 Test: Soong tests pass. Test: Example cc_binary can include a rust shared library as a dep. Test: m crosvm.experimental Change-Id: Ia7deed1345d2423001089014cc65ce7934123da4
This commit is contained in:
@@ -36,10 +36,10 @@ type AndroidMkContext interface {
|
|||||||
Arch() android.Arch
|
Arch() android.Arch
|
||||||
Os() android.OsType
|
Os() android.OsType
|
||||||
Host() bool
|
Host() bool
|
||||||
useVndk() bool
|
UseVndk() bool
|
||||||
vndkVersion() string
|
vndkVersion() string
|
||||||
static() bool
|
static() bool
|
||||||
inRecovery() bool
|
InRecovery() bool
|
||||||
}
|
}
|
||||||
|
|
||||||
type subAndroidMkProvider interface {
|
type subAndroidMkProvider interface {
|
||||||
@@ -89,9 +89,9 @@ func (c *Module) AndroidMk() android.AndroidMkData {
|
|||||||
fmt.Fprintln(w, "LOCAL_WHOLE_STATIC_LIBRARIES := "+strings.Join(c.Properties.AndroidMkWholeStaticLibs, " "))
|
fmt.Fprintln(w, "LOCAL_WHOLE_STATIC_LIBRARIES := "+strings.Join(c.Properties.AndroidMkWholeStaticLibs, " "))
|
||||||
}
|
}
|
||||||
fmt.Fprintln(w, "LOCAL_SOONG_LINK_TYPE :=", c.makeLinkType)
|
fmt.Fprintln(w, "LOCAL_SOONG_LINK_TYPE :=", c.makeLinkType)
|
||||||
if c.useVndk() {
|
if c.UseVndk() {
|
||||||
fmt.Fprintln(w, "LOCAL_USE_VNDK := true")
|
fmt.Fprintln(w, "LOCAL_USE_VNDK := true")
|
||||||
if c.isVndk() && !c.static() {
|
if c.IsVndk() && !c.static() {
|
||||||
fmt.Fprintln(w, "LOCAL_SOONG_VNDK_VERSION := "+c.vndkVersion())
|
fmt.Fprintln(w, "LOCAL_SOONG_VNDK_VERSION := "+c.vndkVersion())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -224,7 +224,7 @@ func (library *libraryDecorator) AndroidMk(ctx AndroidMkContext, ret *android.An
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
if len(library.Properties.Stubs.Versions) > 0 &&
|
if len(library.Properties.Stubs.Versions) > 0 &&
|
||||||
android.DirectlyInAnyApex(ctx, ctx.Name()) && !ctx.inRecovery() && !ctx.useVndk() &&
|
android.DirectlyInAnyApex(ctx, ctx.Name()) && !ctx.InRecovery() && !ctx.UseVndk() &&
|
||||||
!ctx.static() {
|
!ctx.static() {
|
||||||
if !library.buildStubs() {
|
if !library.buildStubs() {
|
||||||
ret.SubName = ".bootstrap"
|
ret.SubName = ".bootstrap"
|
||||||
|
328
cc/cc.go
328
cc/cc.go
@@ -429,14 +429,79 @@ type Module struct {
|
|||||||
depsInLinkOrder android.Paths
|
depsInLinkOrder android.Paths
|
||||||
|
|
||||||
// only non-nil when this is a shared library that reuses the objects of a static library
|
// only non-nil when this is a shared library that reuses the objects of a static library
|
||||||
staticVariant *Module
|
staticVariant LinkableInterface
|
||||||
|
|
||||||
makeLinkType string
|
makeLinkType string
|
||||||
// Kythe (source file indexer) paths for this compilation module
|
// Kythe (source file indexer) paths for this compilation module
|
||||||
kytheFiles android.Paths
|
kytheFiles android.Paths
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) IncludeDirs() android.Paths {
|
func (c *Module) Toc() android.OptionalPath {
|
||||||
|
if c.linker != nil {
|
||||||
|
if library, ok := c.linker.(libraryInterface); ok {
|
||||||
|
return library.toc()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("Toc() called on non-library module: %q", c.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) ApiLevel() string {
|
||||||
|
if c.linker != nil {
|
||||||
|
if stub, ok := c.linker.(*stubDecorator); ok {
|
||||||
|
return stub.properties.ApiLevel
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("ApiLevel() called on non-stub library module: %q", c.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) Static() bool {
|
||||||
|
if c.linker != nil {
|
||||||
|
if library, ok := c.linker.(libraryInterface); ok {
|
||||||
|
return library.static()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("Static() called on non-library module: %q", c.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) Shared() bool {
|
||||||
|
if c.linker != nil {
|
||||||
|
if library, ok := c.linker.(libraryInterface); ok {
|
||||||
|
return library.shared()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("Shared() called on non-library module: %q", c.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) SelectedStl() string {
|
||||||
|
return c.stl.Properties.SelectedStl
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) ToolchainLibrary() bool {
|
||||||
|
if _, ok := c.linker.(*toolchainLibraryDecorator); ok {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) NdkPrebuiltStl() bool {
|
||||||
|
if _, ok := c.linker.(*ndkPrebuiltStlLinker); ok {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) StubDecorator() bool {
|
||||||
|
if _, ok := c.linker.(*stubDecorator); ok {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) SdkVersion() string {
|
||||||
|
return String(c.Properties.Sdk_version)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Module) IncludeDirs(ctx android.BaseModuleContext) android.Paths {
|
||||||
if c.linker != nil {
|
if c.linker != nil {
|
||||||
if library, ok := c.linker.(exportedFlagsProducer); ok {
|
if library, ok := c.linker.(exportedFlagsProducer); ok {
|
||||||
return library.exportedDirs()
|
return library.exportedDirs()
|
||||||
@@ -483,7 +548,7 @@ func (c *Module) CcLibrary() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) CcLibraryInterface() bool {
|
func (c *Module) CcLibraryInterface() bool {
|
||||||
if _, ok := c.compiler.(libraryInterface); ok {
|
if _, ok := c.linker.(libraryInterface); ok {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
@@ -493,12 +558,25 @@ func (c *Module) SetBuildStubs() {
|
|||||||
if c.linker != nil {
|
if c.linker != nil {
|
||||||
if library, ok := c.linker.(*libraryDecorator); ok {
|
if library, ok := c.linker.(*libraryDecorator); ok {
|
||||||
library.MutatedProperties.BuildStubs = true
|
library.MutatedProperties.BuildStubs = true
|
||||||
|
c.Properties.HideFromMake = true
|
||||||
|
c.sanitize = nil
|
||||||
|
c.stl = nil
|
||||||
|
c.Properties.PreventInstall = true
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
panic(fmt.Errorf("SetBuildStubs called on non-library module: %q", c.BaseModuleName()))
|
panic(fmt.Errorf("SetBuildStubs called on non-library module: %q", c.BaseModuleName()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Module) BuildStubs() bool {
|
||||||
|
if c.linker != nil {
|
||||||
|
if library, ok := c.linker.(*libraryDecorator); ok {
|
||||||
|
return library.buildStubs()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("BuildStubs called on non-library module: %q", c.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
func (c *Module) SetStubsVersions(version string) {
|
func (c *Module) SetStubsVersions(version string) {
|
||||||
if c.linker != nil {
|
if c.linker != nil {
|
||||||
if library, ok := c.linker.(*libraryDecorator); ok {
|
if library, ok := c.linker.(*libraryDecorator); ok {
|
||||||
@@ -511,7 +589,7 @@ func (c *Module) SetStubsVersions(version string) {
|
|||||||
|
|
||||||
func (c *Module) SetStatic() {
|
func (c *Module) SetStatic() {
|
||||||
if c.linker != nil {
|
if c.linker != nil {
|
||||||
if library, ok := c.linker.(*libraryDecorator); ok {
|
if library, ok := c.linker.(libraryInterface); ok {
|
||||||
library.setStatic()
|
library.setStatic()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -521,7 +599,7 @@ func (c *Module) SetStatic() {
|
|||||||
|
|
||||||
func (c *Module) SetShared() {
|
func (c *Module) SetShared() {
|
||||||
if c.linker != nil {
|
if c.linker != nil {
|
||||||
if library, ok := c.linker.(*libraryDecorator); ok {
|
if library, ok := c.linker.(libraryInterface); ok {
|
||||||
library.setShared()
|
library.setShared()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -531,7 +609,7 @@ func (c *Module) SetShared() {
|
|||||||
|
|
||||||
func (c *Module) BuildStaticVariant() bool {
|
func (c *Module) BuildStaticVariant() bool {
|
||||||
if c.linker != nil {
|
if c.linker != nil {
|
||||||
if library, ok := c.linker.(*libraryDecorator); ok {
|
if library, ok := c.linker.(libraryInterface); ok {
|
||||||
return library.buildStatic()
|
return library.buildStatic()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -540,7 +618,7 @@ func (c *Module) BuildStaticVariant() bool {
|
|||||||
|
|
||||||
func (c *Module) BuildSharedVariant() bool {
|
func (c *Module) BuildSharedVariant() bool {
|
||||||
if c.linker != nil {
|
if c.linker != nil {
|
||||||
if library, ok := c.linker.(*libraryDecorator); ok {
|
if library, ok := c.linker.(libraryInterface); ok {
|
||||||
return library.buildShared()
|
return library.buildShared()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -551,10 +629,6 @@ func (c *Module) Module() android.Module {
|
|||||||
return c
|
return c
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) InRecovery() bool {
|
|
||||||
return c.inRecovery()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *Module) OutputFile() android.OptionalPath {
|
func (c *Module) OutputFile() android.OptionalPath {
|
||||||
return c.outputFile
|
return c.outputFile
|
||||||
}
|
}
|
||||||
@@ -657,7 +731,7 @@ func (c *Module) isDependencyRoot() bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) useVndk() bool {
|
func (c *Module) UseVndk() bool {
|
||||||
return c.Properties.VndkVersion != ""
|
return c.Properties.VndkVersion != ""
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -684,7 +758,7 @@ func (c *Module) isVndkPrivate(config android.Config) bool {
|
|||||||
return inList(c.BaseModuleName(), *vndkPrivateLibraries(config))
|
return inList(c.BaseModuleName(), *vndkPrivateLibraries(config))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) isVndk() bool {
|
func (c *Module) IsVndk() bool {
|
||||||
if vndkdep := c.vndkdep; vndkdep != nil {
|
if vndkdep := c.vndkdep; vndkdep != nil {
|
||||||
return vndkdep.isVndk()
|
return vndkdep.isVndk()
|
||||||
}
|
}
|
||||||
@@ -723,7 +797,7 @@ func (c *Module) isVndkExt() bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) mustUseVendorVariant() bool {
|
func (c *Module) MustUseVendorVariant() bool {
|
||||||
return c.isVndkSp() || c.Properties.MustUseVendorVariant
|
return c.isVndkSp() || c.Properties.MustUseVendorVariant
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -736,15 +810,15 @@ func (c *Module) getVndkExtendsModuleName() string {
|
|||||||
|
|
||||||
// Returns true only when this module is configured to have core and vendor
|
// Returns true only when this module is configured to have core and vendor
|
||||||
// variants.
|
// variants.
|
||||||
func (c *Module) hasVendorVariant() bool {
|
func (c *Module) HasVendorVariant() bool {
|
||||||
return c.isVndk() || Bool(c.VendorProperties.Vendor_available)
|
return c.IsVndk() || Bool(c.VendorProperties.Vendor_available)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) inRecovery() bool {
|
func (c *Module) InRecovery() bool {
|
||||||
return c.Properties.InRecovery || c.ModuleBase.InstallInRecovery()
|
return c.Properties.InRecovery || c.ModuleBase.InstallInRecovery()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) onlyInRecovery() bool {
|
func (c *Module) OnlyInRecovery() bool {
|
||||||
return c.ModuleBase.InstallInRecovery()
|
return c.ModuleBase.InstallInRecovery()
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -815,7 +889,7 @@ type moduleContext struct {
|
|||||||
|
|
||||||
func (ctx *moduleContext) SocSpecific() bool {
|
func (ctx *moduleContext) SocSpecific() bool {
|
||||||
return ctx.ModuleContext.SocSpecific() ||
|
return ctx.ModuleContext.SocSpecific() ||
|
||||||
(ctx.mod.hasVendorVariant() && ctx.mod.useVndk() && !ctx.mod.isVndk())
|
(ctx.mod.HasVendorVariant() && ctx.mod.UseVndk() && !ctx.mod.IsVndk())
|
||||||
}
|
}
|
||||||
|
|
||||||
type moduleContextImpl struct {
|
type moduleContextImpl struct {
|
||||||
@@ -865,7 +939,7 @@ func (ctx *moduleContextImpl) sdkVersion() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *moduleContextImpl) useVndk() bool {
|
func (ctx *moduleContextImpl) useVndk() bool {
|
||||||
return ctx.mod.useVndk()
|
return ctx.mod.UseVndk()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *moduleContextImpl) isNdk() bool {
|
func (ctx *moduleContextImpl) isNdk() bool {
|
||||||
@@ -885,7 +959,7 @@ func (ctx *moduleContextImpl) isVndkPrivate(config android.Config) bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *moduleContextImpl) isVndk() bool {
|
func (ctx *moduleContextImpl) isVndk() bool {
|
||||||
return ctx.mod.isVndk()
|
return ctx.mod.IsVndk()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *moduleContextImpl) isPgoCompile() bool {
|
func (ctx *moduleContextImpl) isPgoCompile() bool {
|
||||||
@@ -905,11 +979,11 @@ func (ctx *moduleContextImpl) isVndkExt() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *moduleContextImpl) mustUseVendorVariant() bool {
|
func (ctx *moduleContextImpl) mustUseVendorVariant() bool {
|
||||||
return ctx.mod.mustUseVendorVariant()
|
return ctx.mod.MustUseVendorVariant()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ctx *moduleContextImpl) inRecovery() bool {
|
func (ctx *moduleContextImpl) inRecovery() bool {
|
||||||
return ctx.mod.inRecovery()
|
return ctx.mod.InRecovery()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check whether ABI dumps should be created for this module.
|
// Check whether ABI dumps should be created for this module.
|
||||||
@@ -1114,7 +1188,7 @@ func (c *Module) GenerateAndroidBuildActions(actx android.ModuleContext) {
|
|||||||
// .vendor suffix is added for backward compatibility with VNDK snapshot whose names with
|
// .vendor suffix is added for backward compatibility with VNDK snapshot whose names with
|
||||||
// such suffixes are already hard-coded in prebuilts/vndk/.../Android.bp.
|
// such suffixes are already hard-coded in prebuilts/vndk/.../Android.bp.
|
||||||
c.Properties.SubName += vendorSuffix
|
c.Properties.SubName += vendorSuffix
|
||||||
} else if _, ok := c.linker.(*llndkStubDecorator); ok || (c.useVndk() && c.hasVendorVariant()) {
|
} else if _, ok := c.linker.(*llndkStubDecorator); ok || (c.UseVndk() && c.HasVendorVariant()) {
|
||||||
// .vendor.{version} suffix is added only when we will have two variants: core and vendor.
|
// .vendor.{version} suffix is added only when we will have two variants: core and vendor.
|
||||||
// The suffix is not added for vendor-only module.
|
// The suffix is not added for vendor-only module.
|
||||||
c.Properties.SubName += vendorSuffix
|
c.Properties.SubName += vendorSuffix
|
||||||
@@ -1125,7 +1199,7 @@ func (c *Module) GenerateAndroidBuildActions(actx android.ModuleContext) {
|
|||||||
if c.Properties.VndkVersion != vendorVersion {
|
if c.Properties.VndkVersion != vendorVersion {
|
||||||
c.Properties.SubName += "." + c.Properties.VndkVersion
|
c.Properties.SubName += "." + c.Properties.VndkVersion
|
||||||
}
|
}
|
||||||
} else if c.inRecovery() && !c.onlyInRecovery() {
|
} else if c.InRecovery() && !c.OnlyInRecovery() {
|
||||||
c.Properties.SubName += recoverySuffix
|
c.Properties.SubName += recoverySuffix
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1235,7 +1309,7 @@ func (c *Module) GenerateAndroidBuildActions(actx android.ModuleContext) {
|
|||||||
// module is marked with 'bootstrap: true').
|
// module is marked with 'bootstrap: true').
|
||||||
if c.HasStubsVariants() &&
|
if c.HasStubsVariants() &&
|
||||||
android.DirectlyInAnyApex(ctx, ctx.baseModuleName()) &&
|
android.DirectlyInAnyApex(ctx, ctx.baseModuleName()) &&
|
||||||
!c.inRecovery() && !c.useVndk() && !c.static() && !c.isCoverageVariant() &&
|
!c.InRecovery() && !c.UseVndk() && !c.static() && !c.isCoverageVariant() &&
|
||||||
c.IsStubs() {
|
c.IsStubs() {
|
||||||
c.Properties.HideFromMake = false // unhide
|
c.Properties.HideFromMake = false // unhide
|
||||||
// Note: this is still non-installable
|
// Note: this is still non-installable
|
||||||
@@ -1524,7 +1598,7 @@ func (c *Module) DepsMutator(actx android.BottomUpMutatorContext) {
|
|||||||
addSharedLibDependencies := func(depTag DependencyTag, name string, version string) {
|
addSharedLibDependencies := func(depTag DependencyTag, name string, version string) {
|
||||||
var variations []blueprint.Variation
|
var variations []blueprint.Variation
|
||||||
variations = append(variations, blueprint.Variation{Mutator: "link", Variation: "shared"})
|
variations = append(variations, blueprint.Variation{Mutator: "link", Variation: "shared"})
|
||||||
versionVariantAvail := !ctx.useVndk() && !c.inRecovery()
|
versionVariantAvail := !ctx.useVndk() && !c.InRecovery()
|
||||||
if version != "" && versionVariantAvail {
|
if version != "" && versionVariantAvail {
|
||||||
// Version is explicitly specified. i.e. libFoo#30
|
// Version is explicitly specified. i.e. libFoo#30
|
||||||
variations = append(variations, blueprint.Variation{Mutator: "version", Variation: version})
|
variations = append(variations, blueprint.Variation{Mutator: "version", Variation: version})
|
||||||
@@ -1637,52 +1711,58 @@ func BeginMutator(ctx android.BottomUpMutatorContext) {
|
|||||||
|
|
||||||
// Whether a module can link to another module, taking into
|
// Whether a module can link to another module, taking into
|
||||||
// account NDK linking.
|
// account NDK linking.
|
||||||
func checkLinkType(ctx android.ModuleContext, from *Module, to *Module, tag DependencyTag) {
|
func checkLinkType(ctx android.ModuleContext, from LinkableInterface, to LinkableInterface, tag DependencyTag) {
|
||||||
if from.Target().Os != android.Android {
|
if from.Module().Target().Os != android.Android {
|
||||||
// Host code is not restricted
|
// Host code is not restricted
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if from.useVndk() {
|
|
||||||
|
// VNDK is cc.Module supported only for now.
|
||||||
|
if ccFrom, ok := from.(*Module); ok && from.UseVndk() {
|
||||||
// Though vendor code is limited by the vendor mutator,
|
// Though vendor code is limited by the vendor mutator,
|
||||||
// each vendor-available module needs to check
|
// each vendor-available module needs to check
|
||||||
// link-type for VNDK.
|
// link-type for VNDK.
|
||||||
if from.vndkdep != nil {
|
if ccTo, ok := to.(*Module); ok {
|
||||||
from.vndkdep.vndkCheckLinkType(ctx, to, tag)
|
if ccFrom.vndkdep != nil {
|
||||||
|
ccFrom.vndkdep.vndkCheckLinkType(ctx, ccTo, tag)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ctx.ModuleErrorf("Attempting to link VNDK cc.Module with unsupported module type")
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if String(from.Properties.Sdk_version) == "" {
|
if from.SdkVersion() == "" {
|
||||||
// Platform code can link to anything
|
// Platform code can link to anything
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if from.inRecovery() {
|
if from.InRecovery() {
|
||||||
// Recovery code is not NDK
|
// Recovery code is not NDK
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if _, ok := to.linker.(*toolchainLibraryDecorator); ok {
|
if to.ToolchainLibrary() {
|
||||||
// These are always allowed
|
// These are always allowed
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if _, ok := to.linker.(*ndkPrebuiltStlLinker); ok {
|
if to.NdkPrebuiltStl() {
|
||||||
// These are allowed, but they don't set sdk_version
|
// These are allowed, but they don't set sdk_version
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if _, ok := to.linker.(*stubDecorator); ok {
|
if to.StubDecorator() {
|
||||||
// These aren't real libraries, but are the stub shared libraries that are included in
|
// These aren't real libraries, but are the stub shared libraries that are included in
|
||||||
// the NDK.
|
// the NDK.
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if strings.HasPrefix(ctx.ModuleName(), "libclang_rt.") && to.Name() == "libc++" {
|
if strings.HasPrefix(ctx.ModuleName(), "libclang_rt.") && to.Module().Name() == "libc++" {
|
||||||
// Bug: http://b/121358700 - Allow libclang_rt.* shared libraries (with sdk_version)
|
// Bug: http://b/121358700 - Allow libclang_rt.* shared libraries (with sdk_version)
|
||||||
// to link to libc++ (non-NDK and without sdk_version).
|
// to link to libc++ (non-NDK and without sdk_version).
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if String(to.Properties.Sdk_version) == "" {
|
if to.SdkVersion() == "" {
|
||||||
// NDK code linking to platform code is never okay.
|
// NDK code linking to platform code is never okay.
|
||||||
ctx.ModuleErrorf("depends on non-NDK-built library %q",
|
ctx.ModuleErrorf("depends on non-NDK-built library %q",
|
||||||
ctx.OtherModuleName(to))
|
ctx.OtherModuleName(to.Module()))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1692,36 +1772,36 @@ func checkLinkType(ctx android.ModuleContext, from *Module, to *Module, tag Depe
|
|||||||
// APIs.
|
// APIs.
|
||||||
|
|
||||||
// Current can link against anything.
|
// Current can link against anything.
|
||||||
if String(from.Properties.Sdk_version) != "current" {
|
if from.SdkVersion() != "current" {
|
||||||
// Otherwise we need to check.
|
// Otherwise we need to check.
|
||||||
if String(to.Properties.Sdk_version) == "current" {
|
if to.SdkVersion() == "current" {
|
||||||
// Current can't be linked against by anything else.
|
// Current can't be linked against by anything else.
|
||||||
ctx.ModuleErrorf("links %q built against newer API version %q",
|
ctx.ModuleErrorf("links %q built against newer API version %q",
|
||||||
ctx.OtherModuleName(to), "current")
|
ctx.OtherModuleName(to.Module()), "current")
|
||||||
} else {
|
} else {
|
||||||
fromApi, err := strconv.Atoi(String(from.Properties.Sdk_version))
|
fromApi, err := strconv.Atoi(from.SdkVersion())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.PropertyErrorf("sdk_version",
|
ctx.PropertyErrorf("sdk_version",
|
||||||
"Invalid sdk_version value (must be int or current): %q",
|
"Invalid sdk_version value (must be int or current): %q",
|
||||||
String(from.Properties.Sdk_version))
|
from.SdkVersion())
|
||||||
}
|
}
|
||||||
toApi, err := strconv.Atoi(String(to.Properties.Sdk_version))
|
toApi, err := strconv.Atoi(to.SdkVersion())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.PropertyErrorf("sdk_version",
|
ctx.PropertyErrorf("sdk_version",
|
||||||
"Invalid sdk_version value (must be int or current): %q",
|
"Invalid sdk_version value (must be int or current): %q",
|
||||||
String(to.Properties.Sdk_version))
|
to.SdkVersion())
|
||||||
}
|
}
|
||||||
|
|
||||||
if toApi > fromApi {
|
if toApi > fromApi {
|
||||||
ctx.ModuleErrorf("links %q built against newer API version %q",
|
ctx.ModuleErrorf("links %q built against newer API version %q",
|
||||||
ctx.OtherModuleName(to), String(to.Properties.Sdk_version))
|
ctx.OtherModuleName(to.Module()), to.SdkVersion())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Also check that the two STL choices are compatible.
|
// Also check that the two STL choices are compatible.
|
||||||
fromStl := from.stl.Properties.SelectedStl
|
fromStl := from.SelectedStl()
|
||||||
toStl := to.stl.Properties.SelectedStl
|
toStl := to.SelectedStl()
|
||||||
if fromStl == "" || toStl == "" {
|
if fromStl == "" || toStl == "" {
|
||||||
// Libraries that don't use the STL are unrestricted.
|
// Libraries that don't use the STL are unrestricted.
|
||||||
} else if fromStl == "ndk_system" || toStl == "ndk_system" {
|
} else if fromStl == "ndk_system" || toStl == "ndk_system" {
|
||||||
@@ -1730,8 +1810,8 @@ func checkLinkType(ctx android.ModuleContext, from *Module, to *Module, tag Depe
|
|||||||
// using either libc++ or nothing.
|
// using either libc++ or nothing.
|
||||||
} else if getNdkStlFamily(from) != getNdkStlFamily(to) {
|
} else if getNdkStlFamily(from) != getNdkStlFamily(to) {
|
||||||
ctx.ModuleErrorf("uses %q and depends on %q which uses incompatible %q",
|
ctx.ModuleErrorf("uses %q and depends on %q which uses incompatible %q",
|
||||||
from.stl.Properties.SelectedStl, ctx.OtherModuleName(to),
|
from.SelectedStl(), ctx.OtherModuleName(to.Module()),
|
||||||
to.stl.Properties.SelectedStl)
|
to.SelectedStl())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1753,7 +1833,7 @@ func checkDoubleLoadableLibraries(ctx android.TopDownMutatorContext) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// if target lib has no vendor variant, keep checking dependency graph
|
// if target lib has no vendor variant, keep checking dependency graph
|
||||||
if !to.hasVendorVariant() {
|
if !to.HasVendorVariant() {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1800,8 +1880,9 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
depName := ctx.OtherModuleName(dep)
|
depName := ctx.OtherModuleName(dep)
|
||||||
depTag := ctx.OtherModuleDependencyTag(dep)
|
depTag := ctx.OtherModuleDependencyTag(dep)
|
||||||
|
|
||||||
ccDep, _ := dep.(*Module)
|
ccDep, ok := dep.(LinkableInterface)
|
||||||
if ccDep == nil {
|
if !ok {
|
||||||
|
|
||||||
// handling for a few module types that aren't cc Module but that are also supported
|
// handling for a few module types that aren't cc Module but that are also supported
|
||||||
switch depTag {
|
switch depTag {
|
||||||
case genSourceDepTag:
|
case genSourceDepTag:
|
||||||
@@ -1859,9 +1940,10 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
|
|
||||||
// re-exporting flags
|
// re-exporting flags
|
||||||
if depTag == reuseObjTag {
|
if depTag == reuseObjTag {
|
||||||
if l, ok := ccDep.compiler.(libraryInterface); ok {
|
// reusing objects only make sense for cc.Modules.
|
||||||
|
if ccReuseDep, ok := ccDep.(*Module); ok && ccDep.CcLibraryInterface() {
|
||||||
c.staticVariant = ccDep
|
c.staticVariant = ccDep
|
||||||
objs, exporter := l.reuseObjs()
|
objs, exporter := ccReuseDep.compiler.(libraryInterface).reuseObjs()
|
||||||
depPaths.Objs = depPaths.Objs.Append(objs)
|
depPaths.Objs = depPaths.Objs.Append(objs)
|
||||||
reexportExporter(exporter)
|
reexportExporter(exporter)
|
||||||
return
|
return
|
||||||
@@ -1869,7 +1951,8 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if depTag == staticVariantTag {
|
if depTag == staticVariantTag {
|
||||||
if _, ok := ccDep.compiler.(libraryInterface); ok {
|
// staticVariants are a cc.Module specific concept.
|
||||||
|
if _, ok := ccDep.(*Module); ok && ccDep.CcLibraryInterface() {
|
||||||
c.staticVariant = ccDep
|
c.staticVariant = ccDep
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -1891,8 +1974,8 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
case StaticDepTag, staticExportDepTag, lateStaticDepTag, wholeStaticDepTag:
|
case StaticDepTag, staticExportDepTag, lateStaticDepTag, wholeStaticDepTag:
|
||||||
depIsStatic = true
|
depIsStatic = true
|
||||||
}
|
}
|
||||||
if dependentLibrary, ok := ccDep.linker.(*libraryDecorator); ok && !depIsStatic {
|
if ccDep.CcLibrary() && !depIsStatic {
|
||||||
depIsStubs := dependentLibrary.buildStubs()
|
depIsStubs := ccDep.BuildStubs()
|
||||||
depHasStubs := ccDep.HasStubsVariants()
|
depHasStubs := ccDep.HasStubsVariants()
|
||||||
depInSameApex := android.DirectlyInApex(c.ApexName(), depName)
|
depInSameApex := android.DirectlyInApex(c.ApexName(), depName)
|
||||||
depInPlatform := !android.DirectlyInAnyApex(ctx, depName)
|
depInPlatform := !android.DirectlyInAnyApex(ctx, depName)
|
||||||
@@ -1909,7 +1992,7 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
// If not building for APEX, use stubs only when it is from
|
// If not building for APEX, use stubs only when it is from
|
||||||
// an APEX (and not from platform)
|
// an APEX (and not from platform)
|
||||||
useThisDep = (depInPlatform != depIsStubs)
|
useThisDep = (depInPlatform != depIsStubs)
|
||||||
if c.inRecovery() || c.bootstrap() {
|
if c.InRecovery() || c.bootstrap() {
|
||||||
// However, for recovery or bootstrap modules,
|
// However, for recovery or bootstrap modules,
|
||||||
// always link to non-stub variant
|
// always link to non-stub variant
|
||||||
useThisDep = !depIsStubs
|
useThisDep = !depIsStubs
|
||||||
@@ -1925,49 +2008,51 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if i, ok := ccDep.linker.(exportedFlagsProducer); ok {
|
// Exporting flags only makes sense for cc.Modules
|
||||||
depPaths.IncludeDirs = append(depPaths.IncludeDirs, i.exportedDirs()...)
|
if _, ok := ccDep.(*Module); ok {
|
||||||
depPaths.SystemIncludeDirs = append(depPaths.SystemIncludeDirs, i.exportedSystemDirs()...)
|
if i, ok := ccDep.(*Module).linker.(exportedFlagsProducer); ok {
|
||||||
depPaths.GeneratedHeaders = append(depPaths.GeneratedHeaders, i.exportedDeps()...)
|
depPaths.IncludeDirs = append(depPaths.IncludeDirs, i.exportedDirs()...)
|
||||||
depPaths.Flags = append(depPaths.Flags, i.exportedFlags()...)
|
depPaths.SystemIncludeDirs = append(depPaths.SystemIncludeDirs, i.exportedSystemDirs()...)
|
||||||
|
depPaths.GeneratedHeaders = append(depPaths.GeneratedHeaders, i.exportedDeps()...)
|
||||||
|
depPaths.Flags = append(depPaths.Flags, i.exportedFlags()...)
|
||||||
|
|
||||||
if t.ReexportFlags {
|
if t.ReexportFlags {
|
||||||
reexportExporter(i)
|
reexportExporter(i)
|
||||||
// Add these re-exported flags to help header-abi-dumper to infer the abi exported by a library.
|
// Add these re-exported flags to help header-abi-dumper to infer the abi exported by a library.
|
||||||
// Re-exported shared library headers must be included as well since they can help us with type information
|
// Re-exported shared library headers must be included as well since they can help us with type information
|
||||||
// about template instantiations (instantiated from their headers).
|
// about template instantiations (instantiated from their headers).
|
||||||
// -isystem headers are not included since for bionic libraries, abi-filtering is taken care of by version
|
// -isystem headers are not included since for bionic libraries, abi-filtering is taken care of by version
|
||||||
// scripts.
|
// scripts.
|
||||||
c.sabi.Properties.ReexportedIncludes = append(
|
c.sabi.Properties.ReexportedIncludes = append(
|
||||||
c.sabi.Properties.ReexportedIncludes, i.exportedDirs().Strings()...)
|
c.sabi.Properties.ReexportedIncludes, i.exportedDirs().Strings()...)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
checkLinkType(ctx, c, ccDep, t)
|
checkLinkType(ctx, c, ccDep, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
var ptr *android.Paths
|
var ptr *android.Paths
|
||||||
var depPtr *android.Paths
|
var depPtr *android.Paths
|
||||||
|
|
||||||
linkFile := ccDep.outputFile
|
linkFile := ccDep.OutputFile()
|
||||||
depFile := android.OptionalPath{}
|
depFile := android.OptionalPath{}
|
||||||
|
|
||||||
switch depTag {
|
switch depTag {
|
||||||
case ndkStubDepTag, SharedDepTag, sharedExportDepTag:
|
case ndkStubDepTag, SharedDepTag, sharedExportDepTag:
|
||||||
ptr = &depPaths.SharedLibs
|
ptr = &depPaths.SharedLibs
|
||||||
depPtr = &depPaths.SharedLibsDeps
|
depPtr = &depPaths.SharedLibsDeps
|
||||||
depFile = ccDep.linker.(libraryInterface).toc()
|
depFile = ccDep.Toc()
|
||||||
directSharedDeps = append(directSharedDeps, ccDep)
|
directSharedDeps = append(directSharedDeps, ccDep)
|
||||||
|
|
||||||
case earlySharedDepTag:
|
case earlySharedDepTag:
|
||||||
ptr = &depPaths.EarlySharedLibs
|
ptr = &depPaths.EarlySharedLibs
|
||||||
depPtr = &depPaths.EarlySharedLibsDeps
|
depPtr = &depPaths.EarlySharedLibsDeps
|
||||||
depFile = ccDep.linker.(libraryInterface).toc()
|
depFile = ccDep.Toc()
|
||||||
directSharedDeps = append(directSharedDeps, ccDep)
|
directSharedDeps = append(directSharedDeps, ccDep)
|
||||||
case lateSharedDepTag, ndkLateStubDepTag:
|
case lateSharedDepTag, ndkLateStubDepTag:
|
||||||
ptr = &depPaths.LateSharedLibs
|
ptr = &depPaths.LateSharedLibs
|
||||||
depPtr = &depPaths.LateSharedLibsDeps
|
depPtr = &depPaths.LateSharedLibsDeps
|
||||||
depFile = ccDep.linker.(libraryInterface).toc()
|
depFile = ccDep.Toc()
|
||||||
case StaticDepTag, staticExportDepTag:
|
case StaticDepTag, staticExportDepTag:
|
||||||
ptr = nil
|
ptr = nil
|
||||||
directStaticDeps = append(directStaticDeps, ccDep)
|
directStaticDeps = append(directStaticDeps, ccDep)
|
||||||
@@ -1975,20 +2060,28 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
ptr = &depPaths.LateStaticLibs
|
ptr = &depPaths.LateStaticLibs
|
||||||
case wholeStaticDepTag:
|
case wholeStaticDepTag:
|
||||||
ptr = &depPaths.WholeStaticLibs
|
ptr = &depPaths.WholeStaticLibs
|
||||||
staticLib, ok := ccDep.linker.(libraryInterface)
|
if !ccDep.CcLibraryInterface() || !ccDep.Static() {
|
||||||
if !ok || !staticLib.static() {
|
|
||||||
ctx.ModuleErrorf("module %q not a static library", depName)
|
ctx.ModuleErrorf("module %q not a static library", depName)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if missingDeps := staticLib.getWholeStaticMissingDeps(); missingDeps != nil {
|
// Because the static library objects are included, this only makes sense
|
||||||
postfix := " (required by " + ctx.OtherModuleName(dep) + ")"
|
// in the context of proper cc.Modules.
|
||||||
for i := range missingDeps {
|
if ccWholeStaticLib, ok := ccDep.(*Module); ok {
|
||||||
missingDeps[i] += postfix
|
staticLib := ccWholeStaticLib.linker.(libraryInterface)
|
||||||
|
if missingDeps := staticLib.getWholeStaticMissingDeps(); missingDeps != nil {
|
||||||
|
postfix := " (required by " + ctx.OtherModuleName(dep) + ")"
|
||||||
|
for i := range missingDeps {
|
||||||
|
missingDeps[i] += postfix
|
||||||
|
}
|
||||||
|
ctx.AddMissingDependencies(missingDeps)
|
||||||
}
|
}
|
||||||
ctx.AddMissingDependencies(missingDeps)
|
depPaths.WholeStaticLibObjs = depPaths.WholeStaticLibObjs.Append(staticLib.objs())
|
||||||
|
} else {
|
||||||
|
ctx.ModuleErrorf(
|
||||||
|
"non-cc.Modules cannot be included as whole static libraries.", depName)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
depPaths.WholeStaticLibObjs = depPaths.WholeStaticLibObjs.Append(staticLib.objs())
|
|
||||||
case headerDepTag:
|
case headerDepTag:
|
||||||
// Nothing
|
// Nothing
|
||||||
case objDepTag:
|
case objDepTag:
|
||||||
@@ -2003,8 +2096,7 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
|
|
||||||
switch depTag {
|
switch depTag {
|
||||||
case StaticDepTag, staticExportDepTag, lateStaticDepTag:
|
case StaticDepTag, staticExportDepTag, lateStaticDepTag:
|
||||||
staticLib, ok := ccDep.linker.(libraryInterface)
|
if !ccDep.CcLibraryInterface() || !ccDep.Static() {
|
||||||
if !ok || !staticLib.static() {
|
|
||||||
ctx.ModuleErrorf("module %q not a static library", depName)
|
ctx.ModuleErrorf("module %q not a static library", depName)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -2012,11 +2104,14 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
// When combining coverage files for shared libraries and executables, coverage files
|
// When combining coverage files for shared libraries and executables, coverage files
|
||||||
// in static libraries act as if they were whole static libraries. The same goes for
|
// in static libraries act as if they were whole static libraries. The same goes for
|
||||||
// source based Abi dump files.
|
// source based Abi dump files.
|
||||||
depPaths.StaticLibObjs.coverageFiles = append(depPaths.StaticLibObjs.coverageFiles,
|
// This should only be done for cc.Modules
|
||||||
staticLib.objs().coverageFiles...)
|
if c, ok := ccDep.(*Module); ok {
|
||||||
depPaths.StaticLibObjs.sAbiDumpFiles = append(depPaths.StaticLibObjs.sAbiDumpFiles,
|
staticLib := c.linker.(libraryInterface)
|
||||||
staticLib.objs().sAbiDumpFiles...)
|
depPaths.StaticLibObjs.coverageFiles = append(depPaths.StaticLibObjs.coverageFiles,
|
||||||
|
staticLib.objs().coverageFiles...)
|
||||||
|
depPaths.StaticLibObjs.sAbiDumpFiles = append(depPaths.StaticLibObjs.sAbiDumpFiles,
|
||||||
|
staticLib.objs().sAbiDumpFiles...)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ptr != nil {
|
if ptr != nil {
|
||||||
@@ -2045,13 +2140,13 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
libName = strings.TrimPrefix(libName, "prebuilt_")
|
libName = strings.TrimPrefix(libName, "prebuilt_")
|
||||||
isLLndk := inList(libName, *llndkLibraries)
|
isLLndk := inList(libName, *llndkLibraries)
|
||||||
isVendorPublicLib := inList(libName, *vendorPublicLibraries)
|
isVendorPublicLib := inList(libName, *vendorPublicLibraries)
|
||||||
bothVendorAndCoreVariantsExist := ccDep.hasVendorVariant() || isLLndk
|
bothVendorAndCoreVariantsExist := ccDep.HasVendorVariant() || isLLndk
|
||||||
|
|
||||||
if ctx.DeviceConfig().VndkUseCoreVariant() && ccDep.isVndk() && !ccDep.mustUseVendorVariant() && !c.inRecovery() {
|
if ctx.DeviceConfig().VndkUseCoreVariant() && ccDep.IsVndk() && !ccDep.MustUseVendorVariant() && !c.InRecovery() {
|
||||||
// The vendor module is a no-vendor-variant VNDK library. Depend on the
|
// The vendor module is a no-vendor-variant VNDK library. Depend on the
|
||||||
// core module instead.
|
// core module instead.
|
||||||
return libName
|
return libName
|
||||||
} else if c.useVndk() && bothVendorAndCoreVariantsExist {
|
} else if c.UseVndk() && bothVendorAndCoreVariantsExist {
|
||||||
// The vendor module in Make will have been renamed to not conflict with the core
|
// The vendor module in Make will have been renamed to not conflict with the core
|
||||||
// module, so update the dependency name here accordingly.
|
// module, so update the dependency name here accordingly.
|
||||||
ret := libName + vendorSuffix
|
ret := libName + vendorSuffix
|
||||||
@@ -2065,9 +2160,9 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
return ret
|
return ret
|
||||||
} else if (ctx.Platform() || ctx.ProductSpecific()) && isVendorPublicLib {
|
} else if (ctx.Platform() || ctx.ProductSpecific()) && isVendorPublicLib {
|
||||||
return libName + vendorPublicLibrarySuffix
|
return libName + vendorPublicLibrarySuffix
|
||||||
} else if ccDep.inRecovery() && !ccDep.onlyInRecovery() {
|
} else if ccDep.InRecovery() && !ccDep.OnlyInRecovery() {
|
||||||
return libName + recoverySuffix
|
return libName + recoverySuffix
|
||||||
} else if ccDep.Target().NativeBridge == android.NativeBridgeEnabled {
|
} else if ccDep.Module().Target().NativeBridge == android.NativeBridgeEnabled {
|
||||||
return libName + nativeBridgeSuffix
|
return libName + nativeBridgeSuffix
|
||||||
} else {
|
} else {
|
||||||
return libName
|
return libName
|
||||||
@@ -2077,8 +2172,8 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
// Export the shared libs to Make.
|
// Export the shared libs to Make.
|
||||||
switch depTag {
|
switch depTag {
|
||||||
case SharedDepTag, sharedExportDepTag, lateSharedDepTag, earlySharedDepTag:
|
case SharedDepTag, sharedExportDepTag, lateSharedDepTag, earlySharedDepTag:
|
||||||
if dependentLibrary, ok := ccDep.linker.(*libraryDecorator); ok {
|
if ccDep.CcLibrary() {
|
||||||
if dependentLibrary.buildStubs() && android.InAnyApex(depName) {
|
if ccDep.BuildStubs() && android.InAnyApex(depName) {
|
||||||
// Add the dependency to the APEX(es) providing the library so that
|
// Add the dependency to the APEX(es) providing the library so that
|
||||||
// m <module> can trigger building the APEXes as well.
|
// m <module> can trigger building the APEXes as well.
|
||||||
for _, an := range android.GetApexesForModule(depName) {
|
for _, an := range android.GetApexesForModule(depName) {
|
||||||
@@ -2093,10 +2188,9 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
c.Properties.AndroidMkSharedLibs = append(
|
c.Properties.AndroidMkSharedLibs = append(
|
||||||
c.Properties.AndroidMkSharedLibs, makeLibName(depName))
|
c.Properties.AndroidMkSharedLibs, makeLibName(depName))
|
||||||
case ndkStubDepTag, ndkLateStubDepTag:
|
case ndkStubDepTag, ndkLateStubDepTag:
|
||||||
ndkStub := ccDep.linker.(*stubDecorator)
|
|
||||||
c.Properties.AndroidMkSharedLibs = append(
|
c.Properties.AndroidMkSharedLibs = append(
|
||||||
c.Properties.AndroidMkSharedLibs,
|
c.Properties.AndroidMkSharedLibs,
|
||||||
depName+"."+ndkStub.properties.ApiLevel)
|
depName+"."+ccDep.ApiLevel())
|
||||||
case StaticDepTag, staticExportDepTag, lateStaticDepTag:
|
case StaticDepTag, staticExportDepTag, lateStaticDepTag:
|
||||||
c.Properties.AndroidMkStaticLibs = append(
|
c.Properties.AndroidMkStaticLibs = append(
|
||||||
c.Properties.AndroidMkStaticLibs, makeLibName(depName))
|
c.Properties.AndroidMkStaticLibs, makeLibName(depName))
|
||||||
@@ -2147,7 +2241,7 @@ func (c *Module) InstallInSanitizerDir() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) InstallInRecovery() bool {
|
func (c *Module) InstallInRecovery() bool {
|
||||||
return c.inRecovery()
|
return c.InRecovery()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) HostToolPath() android.OptionalPath {
|
func (c *Module) HostToolPath() android.OptionalPath {
|
||||||
@@ -2201,28 +2295,28 @@ func (c *Module) header() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) getMakeLinkType(actx android.ModuleContext) string {
|
func (c *Module) getMakeLinkType(actx android.ModuleContext) string {
|
||||||
if c.useVndk() {
|
if c.UseVndk() {
|
||||||
if lib, ok := c.linker.(*llndkStubDecorator); ok {
|
if lib, ok := c.linker.(*llndkStubDecorator); ok {
|
||||||
if Bool(lib.Properties.Vendor_available) {
|
if Bool(lib.Properties.Vendor_available) {
|
||||||
return "native:vndk"
|
return "native:vndk"
|
||||||
}
|
}
|
||||||
return "native:vndk_private"
|
return "native:vndk_private"
|
||||||
}
|
}
|
||||||
if c.isVndk() && !c.isVndkExt() {
|
if c.IsVndk() && !c.isVndkExt() {
|
||||||
if Bool(c.VendorProperties.Vendor_available) {
|
if Bool(c.VendorProperties.Vendor_available) {
|
||||||
return "native:vndk"
|
return "native:vndk"
|
||||||
}
|
}
|
||||||
return "native:vndk_private"
|
return "native:vndk_private"
|
||||||
}
|
}
|
||||||
return "native:vendor"
|
return "native:vendor"
|
||||||
} else if c.inRecovery() {
|
} else if c.InRecovery() {
|
||||||
return "native:recovery"
|
return "native:recovery"
|
||||||
} else if c.Target().Os == android.Android && String(c.Properties.Sdk_version) != "" {
|
} else if c.Target().Os == android.Android && String(c.Properties.Sdk_version) != "" {
|
||||||
return "native:ndk:none:none"
|
return "native:ndk:none:none"
|
||||||
// TODO(b/114741097): use the correct ndk stl once build errors have been fixed
|
// TODO(b/114741097): use the correct ndk stl once build errors have been fixed
|
||||||
//family, link := getNdkStlFamilyAndLinkType(c)
|
//family, link := getNdkStlFamilyAndLinkType(c)
|
||||||
//return fmt.Sprintf("native:ndk:%s:%s", family, link)
|
//return fmt.Sprintf("native:ndk:%s:%s", family, link)
|
||||||
} else if actx.DeviceConfig().VndkUseCoreVariant() && !c.mustUseVendorVariant() {
|
} else if actx.DeviceConfig().VndkUseCoreVariant() && !c.MustUseVendorVariant() {
|
||||||
return "native:platform_vndk"
|
return "native:platform_vndk"
|
||||||
} else {
|
} else {
|
||||||
return "native:platform"
|
return "native:platform"
|
||||||
@@ -2257,9 +2351,9 @@ func (c *Module) installable() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *Module) imageVariation() string {
|
func (c *Module) imageVariation() string {
|
||||||
if c.useVndk() {
|
if c.UseVndk() {
|
||||||
return vendorMode + "." + c.Properties.VndkVersion
|
return vendorMode + "." + c.Properties.VndkVersion
|
||||||
} else if c.inRecovery() {
|
} else if c.InRecovery() {
|
||||||
return recoveryMode
|
return recoveryMode
|
||||||
}
|
}
|
||||||
return coreMode
|
return coreMode
|
||||||
@@ -2434,8 +2528,16 @@ func ImageMutator(mctx android.BottomUpMutatorContext) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//TODO When LinkableInterface supports VNDK, this should be mctx.Module().(LinkableInterface)
|
||||||
m, ok := mctx.Module().(*Module)
|
m, ok := mctx.Module().(*Module)
|
||||||
if !ok {
|
if !ok {
|
||||||
|
if linkable, ok := mctx.Module().(LinkableInterface); ok {
|
||||||
|
variations := []string{coreMode}
|
||||||
|
if linkable.InRecovery() {
|
||||||
|
variations = append(variations, recoveryMode)
|
||||||
|
}
|
||||||
|
mctx.CreateVariations(variations...)
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2525,12 +2627,12 @@ func ImageMutator(mctx android.BottomUpMutatorContext) {
|
|||||||
// Make vendor variants only for the versions in BOARD_VNDK_VERSION and
|
// Make vendor variants only for the versions in BOARD_VNDK_VERSION and
|
||||||
// PRODUCT_EXTRA_VNDK_VERSIONS.
|
// PRODUCT_EXTRA_VNDK_VERSIONS.
|
||||||
vendorVariants = append(vendorVariants, lib.version())
|
vendorVariants = append(vendorVariants, lib.version())
|
||||||
} else if m.hasVendorVariant() && !vendorSpecific {
|
} else if m.HasVendorVariant() && !vendorSpecific {
|
||||||
// This will be available in both /system and /vendor
|
// This will be available in both /system and /vendor
|
||||||
// or a /system directory that is available to vendor.
|
// or a /system directory that is available to vendor.
|
||||||
coreVariantNeeded = true
|
coreVariantNeeded = true
|
||||||
vendorVariants = append(vendorVariants, platformVndkVersion)
|
vendorVariants = append(vendorVariants, platformVndkVersion)
|
||||||
if m.isVndk() {
|
if m.IsVndk() {
|
||||||
vendorVariants = append(vendorVariants, deviceVndkVersion)
|
vendorVariants = append(vendorVariants, deviceVndkVersion)
|
||||||
}
|
}
|
||||||
} else if vendorSpecific && String(m.Properties.Sdk_version) == "" {
|
} else if vendorSpecific && String(m.Properties.Sdk_version) == "" {
|
||||||
|
@@ -213,7 +213,7 @@ func checkVndkModule(t *testing.T, ctx *android.TestContext, name, subDir string
|
|||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
mod := ctx.ModuleForTests(name, vendorVariant).Module().(*Module)
|
mod := ctx.ModuleForTests(name, vendorVariant).Module().(*Module)
|
||||||
if !mod.hasVendorVariant() {
|
if !mod.HasVendorVariant() {
|
||||||
t.Errorf("%q must have vendor variant", name)
|
t.Errorf("%q must have vendor variant", name)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -230,8 +230,8 @@ func checkVndkModule(t *testing.T, ctx *android.TestContext, name, subDir string
|
|||||||
if mod.vndkdep == nil {
|
if mod.vndkdep == nil {
|
||||||
t.Fatalf("%q must have `vndkdep`", name)
|
t.Fatalf("%q must have `vndkdep`", name)
|
||||||
}
|
}
|
||||||
if !mod.isVndk() {
|
if !mod.IsVndk() {
|
||||||
t.Errorf("%q isVndk() must equal to true", name)
|
t.Errorf("%q IsVndk() must equal to true", name)
|
||||||
}
|
}
|
||||||
if mod.isVndkSp() != isVndkSp {
|
if mod.isVndkSp() != isVndkSp {
|
||||||
t.Errorf("%q isVndkSp() must equal to %t", name, isVndkSp)
|
t.Errorf("%q isVndkSp() must equal to %t", name, isVndkSp)
|
||||||
|
@@ -207,7 +207,7 @@ func (s *fuzzPackager) GenerateBuildActions(ctx android.SingletonContext) {
|
|||||||
|
|
||||||
// Discard vendor-NDK-linked modules, they're duplicates of fuzz targets
|
// Discard vendor-NDK-linked modules, they're duplicates of fuzz targets
|
||||||
// we're going to package anyway.
|
// we're going to package anyway.
|
||||||
if ccModule.useVndk() || !ccModule.Enabled() {
|
if ccModule.UseVndk() || !ccModule.Enabled() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1227,45 +1227,59 @@ func reuseStaticLibrary(mctx android.BottomUpMutatorContext, static, shared *Mod
|
|||||||
}
|
}
|
||||||
|
|
||||||
func LinkageMutator(mctx android.BottomUpMutatorContext) {
|
func LinkageMutator(mctx android.BottomUpMutatorContext) {
|
||||||
|
cc_prebuilt := false
|
||||||
if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
|
if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
|
||||||
switch library := m.linker.(type) {
|
_, cc_prebuilt = m.linker.(prebuiltLibraryInterface)
|
||||||
case prebuiltLibraryInterface:
|
}
|
||||||
// Always create both the static and shared variants for prebuilt libraries, and then disable the one
|
if cc_prebuilt {
|
||||||
// that is not being used. This allows them to share the name of a cc_library module, which requires that
|
library := mctx.Module().(*Module).linker.(prebuiltLibraryInterface)
|
||||||
// all the variants of the cc_library also exist on the prebuilt.
|
|
||||||
modules := mctx.CreateLocalVariations("static", "shared")
|
|
||||||
static := modules[0].(*Module)
|
|
||||||
shared := modules[1].(*Module)
|
|
||||||
|
|
||||||
static.linker.(prebuiltLibraryInterface).setStatic()
|
// Always create both the static and shared variants for prebuilt libraries, and then disable the one
|
||||||
shared.linker.(prebuiltLibraryInterface).setShared()
|
// that is not being used. This allows them to share the name of a cc_library module, which requires that
|
||||||
|
// all the variants of the cc_library also exist on the prebuilt.
|
||||||
|
modules := mctx.CreateLocalVariations("static", "shared")
|
||||||
|
static := modules[0].(*Module)
|
||||||
|
shared := modules[1].(*Module)
|
||||||
|
|
||||||
if !library.buildStatic() {
|
static.linker.(prebuiltLibraryInterface).setStatic()
|
||||||
static.linker.(prebuiltLibraryInterface).disablePrebuilt()
|
shared.linker.(prebuiltLibraryInterface).setShared()
|
||||||
}
|
|
||||||
if !library.buildShared() {
|
|
||||||
shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
|
|
||||||
}
|
|
||||||
|
|
||||||
case libraryInterface:
|
if !library.buildStatic() {
|
||||||
if library.buildStatic() && library.buildShared() {
|
static.linker.(prebuiltLibraryInterface).disablePrebuilt()
|
||||||
modules := mctx.CreateLocalVariations("static", "shared")
|
|
||||||
static := modules[0].(*Module)
|
|
||||||
shared := modules[1].(*Module)
|
|
||||||
|
|
||||||
static.linker.(libraryInterface).setStatic()
|
|
||||||
shared.linker.(libraryInterface).setShared()
|
|
||||||
|
|
||||||
reuseStaticLibrary(mctx, static, shared)
|
|
||||||
|
|
||||||
} else if library.buildStatic() {
|
|
||||||
modules := mctx.CreateLocalVariations("static")
|
|
||||||
modules[0].(*Module).linker.(libraryInterface).setStatic()
|
|
||||||
} else if library.buildShared() {
|
|
||||||
modules := mctx.CreateLocalVariations("shared")
|
|
||||||
modules[0].(*Module).linker.(libraryInterface).setShared()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
if !library.buildShared() {
|
||||||
|
shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
|
||||||
|
}
|
||||||
|
} else if library, ok := mctx.Module().(LinkableInterface); ok && library.CcLibraryInterface() {
|
||||||
|
if library.BuildStaticVariant() && library.BuildSharedVariant() {
|
||||||
|
variations := []string{"static", "shared"}
|
||||||
|
|
||||||
|
// Non-cc.Modules need an empty variant for their mutators.
|
||||||
|
if _, ok := mctx.Module().(*Module); !ok {
|
||||||
|
variations = append(variations, "")
|
||||||
|
}
|
||||||
|
|
||||||
|
modules := mctx.CreateLocalVariations(variations...)
|
||||||
|
static := modules[0].(LinkableInterface)
|
||||||
|
shared := modules[1].(LinkableInterface)
|
||||||
|
|
||||||
|
static.SetStatic()
|
||||||
|
shared.SetShared()
|
||||||
|
|
||||||
|
if _, ok := library.(*Module); ok {
|
||||||
|
reuseStaticLibrary(mctx, static.(*Module), shared.(*Module))
|
||||||
|
}
|
||||||
|
} else if library.BuildStaticVariant() {
|
||||||
|
modules := mctx.CreateLocalVariations("static")
|
||||||
|
modules[0].(LinkableInterface).SetStatic()
|
||||||
|
} else if library.BuildSharedVariant() {
|
||||||
|
modules := mctx.CreateLocalVariations("shared")
|
||||||
|
modules[0].(LinkableInterface).SetShared()
|
||||||
|
} else if _, ok := mctx.Module().(*Module); !ok {
|
||||||
|
// Non-cc.Modules need an empty variant for their mutators.
|
||||||
|
mctx.CreateLocalVariations("")
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1292,11 +1306,10 @@ func latestStubsVersionFor(config android.Config, name string) string {
|
|||||||
// Version mutator splits a module into the mandatory non-stubs variant
|
// Version mutator splits a module into the mandatory non-stubs variant
|
||||||
// (which is unnamed) and zero or more stubs variants.
|
// (which is unnamed) and zero or more stubs variants.
|
||||||
func VersionMutator(mctx android.BottomUpMutatorContext) {
|
func VersionMutator(mctx android.BottomUpMutatorContext) {
|
||||||
if m, ok := mctx.Module().(*Module); ok && !m.inRecovery() && m.linker != nil {
|
if library, ok := mctx.Module().(LinkableInterface); ok && !library.InRecovery() {
|
||||||
if library, ok := m.linker.(*libraryDecorator); ok && library.buildShared() &&
|
if library.CcLibrary() && library.BuildSharedVariant() && len(library.StubsVersions()) > 0 {
|
||||||
len(library.Properties.Stubs.Versions) > 0 {
|
|
||||||
versions := []string{}
|
versions := []string{}
|
||||||
for _, v := range library.Properties.Stubs.Versions {
|
for _, v := range library.StubsVersions() {
|
||||||
if _, err := strconv.Atoi(v); err != nil {
|
if _, err := strconv.Atoi(v); err != nil {
|
||||||
mctx.PropertyErrorf("versions", "%q is not a number", v)
|
mctx.PropertyErrorf("versions", "%q is not a number", v)
|
||||||
}
|
}
|
||||||
@@ -1320,14 +1333,9 @@ func VersionMutator(mctx android.BottomUpMutatorContext) {
|
|||||||
|
|
||||||
modules := mctx.CreateVariations(versions...)
|
modules := mctx.CreateVariations(versions...)
|
||||||
for i, m := range modules {
|
for i, m := range modules {
|
||||||
l := m.(*Module).linker.(*libraryDecorator)
|
|
||||||
if versions[i] != "" {
|
if versions[i] != "" {
|
||||||
l.MutatedProperties.BuildStubs = true
|
m.(LinkableInterface).SetBuildStubs()
|
||||||
l.MutatedProperties.StubsVersion = versions[i]
|
m.(LinkableInterface).SetStubsVersions(versions[i])
|
||||||
m.(*Module).Properties.HideFromMake = true
|
|
||||||
m.(*Module).sanitize = nil
|
|
||||||
m.(*Module).stl = nil
|
|
||||||
m.(*Module).Properties.PreventInstall = true
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@@ -11,10 +11,9 @@ type LinkableInterface interface {
|
|||||||
CcLibrary() bool
|
CcLibrary() bool
|
||||||
CcLibraryInterface() bool
|
CcLibraryInterface() bool
|
||||||
|
|
||||||
InRecovery() bool
|
|
||||||
OutputFile() android.OptionalPath
|
OutputFile() android.OptionalPath
|
||||||
|
|
||||||
IncludeDirs() android.Paths
|
IncludeDirs(ctx android.BaseModuleContext) android.Paths
|
||||||
SetDepsInLinkOrder([]android.Path)
|
SetDepsInLinkOrder([]android.Path)
|
||||||
GetDepsInLinkOrder() []android.Path
|
GetDepsInLinkOrder() []android.Path
|
||||||
|
|
||||||
@@ -22,13 +21,34 @@ type LinkableInterface interface {
|
|||||||
GetStaticVariant() LinkableInterface
|
GetStaticVariant() LinkableInterface
|
||||||
|
|
||||||
StubsVersions() []string
|
StubsVersions() []string
|
||||||
|
BuildStubs() bool
|
||||||
SetBuildStubs()
|
SetBuildStubs()
|
||||||
SetStubsVersions(string)
|
SetStubsVersions(string)
|
||||||
|
HasStubsVariants() bool
|
||||||
|
SelectedStl() string
|
||||||
|
ApiLevel() string
|
||||||
|
|
||||||
BuildStaticVariant() bool
|
BuildStaticVariant() bool
|
||||||
BuildSharedVariant() bool
|
BuildSharedVariant() bool
|
||||||
SetStatic()
|
SetStatic()
|
||||||
SetShared()
|
SetShared()
|
||||||
|
Static() bool
|
||||||
|
Shared() bool
|
||||||
|
Toc() android.OptionalPath
|
||||||
|
|
||||||
|
InRecovery() bool
|
||||||
|
OnlyInRecovery() bool
|
||||||
|
|
||||||
|
UseVndk() bool
|
||||||
|
MustUseVendorVariant() bool
|
||||||
|
IsVndk() bool
|
||||||
|
HasVendorVariant() bool
|
||||||
|
|
||||||
|
SdkVersion() string
|
||||||
|
|
||||||
|
ToolchainLibrary() bool
|
||||||
|
NdkPrebuiltStl() bool
|
||||||
|
StubDecorator() bool
|
||||||
}
|
}
|
||||||
|
|
||||||
type DependencyTag struct {
|
type DependencyTag struct {
|
||||||
|
@@ -78,7 +78,7 @@ func (sabimod *sabi) flags(ctx ModuleContext, flags Flags) Flags {
|
|||||||
|
|
||||||
func sabiDepsMutator(mctx android.TopDownMutatorContext) {
|
func sabiDepsMutator(mctx android.TopDownMutatorContext) {
|
||||||
if c, ok := mctx.Module().(*Module); ok &&
|
if c, ok := mctx.Module().(*Module); ok &&
|
||||||
((c.isVndk() && c.useVndk()) || inList(c.Name(), *llndkLibraries(mctx.Config())) ||
|
((c.IsVndk() && c.UseVndk()) || inList(c.Name(), *llndkLibraries(mctx.Config())) ||
|
||||||
(c.sabi != nil && c.sabi.Properties.CreateSAbiDumps)) {
|
(c.sabi != nil && c.sabi.Properties.CreateSAbiDumps)) {
|
||||||
mctx.VisitDirectDeps(func(m android.Module) {
|
mctx.VisitDirectDeps(func(m android.Module) {
|
||||||
tag := mctx.OtherModuleDependencyTag(m)
|
tag := mctx.OtherModuleDependencyTag(m)
|
||||||
|
@@ -873,7 +873,7 @@ func sanitizerRuntimeMutator(mctx android.BottomUpMutatorContext) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if mctx.Device() && runtimeLibrary != "" {
|
if mctx.Device() && runtimeLibrary != "" {
|
||||||
if inList(runtimeLibrary, *llndkLibraries(mctx.Config())) && !c.static() && c.useVndk() {
|
if inList(runtimeLibrary, *llndkLibraries(mctx.Config())) && !c.static() && c.UseVndk() {
|
||||||
runtimeLibrary = runtimeLibrary + llndkLibrarySuffix
|
runtimeLibrary = runtimeLibrary + llndkLibrarySuffix
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -963,7 +963,7 @@ func sanitizerMutator(t sanitizerType) func(android.BottomUpMutatorContext) {
|
|||||||
if t == cfi {
|
if t == cfi {
|
||||||
appendStringSync(c.Name(), cfiStaticLibs(mctx.Config()), &cfiStaticLibsMutex)
|
appendStringSync(c.Name(), cfiStaticLibs(mctx.Config()), &cfiStaticLibsMutex)
|
||||||
} else if t == hwasan {
|
} else if t == hwasan {
|
||||||
if c.useVndk() {
|
if c.UseVndk() {
|
||||||
appendStringSync(c.Name(), hwasanVendorStaticLibs(mctx.Config()),
|
appendStringSync(c.Name(), hwasanVendorStaticLibs(mctx.Config()),
|
||||||
&hwasanStaticLibsMutex)
|
&hwasanStaticLibsMutex)
|
||||||
} else {
|
} else {
|
||||||
|
@@ -20,13 +20,13 @@ import (
|
|||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
func getNdkStlFamily(m *Module) string {
|
func getNdkStlFamily(m LinkableInterface) string {
|
||||||
family, _ := getNdkStlFamilyAndLinkType(m)
|
family, _ := getNdkStlFamilyAndLinkType(m)
|
||||||
return family
|
return family
|
||||||
}
|
}
|
||||||
|
|
||||||
func getNdkStlFamilyAndLinkType(m *Module) (string, string) {
|
func getNdkStlFamilyAndLinkType(m LinkableInterface) (string, string) {
|
||||||
stl := m.stl.Properties.SelectedStl
|
stl := m.SelectedStl()
|
||||||
switch stl {
|
switch stl {
|
||||||
case "ndk_libc++_shared":
|
case "ndk_libc++_shared":
|
||||||
return "libc++", "shared"
|
return "libc++", "shared"
|
||||||
|
10
cc/vndk.go
10
cc/vndk.go
@@ -125,7 +125,7 @@ func (vndk *vndkdep) vndkCheckLinkType(ctx android.ModuleContext, to *Module, ta
|
|||||||
// Other (static and LL-NDK) libraries are allowed to link.
|
// Other (static and LL-NDK) libraries are allowed to link.
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if !to.useVndk() {
|
if !to.UseVndk() {
|
||||||
ctx.ModuleErrorf("(%s) should not link to %q which is not a vendor-available library",
|
ctx.ModuleErrorf("(%s) should not link to %q which is not a vendor-available library",
|
||||||
vndk.typeName(), to.Name())
|
vndk.typeName(), to.Name())
|
||||||
return
|
return
|
||||||
@@ -352,7 +352,7 @@ func IsForVndkApex(mctx android.BottomUpMutatorContext, m *Module) bool {
|
|||||||
useCoreVariant := m.vndkVersion() == mctx.DeviceConfig().PlatformVndkVersion() &&
|
useCoreVariant := m.vndkVersion() == mctx.DeviceConfig().PlatformVndkVersion() &&
|
||||||
mctx.DeviceConfig().VndkUseCoreVariant() &&
|
mctx.DeviceConfig().VndkUseCoreVariant() &&
|
||||||
!inList(m.BaseModuleName(), config.VndkMustUseVendorVariantList)
|
!inList(m.BaseModuleName(), config.VndkMustUseVendorVariantList)
|
||||||
return lib.shared() && m.useVndk() && m.isVndk() && !m.isVndkExt() && !useCoreVariant
|
return lib.shared() && m.UseVndk() && m.IsVndk() && !m.isVndkExt() && !useCoreVariant
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
@@ -536,7 +536,7 @@ func (c *vndkSnapshotSingleton) GenerateBuildActions(ctx android.SingletonContex
|
|||||||
if m.Target().NativeBridge == android.NativeBridgeEnabled {
|
if m.Target().NativeBridge == android.NativeBridgeEnabled {
|
||||||
return nil, "", false
|
return nil, "", false
|
||||||
}
|
}
|
||||||
if !m.useVndk() || !m.IsForPlatform() || !m.installable() {
|
if !m.UseVndk() || !m.IsForPlatform() || !m.installable() {
|
||||||
return nil, "", false
|
return nil, "", false
|
||||||
}
|
}
|
||||||
l, ok := m.linker.(vndkSnapshotLibraryInterface)
|
l, ok := m.linker.(vndkSnapshotLibraryInterface)
|
||||||
@@ -699,7 +699,7 @@ func (c *vndkSnapshotSingleton) buildVndkLibrariesTxtFiles(ctx android.Singleton
|
|||||||
if c.isVndkPrivate(config) {
|
if c.isVndkPrivate(config) {
|
||||||
vndkprivate = append(vndkprivate, filename)
|
vndkprivate = append(vndkprivate, filename)
|
||||||
}
|
}
|
||||||
} else if c.vndkVersion() == vndkVersion && c.isVndk() && !c.isVndkExt() {
|
} else if c.vndkVersion() == vndkVersion && c.IsVndk() && !c.isVndkExt() {
|
||||||
if c.isVndkSp() {
|
if c.isVndkSp() {
|
||||||
vndksp = append(vndksp, filename)
|
vndksp = append(vndksp, filename)
|
||||||
} else {
|
} else {
|
||||||
@@ -708,7 +708,7 @@ func (c *vndkSnapshotSingleton) buildVndkLibrariesTxtFiles(ctx android.Singleton
|
|||||||
if c.isVndkPrivate(config) {
|
if c.isVndkPrivate(config) {
|
||||||
vndkprivate = append(vndkprivate, filename)
|
vndkprivate = append(vndkprivate, filename)
|
||||||
}
|
}
|
||||||
if ctx.DeviceConfig().VndkUseCoreVariant() && !c.mustUseVendorVariant() {
|
if ctx.DeviceConfig().VndkUseCoreVariant() && !c.MustUseVendorVariant() {
|
||||||
vndkcorevariant = append(vndkcorevariant, filename)
|
vndkcorevariant = append(vndkcorevariant, filename)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -92,7 +92,12 @@ func (library *libraryDecorator) AndroidMk(ctx AndroidMkContext, ret *android.An
|
|||||||
ret.Class = "RLIB_LIBRARIES"
|
ret.Class = "RLIB_LIBRARIES"
|
||||||
} else if library.dylib() {
|
} else if library.dylib() {
|
||||||
ret.Class = "DYLIB_LIBRARIES"
|
ret.Class = "DYLIB_LIBRARIES"
|
||||||
|
} else if library.static() {
|
||||||
|
ret.Class = "STATIC_LIBRARIES"
|
||||||
|
} else if library.shared() {
|
||||||
|
ret.Class = "SHARED_LIBRARIES"
|
||||||
}
|
}
|
||||||
|
|
||||||
ret.DistFile = library.distFile
|
ret.DistFile = library.distFile
|
||||||
ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) {
|
ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) {
|
||||||
if !library.rlib() {
|
if !library.rlib() {
|
||||||
|
@@ -53,6 +53,14 @@ func TransformSrctoDylib(ctx android.ModuleContext, mainSrc android.Path, deps P
|
|||||||
transformSrctoCrate(ctx, mainSrc, deps.RLibs, deps.DyLibs, deps.ProcMacros, deps.StaticLibs, deps.SharedLibs, deps.CrtBegin, deps.CrtEnd, flags, outputFile, "dylib", includeDirs)
|
transformSrctoCrate(ctx, mainSrc, deps.RLibs, deps.DyLibs, deps.ProcMacros, deps.StaticLibs, deps.SharedLibs, deps.CrtBegin, deps.CrtEnd, flags, outputFile, "dylib", includeDirs)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TransformSrctoStatic(ctx android.ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags, outputFile android.WritablePath, includeDirs []string) {
|
||||||
|
transformSrctoCrate(ctx, mainSrc, deps.RLibs, deps.DyLibs, deps.ProcMacros, deps.StaticLibs, deps.SharedLibs, deps.CrtBegin, deps.CrtEnd, flags, outputFile, "staticlib", includeDirs)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TransformSrctoShared(ctx android.ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags, outputFile android.WritablePath, includeDirs []string) {
|
||||||
|
transformSrctoCrate(ctx, mainSrc, deps.RLibs, deps.DyLibs, deps.ProcMacros, deps.StaticLibs, deps.SharedLibs, deps.CrtBegin, deps.CrtEnd, flags, outputFile, "cdylib", includeDirs)
|
||||||
|
}
|
||||||
|
|
||||||
func TransformSrctoProcMacro(ctx android.ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags, outputFile android.WritablePath, includeDirs []string) {
|
func TransformSrctoProcMacro(ctx android.ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags, outputFile android.WritablePath, includeDirs []string) {
|
||||||
transformSrctoCrate(ctx, mainSrc, deps.RLibs, deps.DyLibs, deps.ProcMacros, deps.StaticLibs, deps.SharedLibs, deps.CrtBegin, deps.CrtEnd, flags, outputFile, "proc-macro", includeDirs)
|
transformSrctoCrate(ctx, mainSrc, deps.RLibs, deps.DyLibs, deps.ProcMacros, deps.StaticLibs, deps.SharedLibs, deps.CrtBegin, deps.CrtEnd, flags, outputFile, "proc-macro", includeDirs)
|
||||||
}
|
}
|
||||||
|
@@ -95,7 +95,7 @@ func (toolchainBase) RlibSuffix() string {
|
|||||||
return ".rlib"
|
return ".rlib"
|
||||||
}
|
}
|
||||||
func (toolchainBase) DylibSuffix() string {
|
func (toolchainBase) DylibSuffix() string {
|
||||||
return ".so"
|
return ".dylib.so"
|
||||||
}
|
}
|
||||||
|
|
||||||
func (toolchainBase) ProcMacroSuffix() string {
|
func (toolchainBase) ProcMacroSuffix() string {
|
||||||
|
184
rust/library.go
184
rust/library.go
@@ -25,8 +25,10 @@ func init() {
|
|||||||
android.RegisterModuleType("rust_library_host", RustLibraryHostFactory)
|
android.RegisterModuleType("rust_library_host", RustLibraryHostFactory)
|
||||||
android.RegisterModuleType("rust_library_host_dylib", RustLibraryDylibHostFactory)
|
android.RegisterModuleType("rust_library_host_dylib", RustLibraryDylibHostFactory)
|
||||||
android.RegisterModuleType("rust_library_host_rlib", RustLibraryRlibHostFactory)
|
android.RegisterModuleType("rust_library_host_rlib", RustLibraryRlibHostFactory)
|
||||||
|
android.RegisterModuleType("rust_library_shared", RustLibrarySharedFactory)
|
||||||
//TODO: Add support for generating standard shared/static libraries.
|
android.RegisterModuleType("rust_library_static", RustLibraryStaticFactory)
|
||||||
|
android.RegisterModuleType("rust_library_host_shared", RustLibrarySharedHostFactory)
|
||||||
|
android.RegisterModuleType("rust_library_host_static", RustLibraryStaticHostFactory)
|
||||||
}
|
}
|
||||||
|
|
||||||
type VariantLibraryProperties struct {
|
type VariantLibraryProperties struct {
|
||||||
@@ -34,25 +36,36 @@ type VariantLibraryProperties struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type LibraryCompilerProperties struct {
|
type LibraryCompilerProperties struct {
|
||||||
Rlib VariantLibraryProperties `android:"arch_variant"`
|
Rlib VariantLibraryProperties `android:"arch_variant"`
|
||||||
Dylib VariantLibraryProperties `android:"arch_variant"`
|
Dylib VariantLibraryProperties `android:"arch_variant"`
|
||||||
|
Shared VariantLibraryProperties `android:"arch_variant"`
|
||||||
|
Static VariantLibraryProperties `android:"arch_variant"`
|
||||||
|
|
||||||
// path to the source file that is the main entry point of the program (e.g. src/lib.rs)
|
// path to the source file that is the main entry point of the program (e.g. src/lib.rs)
|
||||||
Srcs []string `android:"path,arch_variant"`
|
Srcs []string `android:"path,arch_variant"`
|
||||||
|
|
||||||
|
// path to include directories to pass to cc_* modules, only relevant for static/shared variants.
|
||||||
|
Include_dirs []string `android:"path,arch_variant"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type LibraryMutatedProperties struct {
|
type LibraryMutatedProperties struct {
|
||||||
VariantName string `blueprint:"mutated"`
|
|
||||||
|
|
||||||
// Build a dylib variant
|
// Build a dylib variant
|
||||||
BuildDylib bool `blueprint:"mutated"`
|
BuildDylib bool `blueprint:"mutated"`
|
||||||
// Build an rlib variant
|
// Build an rlib variant
|
||||||
BuildRlib bool `blueprint:"mutated"`
|
BuildRlib bool `blueprint:"mutated"`
|
||||||
|
// Build a shared library variant
|
||||||
|
BuildShared bool `blueprint:"mutated"`
|
||||||
|
// Build a static library variant
|
||||||
|
BuildStatic bool `blueprint:"mutated"`
|
||||||
|
|
||||||
// This variant is a dylib
|
// This variant is a dylib
|
||||||
VariantIsDylib bool `blueprint:"mutated"`
|
VariantIsDylib bool `blueprint:"mutated"`
|
||||||
// This variant is an rlib
|
// This variant is an rlib
|
||||||
VariantIsRlib bool `blueprint:"mutated"`
|
VariantIsRlib bool `blueprint:"mutated"`
|
||||||
|
// This variant is a shared library
|
||||||
|
VariantIsShared bool `blueprint:"mutated"`
|
||||||
|
// This variant is a static library
|
||||||
|
VariantIsStatic bool `blueprint:"mutated"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type libraryDecorator struct {
|
type libraryDecorator struct {
|
||||||
@@ -67,14 +80,26 @@ type libraryDecorator struct {
|
|||||||
type libraryInterface interface {
|
type libraryInterface interface {
|
||||||
rlib() bool
|
rlib() bool
|
||||||
dylib() bool
|
dylib() bool
|
||||||
|
static() bool
|
||||||
|
shared() bool
|
||||||
|
|
||||||
// Returns true if the build options for the module have selected a particular build type
|
// Returns true if the build options for the module have selected a particular build type
|
||||||
buildRlib() bool
|
buildRlib() bool
|
||||||
buildDylib() bool
|
buildDylib() bool
|
||||||
|
buildShared() bool
|
||||||
|
buildStatic() bool
|
||||||
|
|
||||||
// Sets a particular variant type
|
// Sets a particular variant type
|
||||||
setRlib()
|
setRlib()
|
||||||
setDylib()
|
setDylib()
|
||||||
|
setShared()
|
||||||
|
setStatic()
|
||||||
|
|
||||||
|
// Build a specific library variant
|
||||||
|
BuildOnlyRlib()
|
||||||
|
BuildOnlyDylib()
|
||||||
|
BuildOnlyStatic()
|
||||||
|
BuildOnlyShared()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) exportedDirs() []string {
|
func (library *libraryDecorator) exportedDirs() []string {
|
||||||
@@ -101,6 +126,14 @@ func (library *libraryDecorator) dylib() bool {
|
|||||||
return library.MutatedProperties.VariantIsDylib
|
return library.MutatedProperties.VariantIsDylib
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) shared() bool {
|
||||||
|
return library.MutatedProperties.VariantIsShared
|
||||||
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) static() bool {
|
||||||
|
return library.MutatedProperties.VariantIsStatic
|
||||||
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) buildRlib() bool {
|
func (library *libraryDecorator) buildRlib() bool {
|
||||||
return library.MutatedProperties.BuildRlib && BoolDefault(library.Properties.Rlib.Enabled, true)
|
return library.MutatedProperties.BuildRlib && BoolDefault(library.Properties.Rlib.Enabled, true)
|
||||||
}
|
}
|
||||||
@@ -109,17 +142,44 @@ func (library *libraryDecorator) buildDylib() bool {
|
|||||||
return library.MutatedProperties.BuildDylib && BoolDefault(library.Properties.Dylib.Enabled, true)
|
return library.MutatedProperties.BuildDylib && BoolDefault(library.Properties.Dylib.Enabled, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) buildShared() bool {
|
||||||
|
return library.MutatedProperties.BuildShared && BoolDefault(library.Properties.Shared.Enabled, true)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) buildStatic() bool {
|
||||||
|
return library.MutatedProperties.BuildStatic && BoolDefault(library.Properties.Static.Enabled, true)
|
||||||
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) setRlib() {
|
func (library *libraryDecorator) setRlib() {
|
||||||
library.MutatedProperties.VariantIsRlib = true
|
library.MutatedProperties.VariantIsRlib = true
|
||||||
library.MutatedProperties.VariantIsDylib = false
|
library.MutatedProperties.VariantIsDylib = false
|
||||||
|
library.MutatedProperties.VariantIsStatic = false
|
||||||
|
library.MutatedProperties.VariantIsShared = false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) setDylib() {
|
func (library *libraryDecorator) setDylib() {
|
||||||
library.MutatedProperties.VariantIsRlib = false
|
library.MutatedProperties.VariantIsRlib = false
|
||||||
library.MutatedProperties.VariantIsDylib = true
|
library.MutatedProperties.VariantIsDylib = true
|
||||||
|
library.MutatedProperties.VariantIsStatic = false
|
||||||
|
library.MutatedProperties.VariantIsShared = false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) setShared() {
|
||||||
|
library.MutatedProperties.VariantIsStatic = false
|
||||||
|
library.MutatedProperties.VariantIsShared = true
|
||||||
|
library.MutatedProperties.VariantIsRlib = false
|
||||||
|
library.MutatedProperties.VariantIsDylib = false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) setStatic() {
|
||||||
|
library.MutatedProperties.VariantIsStatic = true
|
||||||
|
library.MutatedProperties.VariantIsShared = false
|
||||||
|
library.MutatedProperties.VariantIsRlib = false
|
||||||
|
library.MutatedProperties.VariantIsDylib = false
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ compiler = (*libraryDecorator)(nil)
|
var _ compiler = (*libraryDecorator)(nil)
|
||||||
|
var _ libraryInterface = (*libraryDecorator)(nil)
|
||||||
|
|
||||||
// rust_library produces all variants.
|
// rust_library produces all variants.
|
||||||
func RustLibraryFactory() android.Module {
|
func RustLibraryFactory() android.Module {
|
||||||
@@ -141,6 +201,20 @@ func RustLibraryRlibFactory() android.Module {
|
|||||||
return module.Init()
|
return module.Init()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// rust_library_shared produces a shared library.
|
||||||
|
func RustLibrarySharedFactory() android.Module {
|
||||||
|
module, library := NewRustLibrary(android.HostAndDeviceSupported)
|
||||||
|
library.BuildOnlyShared()
|
||||||
|
return module.Init()
|
||||||
|
}
|
||||||
|
|
||||||
|
// rust_library_static produces a static library.
|
||||||
|
func RustLibraryStaticFactory() android.Module {
|
||||||
|
module, library := NewRustLibrary(android.HostAndDeviceSupported)
|
||||||
|
library.BuildOnlyStatic()
|
||||||
|
return module.Init()
|
||||||
|
}
|
||||||
|
|
||||||
// rust_library_host produces all variants.
|
// rust_library_host produces all variants.
|
||||||
func RustLibraryHostFactory() android.Module {
|
func RustLibraryHostFactory() android.Module {
|
||||||
module, _ := NewRustLibrary(android.HostSupported)
|
module, _ := NewRustLibrary(android.HostSupported)
|
||||||
@@ -161,12 +235,44 @@ func RustLibraryRlibHostFactory() android.Module {
|
|||||||
return module.Init()
|
return module.Init()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// rust_library_static_host produces a static library.
|
||||||
|
func RustLibraryStaticHostFactory() android.Module {
|
||||||
|
module, library := NewRustLibrary(android.HostSupported)
|
||||||
|
library.BuildOnlyStatic()
|
||||||
|
return module.Init()
|
||||||
|
}
|
||||||
|
|
||||||
|
// rust_library_shared_host produces an shared library.
|
||||||
|
func RustLibrarySharedHostFactory() android.Module {
|
||||||
|
module, library := NewRustLibrary(android.HostSupported)
|
||||||
|
library.BuildOnlyShared()
|
||||||
|
return module.Init()
|
||||||
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) BuildOnlyDylib() {
|
func (library *libraryDecorator) BuildOnlyDylib() {
|
||||||
library.MutatedProperties.BuildRlib = false
|
library.MutatedProperties.BuildRlib = false
|
||||||
|
library.MutatedProperties.BuildShared = false
|
||||||
|
library.MutatedProperties.BuildStatic = false
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) BuildOnlyRlib() {
|
func (library *libraryDecorator) BuildOnlyRlib() {
|
||||||
library.MutatedProperties.BuildDylib = false
|
library.MutatedProperties.BuildDylib = false
|
||||||
|
library.MutatedProperties.BuildShared = false
|
||||||
|
library.MutatedProperties.BuildStatic = false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) BuildOnlyStatic() {
|
||||||
|
library.MutatedProperties.BuildShared = false
|
||||||
|
library.MutatedProperties.BuildRlib = false
|
||||||
|
library.MutatedProperties.BuildDylib = false
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func (library *libraryDecorator) BuildOnlyShared() {
|
||||||
|
library.MutatedProperties.BuildStatic = false
|
||||||
|
library.MutatedProperties.BuildRlib = false
|
||||||
|
library.MutatedProperties.BuildDylib = false
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewRustLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
|
func NewRustLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
|
||||||
@@ -174,8 +280,10 @@ func NewRustLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorat
|
|||||||
|
|
||||||
library := &libraryDecorator{
|
library := &libraryDecorator{
|
||||||
MutatedProperties: LibraryMutatedProperties{
|
MutatedProperties: LibraryMutatedProperties{
|
||||||
BuildDylib: true,
|
BuildDylib: true,
|
||||||
BuildRlib: true,
|
BuildRlib: true,
|
||||||
|
BuildShared: true,
|
||||||
|
BuildStatic: true,
|
||||||
},
|
},
|
||||||
baseCompiler: NewBaseCompiler("lib", "lib64"),
|
baseCompiler: NewBaseCompiler("lib", "lib64"),
|
||||||
}
|
}
|
||||||
@@ -194,7 +302,7 @@ func (library *libraryDecorator) compilerProps() []interface{} {
|
|||||||
func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
|
func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
|
||||||
deps = library.baseCompiler.compilerDeps(ctx, deps)
|
deps = library.baseCompiler.compilerDeps(ctx, deps)
|
||||||
|
|
||||||
if ctx.toolchain().Bionic() && library.dylib() {
|
if ctx.toolchain().Bionic() && (library.dylib() || library.shared()) {
|
||||||
deps = library.baseCompiler.bionicDeps(ctx, deps)
|
deps = library.baseCompiler.bionicDeps(ctx, deps)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -208,6 +316,13 @@ func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps Pa
|
|||||||
|
|
||||||
flags.RustFlags = append(flags.RustFlags, deps.depFlags...)
|
flags.RustFlags = append(flags.RustFlags, deps.depFlags...)
|
||||||
|
|
||||||
|
if library.dylib() || library.shared() {
|
||||||
|
// We need prefer-dynamic for now to avoid linking in the static stdlib. See:
|
||||||
|
// https://github.com/rust-lang/rust/issues/19680
|
||||||
|
// https://github.com/rust-lang/rust/issues/34909
|
||||||
|
flags.RustFlags = append(flags.RustFlags, "-C prefer-dynamic")
|
||||||
|
}
|
||||||
|
|
||||||
if library.rlib() {
|
if library.rlib() {
|
||||||
fileName := library.getStem(ctx) + ctx.toolchain().RlibSuffix()
|
fileName := library.getStem(ctx) + ctx.toolchain().RlibSuffix()
|
||||||
outputFile = android.PathForModuleOut(ctx, fileName)
|
outputFile = android.PathForModuleOut(ctx, fileName)
|
||||||
@@ -217,16 +332,23 @@ func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps Pa
|
|||||||
fileName := library.getStem(ctx) + ctx.toolchain().DylibSuffix()
|
fileName := library.getStem(ctx) + ctx.toolchain().DylibSuffix()
|
||||||
outputFile = android.PathForModuleOut(ctx, fileName)
|
outputFile = android.PathForModuleOut(ctx, fileName)
|
||||||
|
|
||||||
// We need prefer-dynamic for now to avoid linking in the static stdlib. See:
|
|
||||||
// https://github.com/rust-lang/rust/issues/19680
|
|
||||||
// https://github.com/rust-lang/rust/issues/34909
|
|
||||||
flags.RustFlags = append(flags.RustFlags, "-C prefer-dynamic")
|
|
||||||
|
|
||||||
TransformSrctoDylib(ctx, srcPath, deps, flags, outputFile, deps.linkDirs)
|
TransformSrctoDylib(ctx, srcPath, deps, flags, outputFile, deps.linkDirs)
|
||||||
|
} else if library.static() {
|
||||||
|
fileName := library.getStem(ctx) + ctx.toolchain().StaticLibSuffix()
|
||||||
|
outputFile = android.PathForModuleOut(ctx, fileName)
|
||||||
|
|
||||||
|
TransformSrctoStatic(ctx, srcPath, deps, flags, outputFile, deps.linkDirs)
|
||||||
|
} else if library.shared() {
|
||||||
|
fileName := library.getStem(ctx) + ctx.toolchain().SharedLibSuffix()
|
||||||
|
outputFile = android.PathForModuleOut(ctx, fileName)
|
||||||
|
|
||||||
|
TransformSrctoShared(ctx, srcPath, deps, flags, outputFile, deps.linkDirs)
|
||||||
}
|
}
|
||||||
|
|
||||||
library.reexportDirs(deps.linkDirs...)
|
if library.rlib() || library.dylib() {
|
||||||
library.reexportDepFlags(deps.depFlags...)
|
library.reexportDirs(deps.linkDirs...)
|
||||||
|
library.reexportDepFlags(deps.depFlags...)
|
||||||
|
}
|
||||||
library.unstrippedOutputFile = outputFile
|
library.unstrippedOutputFile = outputFile
|
||||||
|
|
||||||
return outputFile
|
return outputFile
|
||||||
@@ -236,19 +358,25 @@ func LibraryMutator(mctx android.BottomUpMutatorContext) {
|
|||||||
if m, ok := mctx.Module().(*Module); ok && m.compiler != nil {
|
if m, ok := mctx.Module().(*Module); ok && m.compiler != nil {
|
||||||
switch library := m.compiler.(type) {
|
switch library := m.compiler.(type) {
|
||||||
case libraryInterface:
|
case libraryInterface:
|
||||||
if library.buildRlib() && library.buildDylib() {
|
|
||||||
modules := mctx.CreateLocalVariations("rlib", "dylib")
|
|
||||||
rlib := modules[0].(*Module)
|
|
||||||
dylib := modules[1].(*Module)
|
|
||||||
|
|
||||||
rlib.compiler.(libraryInterface).setRlib()
|
// We only build the rust library variants here. This assumes that
|
||||||
dylib.compiler.(libraryInterface).setDylib()
|
// LinkageMutator runs first and there's an empty variant
|
||||||
} else if library.buildRlib() {
|
// if rust variants are required.
|
||||||
modules := mctx.CreateLocalVariations("rlib")
|
if !library.static() && !library.shared() {
|
||||||
modules[0].(*Module).compiler.(libraryInterface).setRlib()
|
if library.buildRlib() && library.buildDylib() {
|
||||||
} else if library.buildDylib() {
|
modules := mctx.CreateLocalVariations("rlib", "dylib")
|
||||||
modules := mctx.CreateLocalVariations("dylib")
|
rlib := modules[0].(*Module)
|
||||||
modules[0].(*Module).compiler.(libraryInterface).setDylib()
|
dylib := modules[1].(*Module)
|
||||||
|
|
||||||
|
rlib.compiler.(libraryInterface).setRlib()
|
||||||
|
dylib.compiler.(libraryInterface).setDylib()
|
||||||
|
} else if library.buildRlib() {
|
||||||
|
modules := mctx.CreateLocalVariations("rlib")
|
||||||
|
modules[0].(*Module).compiler.(libraryInterface).setRlib()
|
||||||
|
} else if library.buildDylib() {
|
||||||
|
modules := mctx.CreateLocalVariations("dylib")
|
||||||
|
modules[0].(*Module).compiler.(libraryInterface).setDylib()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -29,19 +29,37 @@ func TestLibraryVariants(t *testing.T) {
|
|||||||
crate_name: "foo",
|
crate_name: "foo",
|
||||||
}`)
|
}`)
|
||||||
|
|
||||||
// Test both variants are being built.
|
// Test all variants are being built.
|
||||||
libfooRlib := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_rlib").Output("libfoo.rlib")
|
libfooRlib := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_rlib").Output("libfoo.rlib")
|
||||||
libfooDylib := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_dylib").Output("libfoo.so")
|
libfooDylib := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_dylib").Output("libfoo.dylib.so")
|
||||||
|
libfooStatic := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_static").Output("libfoo.a")
|
||||||
|
libfooShared := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_shared").Output("libfoo.so")
|
||||||
|
|
||||||
|
rlibCrateType := "rlib"
|
||||||
|
dylibCrateType := "dylib"
|
||||||
|
sharedCrateType := "cdylib"
|
||||||
|
staticCrateType := "static"
|
||||||
|
|
||||||
// Test crate type for rlib is correct.
|
// Test crate type for rlib is correct.
|
||||||
if !strings.Contains(libfooRlib.Args["rustcFlags"], "crate-type=rlib") {
|
if !strings.Contains(libfooRlib.Args["rustcFlags"], "crate-type="+rlibCrateType) {
|
||||||
t.Errorf("missing crate-type for libfoo rlib, rustcFlags: %#v", libfooRlib.Args["rustcFlags"])
|
t.Errorf("missing crate-type for static variant, expecting %#v, rustcFlags: %#v", rlibCrateType, libfooRlib.Args["rustcFlags"])
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test crate type for dylib is correct.
|
// Test crate type for dylib is correct.
|
||||||
if !strings.Contains(libfooDylib.Args["rustcFlags"], "crate-type=dylib") {
|
if !strings.Contains(libfooDylib.Args["rustcFlags"], "crate-type="+dylibCrateType) {
|
||||||
t.Errorf("missing crate-type for libfoo dylib, rustcFlags: %#v", libfooDylib.Args["rustcFlags"])
|
t.Errorf("missing crate-type for static variant, expecting %#v, rustcFlags: %#v", dylibCrateType, libfooDylib.Args["rustcFlags"])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Test crate type for C static libraries is correct.
|
||||||
|
if !strings.Contains(libfooStatic.Args["rustcFlags"], "crate-type="+staticCrateType) {
|
||||||
|
t.Errorf("missing crate-type for static variant, expecting %#v, rustcFlags: %#v", staticCrateType, libfooStatic.Args["rustcFlags"])
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test crate type for C shared libraries is correct.
|
||||||
|
if !strings.Contains(libfooShared.Args["rustcFlags"], "crate-type="+sharedCrateType) {
|
||||||
|
t.Errorf("missing crate-type for shared variant, expecting %#v, got rustcFlags: %#v", sharedCrateType, libfooShared.Args["rustcFlags"])
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test that dylibs are not statically linking the standard library.
|
// Test that dylibs are not statically linking the standard library.
|
||||||
@@ -53,7 +71,7 @@ func TestDylibPreferDynamic(t *testing.T) {
|
|||||||
crate_name: "foo",
|
crate_name: "foo",
|
||||||
}`)
|
}`)
|
||||||
|
|
||||||
libfooDylib := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_dylib").Output("libfoo.so")
|
libfooDylib := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_dylib").Output("libfoo.dylib.so")
|
||||||
|
|
||||||
if !strings.Contains(libfooDylib.Args["rustcFlags"], "prefer-dynamic") {
|
if !strings.Contains(libfooDylib.Args["rustcFlags"], "prefer-dynamic") {
|
||||||
t.Errorf("missing prefer-dynamic flag for libfoo dylib, rustcFlags: %#v", libfooDylib.Args["rustcFlags"])
|
t.Errorf("missing prefer-dynamic flag for libfoo dylib, rustcFlags: %#v", libfooDylib.Args["rustcFlags"])
|
||||||
|
172
rust/rust.go
172
rust/rust.go
@@ -75,6 +75,85 @@ type Module struct {
|
|||||||
outputFile android.OptionalPath
|
outputFile android.OptionalPath
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (mod *Module) BuildStubs() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) HasStubsVariants() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) SelectedStl() string {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) ApiLevel() string {
|
||||||
|
panic(fmt.Errorf("Called ApiLevel on Rust module %q; stubs libraries are not yet supported.", mod.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) Static() bool {
|
||||||
|
if mod.compiler != nil {
|
||||||
|
if library, ok := mod.compiler.(libraryInterface); ok {
|
||||||
|
return library.static()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("Static called on non-library module: %q", mod.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) Shared() bool {
|
||||||
|
if mod.compiler != nil {
|
||||||
|
if library, ok := mod.compiler.(libraryInterface); ok {
|
||||||
|
return library.static()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("Shared called on non-library module: %q", mod.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) Toc() android.OptionalPath {
|
||||||
|
if mod.compiler != nil {
|
||||||
|
if _, ok := mod.compiler.(libraryInterface); ok {
|
||||||
|
return android.OptionalPath{}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic(fmt.Errorf("Toc() called on non-library module: %q", mod.BaseModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) OnlyInRecovery() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) UseVndk() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) MustUseVendorVariant() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) IsVndk() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) HasVendorVariant() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) SdkVersion() string {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) ToolchainLibrary() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) NdkPrebuiltStl() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mod *Module) StubDecorator() bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
type Deps struct {
|
type Deps struct {
|
||||||
Dylibs []string
|
Dylibs []string
|
||||||
Rlibs []string
|
Rlibs []string
|
||||||
@@ -169,11 +248,10 @@ func (mod *Module) CcLibraryInterface() bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (mod *Module) IncludeDirs() android.Paths {
|
func (mod *Module) IncludeDirs(ctx android.BaseModuleContext) android.Paths {
|
||||||
if mod.compiler != nil {
|
if mod.compiler != nil {
|
||||||
if _, ok := mod.compiler.(*libraryDecorator); ok {
|
if library, ok := mod.compiler.(*libraryDecorator); ok {
|
||||||
//TODO add Include_dirs to libraryDecorator for C libraries.
|
return android.PathsForSource(ctx, library.Properties.Include_dirs)
|
||||||
return android.Paths{}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
panic(fmt.Errorf("IncludeDirs called on non-library module: %q", mod.BaseModuleName()))
|
panic(fmt.Errorf("IncludeDirs called on non-library module: %q", mod.BaseModuleName()))
|
||||||
@@ -181,8 +259,8 @@ func (mod *Module) IncludeDirs() android.Paths {
|
|||||||
|
|
||||||
func (mod *Module) SetStatic() {
|
func (mod *Module) SetStatic() {
|
||||||
if mod.compiler != nil {
|
if mod.compiler != nil {
|
||||||
if _, ok := mod.compiler.(*libraryDecorator); ok {
|
if library, ok := mod.compiler.(libraryInterface); ok {
|
||||||
//TODO add support for static variants.
|
library.setStatic()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -191,8 +269,8 @@ func (mod *Module) SetStatic() {
|
|||||||
|
|
||||||
func (mod *Module) SetShared() {
|
func (mod *Module) SetShared() {
|
||||||
if mod.compiler != nil {
|
if mod.compiler != nil {
|
||||||
if _, ok := mod.compiler.(*libraryDecorator); ok {
|
if library, ok := mod.compiler.(libraryInterface); ok {
|
||||||
//TODO add support for shared variants.
|
library.setShared()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -209,9 +287,8 @@ func (mod *Module) SetStubsVersions(string) {
|
|||||||
|
|
||||||
func (mod *Module) BuildStaticVariant() bool {
|
func (mod *Module) BuildStaticVariant() bool {
|
||||||
if mod.compiler != nil {
|
if mod.compiler != nil {
|
||||||
if _, ok := mod.compiler.(*libraryDecorator); ok {
|
if library, ok := mod.compiler.(libraryInterface); ok {
|
||||||
//TODO add support for static variants.
|
return library.buildStatic()
|
||||||
return false
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
panic(fmt.Errorf("BuildStaticVariant called on non-library module: %q", mod.BaseModuleName()))
|
panic(fmt.Errorf("BuildStaticVariant called on non-library module: %q", mod.BaseModuleName()))
|
||||||
@@ -219,9 +296,8 @@ func (mod *Module) BuildStaticVariant() bool {
|
|||||||
|
|
||||||
func (mod *Module) BuildSharedVariant() bool {
|
func (mod *Module) BuildSharedVariant() bool {
|
||||||
if mod.compiler != nil {
|
if mod.compiler != nil {
|
||||||
if _, ok := mod.compiler.(*libraryDecorator); ok {
|
if library, ok := mod.compiler.(libraryInterface); ok {
|
||||||
//TODO add support for shared variants.
|
return library.buildShared()
|
||||||
return false
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
panic(fmt.Errorf("BuildSharedVariant called on non-library module: %q", mod.BaseModuleName()))
|
panic(fmt.Errorf("BuildSharedVariant called on non-library module: %q", mod.BaseModuleName()))
|
||||||
@@ -430,13 +506,12 @@ func (mod *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
directRlibDeps := []*Module{}
|
directRlibDeps := []*Module{}
|
||||||
directDylibDeps := []*Module{}
|
directDylibDeps := []*Module{}
|
||||||
directProcMacroDeps := []*Module{}
|
directProcMacroDeps := []*Module{}
|
||||||
directSharedLibDeps := []*(cc.Module){}
|
directSharedLibDeps := [](cc.LinkableInterface){}
|
||||||
directStaticLibDeps := []*(cc.Module){}
|
directStaticLibDeps := [](cc.LinkableInterface){}
|
||||||
|
|
||||||
ctx.VisitDirectDeps(func(dep android.Module) {
|
ctx.VisitDirectDeps(func(dep android.Module) {
|
||||||
depName := ctx.OtherModuleName(dep)
|
depName := ctx.OtherModuleName(dep)
|
||||||
depTag := ctx.OtherModuleDependencyTag(dep)
|
depTag := ctx.OtherModuleDependencyTag(dep)
|
||||||
|
|
||||||
if rustDep, ok := dep.(*Module); ok {
|
if rustDep, ok := dep.(*Module); ok {
|
||||||
//Handle Rust Modules
|
//Handle Rust Modules
|
||||||
|
|
||||||
@@ -484,16 +559,19 @@ func (mod *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if ccDep, ok := dep.(*cc.Module); ok {
|
}
|
||||||
//Handle C dependencies
|
|
||||||
|
|
||||||
if ccDep.Target().Os != ctx.Os() {
|
if ccDep, ok := dep.(cc.LinkableInterface); ok {
|
||||||
ctx.ModuleErrorf("OS mismatch between %q and %q", ctx.ModuleName(), depName)
|
//Handle C dependencies
|
||||||
return
|
if _, ok := ccDep.(*Module); !ok {
|
||||||
}
|
if ccDep.Module().Target().Os != ctx.Os() {
|
||||||
if ccDep.Target().Arch.ArchType != ctx.Arch().ArchType {
|
ctx.ModuleErrorf("OS mismatch between %q and %q", ctx.ModuleName(), depName)
|
||||||
ctx.ModuleErrorf("Arch mismatch between %q and %q", ctx.ModuleName(), depName)
|
return
|
||||||
return
|
}
|
||||||
|
if ccDep.Module().Target().Arch.ArchType != ctx.Arch().ArchType {
|
||||||
|
ctx.ModuleErrorf("Arch mismatch between %q and %q", ctx.ModuleName(), depName)
|
||||||
|
return
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
linkFile := ccDep.OutputFile()
|
linkFile := ccDep.OutputFile()
|
||||||
@@ -524,7 +602,7 @@ func (mod *Module) depsToPaths(ctx android.ModuleContext) PathDeps {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Make sure these dependencies are propagated
|
// Make sure these dependencies are propagated
|
||||||
if lib, ok := mod.compiler.(*libraryDecorator); ok && (exportDep || lib.rlib()) {
|
if lib, ok := mod.compiler.(*libraryDecorator); ok && exportDep {
|
||||||
lib.linkDirs = append(lib.linkDirs, linkPath)
|
lib.linkDirs = append(lib.linkDirs, linkPath)
|
||||||
lib.depFlags = append(lib.depFlags, "-l"+libName)
|
lib.depFlags = append(lib.depFlags, "-l"+libName)
|
||||||
} else if procMacro, ok := mod.compiler.(*procMacroDecorator); ok && exportDep {
|
} else if procMacro, ok := mod.compiler.(*procMacroDecorator); ok && exportDep {
|
||||||
@@ -576,8 +654,8 @@ func linkPathFromFilePath(filepath android.Path) string {
|
|||||||
}
|
}
|
||||||
func libNameFromFilePath(filepath android.Path) string {
|
func libNameFromFilePath(filepath android.Path) string {
|
||||||
libName := strings.Split(filepath.Base(), filepath.Ext())[0]
|
libName := strings.Split(filepath.Base(), filepath.Ext())[0]
|
||||||
if strings.Contains(libName, "lib") {
|
if strings.HasPrefix(libName, "lib") {
|
||||||
libName = strings.Split(libName, "lib")[1]
|
libName = libName[3:]
|
||||||
}
|
}
|
||||||
return libName
|
return libName
|
||||||
}
|
}
|
||||||
@@ -591,23 +669,37 @@ func (mod *Module) DepsMutator(actx android.BottomUpMutatorContext) {
|
|||||||
ctx.ctx = ctx
|
ctx.ctx = ctx
|
||||||
|
|
||||||
deps := mod.deps(ctx)
|
deps := mod.deps(ctx)
|
||||||
|
commonDepVariations := []blueprint.Variation{}
|
||||||
actx.AddVariationDependencies([]blueprint.Variation{{Mutator: "rust_libraries", Variation: "rlib"}}, rlibDepTag, deps.Rlibs...)
|
commonDepVariations = append(commonDepVariations,
|
||||||
actx.AddVariationDependencies([]blueprint.Variation{{Mutator: "rust_libraries", Variation: "dylib"}}, dylibDepTag, deps.Dylibs...)
|
blueprint.Variation{Mutator: "version", Variation: ""})
|
||||||
|
|
||||||
ccDepVariations := []blueprint.Variation{}
|
|
||||||
ccDepVariations = append(ccDepVariations, blueprint.Variation{Mutator: "version", Variation: ""})
|
|
||||||
if !mod.Host() {
|
if !mod.Host() {
|
||||||
ccDepVariations = append(ccDepVariations, blueprint.Variation{Mutator: "image", Variation: "core"})
|
commonDepVariations = append(commonDepVariations,
|
||||||
|
blueprint.Variation{Mutator: "image", Variation: "core"})
|
||||||
}
|
}
|
||||||
actx.AddVariationDependencies(append(ccDepVariations, blueprint.Variation{Mutator: "link", Variation: "shared"}), cc.SharedDepTag, deps.SharedLibs...)
|
|
||||||
actx.AddVariationDependencies(append(ccDepVariations, blueprint.Variation{Mutator: "link", Variation: "static"}), cc.StaticDepTag, deps.StaticLibs...)
|
actx.AddVariationDependencies(
|
||||||
|
append(commonDepVariations, []blueprint.Variation{
|
||||||
|
{Mutator: "rust_libraries", Variation: "rlib"},
|
||||||
|
{Mutator: "link", Variation: ""}}...),
|
||||||
|
rlibDepTag, deps.Rlibs...)
|
||||||
|
actx.AddVariationDependencies(
|
||||||
|
append(commonDepVariations, []blueprint.Variation{
|
||||||
|
{Mutator: "rust_libraries", Variation: "dylib"},
|
||||||
|
{Mutator: "link", Variation: ""}}...),
|
||||||
|
dylibDepTag, deps.Dylibs...)
|
||||||
|
|
||||||
|
actx.AddVariationDependencies(append(commonDepVariations,
|
||||||
|
blueprint.Variation{Mutator: "link", Variation: "shared"}),
|
||||||
|
cc.SharedDepTag, deps.SharedLibs...)
|
||||||
|
actx.AddVariationDependencies(append(commonDepVariations,
|
||||||
|
blueprint.Variation{Mutator: "link", Variation: "static"}),
|
||||||
|
cc.StaticDepTag, deps.StaticLibs...)
|
||||||
|
|
||||||
if deps.CrtBegin != "" {
|
if deps.CrtBegin != "" {
|
||||||
actx.AddVariationDependencies(ccDepVariations, cc.CrtBeginDepTag, deps.CrtBegin)
|
actx.AddVariationDependencies(commonDepVariations, cc.CrtBeginDepTag, deps.CrtBegin)
|
||||||
}
|
}
|
||||||
if deps.CrtEnd != "" {
|
if deps.CrtEnd != "" {
|
||||||
actx.AddVariationDependencies(ccDepVariations, cc.CrtEndDepTag, deps.CrtEnd)
|
actx.AddVariationDependencies(commonDepVariations, cc.CrtEndDepTag, deps.CrtEnd)
|
||||||
}
|
}
|
||||||
|
|
||||||
// proc_macros are compiler plugins, and so we need the host arch variant as a dependendcy.
|
// proc_macros are compiler plugins, and so we need the host arch variant as a dependendcy.
|
||||||
|
@@ -101,12 +101,20 @@ func testRustError(t *testing.T, pattern string, bp string) {
|
|||||||
|
|
||||||
// Test that we can extract the lib name from a lib path.
|
// Test that we can extract the lib name from a lib path.
|
||||||
func TestLibNameFromFilePath(t *testing.T) {
|
func TestLibNameFromFilePath(t *testing.T) {
|
||||||
barPath := android.PathForTesting("out/soong/.intermediates/external/libbar/libbar/linux_glibc_x86_64_shared/libbar.so")
|
libBarPath := android.PathForTesting("out/soong/.intermediates/external/libbar/libbar/linux_glibc_x86_64_shared/libbar.so")
|
||||||
libName := libNameFromFilePath(barPath)
|
libLibPath := android.PathForTesting("out/soong/.intermediates/external/libbar/libbar/linux_glibc_x86_64_shared/liblib.dylib.so")
|
||||||
expectedResult := "bar"
|
|
||||||
|
|
||||||
if libName != expectedResult {
|
libBarName := libNameFromFilePath(libBarPath)
|
||||||
t.Errorf("libNameFromFilePath returned the wrong name; expected '%#v', got '%#v'", expectedResult, libName)
|
libLibName := libNameFromFilePath(libLibPath)
|
||||||
|
|
||||||
|
expectedResult := "bar"
|
||||||
|
if libBarName != expectedResult {
|
||||||
|
t.Errorf("libNameFromFilePath returned the wrong name; expected '%#v', got '%#v'", expectedResult, libBarName)
|
||||||
|
}
|
||||||
|
|
||||||
|
expectedResult = "lib.dylib"
|
||||||
|
if libLibName != expectedResult {
|
||||||
|
t.Errorf("libNameFromFilePath returned the wrong name; expected '%#v', got '%#v'", expectedResult, libLibPath)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -140,12 +148,20 @@ func TestDefaultCrateName(t *testing.T) {
|
|||||||
// Test to make sure dependencies are being picked up correctly.
|
// Test to make sure dependencies are being picked up correctly.
|
||||||
func TestDepsTracking(t *testing.T) {
|
func TestDepsTracking(t *testing.T) {
|
||||||
ctx := testRust(t, `
|
ctx := testRust(t, `
|
||||||
|
rust_library_host_static {
|
||||||
|
name: "libstatic",
|
||||||
|
srcs: ["foo.rs"],
|
||||||
|
}
|
||||||
|
rust_library_host_shared {
|
||||||
|
name: "libshared",
|
||||||
|
srcs: ["foo.rs"],
|
||||||
|
}
|
||||||
rust_library_host_dylib {
|
rust_library_host_dylib {
|
||||||
name: "libfoo",
|
name: "libdylib",
|
||||||
srcs: ["foo.rs"],
|
srcs: ["foo.rs"],
|
||||||
}
|
}
|
||||||
rust_library_host_rlib {
|
rust_library_host_rlib {
|
||||||
name: "libbar",
|
name: "librlib",
|
||||||
srcs: ["foo.rs"],
|
srcs: ["foo.rs"],
|
||||||
}
|
}
|
||||||
rust_proc_macro {
|
rust_proc_macro {
|
||||||
@@ -154,20 +170,22 @@ func TestDepsTracking(t *testing.T) {
|
|||||||
}
|
}
|
||||||
rust_binary_host {
|
rust_binary_host {
|
||||||
name: "fizz-buzz",
|
name: "fizz-buzz",
|
||||||
dylibs: ["libfoo"],
|
dylibs: ["libdylib"],
|
||||||
rlibs: ["libbar"],
|
rlibs: ["librlib"],
|
||||||
proc_macros: ["libpm"],
|
proc_macros: ["libpm"],
|
||||||
|
static_libs: ["libstatic"],
|
||||||
|
shared_libs: ["libshared"],
|
||||||
srcs: ["foo.rs"],
|
srcs: ["foo.rs"],
|
||||||
}
|
}
|
||||||
`)
|
`)
|
||||||
module := ctx.ModuleForTests("fizz-buzz", "linux_glibc_x86_64").Module().(*Module)
|
module := ctx.ModuleForTests("fizz-buzz", "linux_glibc_x86_64").Module().(*Module)
|
||||||
|
|
||||||
// Since dependencies are added to AndroidMk* properties, we can check these to see if they've been picked up.
|
// Since dependencies are added to AndroidMk* properties, we can check these to see if they've been picked up.
|
||||||
if !android.InList("libfoo", module.Properties.AndroidMkDylibs) {
|
if !android.InList("libdylib", module.Properties.AndroidMkDylibs) {
|
||||||
t.Errorf("Dylib dependency not detected (dependency missing from AndroidMkDylibs)")
|
t.Errorf("Dylib dependency not detected (dependency missing from AndroidMkDylibs)")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !android.InList("libbar", module.Properties.AndroidMkRlibs) {
|
if !android.InList("librlib", module.Properties.AndroidMkRlibs) {
|
||||||
t.Errorf("Rlib dependency not detected (dependency missing from AndroidMkRlibs)")
|
t.Errorf("Rlib dependency not detected (dependency missing from AndroidMkRlibs)")
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -175,6 +193,13 @@ func TestDepsTracking(t *testing.T) {
|
|||||||
t.Errorf("Proc_macro dependency not detected (dependency missing from AndroidMkProcMacroLibs)")
|
t.Errorf("Proc_macro dependency not detected (dependency missing from AndroidMkProcMacroLibs)")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if !android.InList("libshared", module.Properties.AndroidMkSharedLibs) {
|
||||||
|
t.Errorf("Shared library dependency not detected (dependency missing from AndroidMkSharedLibs)")
|
||||||
|
}
|
||||||
|
|
||||||
|
if !android.InList("libstatic", module.Properties.AndroidMkStaticLibs) {
|
||||||
|
t.Errorf("Static library dependency not detected (dependency missing from AndroidMkStaticLibs)")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test to make sure proc_macros use host variants when building device modules.
|
// Test to make sure proc_macros use host variants when building device modules.
|
||||||
|
@@ -174,18 +174,23 @@ func CreateTestContext(bp string) *android.TestContext {
|
|||||||
ctx.RegisterModuleType("rust_library_host_dylib", android.ModuleFactoryAdaptor(RustLibraryDylibHostFactory))
|
ctx.RegisterModuleType("rust_library_host_dylib", android.ModuleFactoryAdaptor(RustLibraryDylibHostFactory))
|
||||||
ctx.RegisterModuleType("rust_library_rlib", android.ModuleFactoryAdaptor(RustLibraryRlibFactory))
|
ctx.RegisterModuleType("rust_library_rlib", android.ModuleFactoryAdaptor(RustLibraryRlibFactory))
|
||||||
ctx.RegisterModuleType("rust_library_dylib", android.ModuleFactoryAdaptor(RustLibraryDylibFactory))
|
ctx.RegisterModuleType("rust_library_dylib", android.ModuleFactoryAdaptor(RustLibraryDylibFactory))
|
||||||
|
ctx.RegisterModuleType("rust_library_shared", android.ModuleFactoryAdaptor(RustLibrarySharedFactory))
|
||||||
|
ctx.RegisterModuleType("rust_library_static", android.ModuleFactoryAdaptor(RustLibraryStaticFactory))
|
||||||
|
ctx.RegisterModuleType("rust_library_host_shared", android.ModuleFactoryAdaptor(RustLibrarySharedHostFactory))
|
||||||
|
ctx.RegisterModuleType("rust_library_host_static", android.ModuleFactoryAdaptor(RustLibraryStaticHostFactory))
|
||||||
ctx.RegisterModuleType("rust_proc_macro", android.ModuleFactoryAdaptor(ProcMacroFactory))
|
ctx.RegisterModuleType("rust_proc_macro", android.ModuleFactoryAdaptor(ProcMacroFactory))
|
||||||
ctx.RegisterModuleType("rust_prebuilt_dylib", android.ModuleFactoryAdaptor(PrebuiltDylibFactory))
|
ctx.RegisterModuleType("rust_prebuilt_dylib", android.ModuleFactoryAdaptor(PrebuiltDylibFactory))
|
||||||
ctx.RegisterModuleType("toolchain_library", android.ModuleFactoryAdaptor(cc.ToolchainLibraryFactory))
|
ctx.RegisterModuleType("toolchain_library", android.ModuleFactoryAdaptor(cc.ToolchainLibraryFactory))
|
||||||
ctx.PreDepsMutators(func(ctx android.RegisterMutatorsContext) {
|
ctx.PreDepsMutators(func(ctx android.RegisterMutatorsContext) {
|
||||||
ctx.BottomUp("rust_libraries", LibraryMutator).Parallel()
|
// cc mutators
|
||||||
|
|
||||||
ctx.BottomUp("image", cc.ImageMutator).Parallel()
|
ctx.BottomUp("image", cc.ImageMutator).Parallel()
|
||||||
ctx.BottomUp("link", cc.LinkageMutator).Parallel()
|
ctx.BottomUp("link", cc.LinkageMutator).Parallel()
|
||||||
ctx.BottomUp("version", cc.VersionMutator).Parallel()
|
ctx.BottomUp("version", cc.VersionMutator).Parallel()
|
||||||
ctx.BottomUp("begin", cc.BeginMutator).Parallel()
|
ctx.BottomUp("begin", cc.BeginMutator).Parallel()
|
||||||
})
|
|
||||||
|
|
||||||
|
// rust mutators
|
||||||
|
ctx.BottomUp("rust_libraries", LibraryMutator).Parallel()
|
||||||
|
})
|
||||||
bp = bp + GatherRequiredDepsForTest()
|
bp = bp + GatherRequiredDepsForTest()
|
||||||
|
|
||||||
mockFS := map[string][]byte{
|
mockFS := map[string][]byte{
|
||||||
|
Reference in New Issue
Block a user