rust: Enable Rust modules in Product

The prohibition on Rust dylibs outside system still stands, but rlibs,
rust_ffi_static, and binaries will all work fine.

Test: m nothing (new soong tests added by this commit)
Test: Created sample product_specific rust_binary, checked out/ location
Bug: 165791368
Change-Id: I6453274064bb24b2019f38e57fc0d09b7c0fcf30
This commit is contained in:
Matthew Maurer
2023-01-24 16:36:02 -08:00
parent 6cf5e0d9cb
commit 993db7a7cc
4 changed files with 108 additions and 14 deletions

View File

@@ -129,6 +129,10 @@ func (ctx *moduleContext) DeviceSpecific() bool {
return ctx.ModuleContext.DeviceSpecific() || (ctx.RustModule().InVendor() && ctx.RustModule().VendorVariantToOdm())
}
func (ctx *moduleContext) SystemExtSpecific() bool {
return ctx.ModuleContext.SystemExtSpecific()
}
// Returns true when this module creates a vendor variant and wants to install the vendor variant
// to the odm partition.
func (c *Module) VendorVariantToOdm() bool {
@@ -158,22 +162,15 @@ func (mod *Module) InVendorRamdisk() bool {
}
func (mod *Module) OnlyInRamdisk() bool {
// TODO(b/165791368)
return false
return mod.ModuleBase.InstallInRamdisk()
}
func (mod *Module) OnlyInRecovery() bool {
// TODO(b/165791368)
return false
return mod.ModuleBase.InstallInRecovery()
}
func (mod *Module) OnlyInVendorRamdisk() bool {
return false
}
func (mod *Module) OnlyInProduct() bool {
//TODO(b/165791368)
return false
return mod.ModuleBase.InstallInVendorRamdisk()
}
// Returns true when this module is configured to have core and vendor variants.
@@ -226,10 +223,7 @@ func (mod *Module) ImageMutatorBegin(mctx android.BaseModuleContext) {
// Rust does not support installing to the product image yet.
vendorSpecific := mctx.SocSpecific() || mctx.DeviceSpecific()
if mctx.ProductSpecific() {
mctx.PropertyErrorf("product_specific",
"Rust modules do not yet support installing to the product image.")
} else if Bool(mod.VendorProperties.Double_loadable) {
if Bool(mod.VendorProperties.Double_loadable) {
mctx.PropertyErrorf("double_loadable",
"Rust modules do not yet support double loading")
}
@@ -243,6 +237,11 @@ func (mod *Module) ImageMutatorBegin(mctx android.BaseModuleContext) {
mctx.PropertyErrorf("vendor", "Vendor-only dylibs are not yet supported, use rust_library_rlib.")
}
}
if mctx.ProductSpecific() {
if lib, ok := mod.compiler.(libraryInterface); ok && lib.buildDylib() {
mctx.PropertyErrorf("product", "Product-only dylibs are not yet supported, use rust_library_rlib.")
}
}
cc.MutateImage(mctx, mod)

View File

@@ -103,3 +103,93 @@ func TestForbiddenVendorLinkage(t *testing.T) {
}
`)
}
func checkInstallPartition(t *testing.T, ctx *android.TestContext, name, variant, expected string) {
mod := ctx.ModuleForTests(name, variant).Module().(*Module)
partitionDefined := false
checkPartition := func(specific bool, partition string) {
if specific {
if expected != partition && !partitionDefined {
// The variant is installed to the 'partition'
t.Errorf("%s variant of %q must not be installed to %s partition", variant, name, partition)
}
partitionDefined = true
} else {
// The variant is not installed to the 'partition'
if expected == partition {
t.Errorf("%s variant of %q must be installed to %s partition", variant, name, partition)
}
}
}
socSpecific := func(m *Module) bool {
return m.SocSpecific()
}
deviceSpecific := func(m *Module) bool {
return m.DeviceSpecific()
}
productSpecific := func(m *Module) bool {
return m.ProductSpecific() || m.productSpecificModuleContext()
}
systemExtSpecific := func(m *Module) bool {
return m.SystemExtSpecific()
}
checkPartition(socSpecific(mod), "vendor")
checkPartition(deviceSpecific(mod), "odm")
checkPartition(productSpecific(mod), "product")
checkPartition(systemExtSpecific(mod), "system_ext")
if !partitionDefined && expected != "system" {
t.Errorf("%s variant of %q is expected to be installed to %s partition,"+
" but installed to system partition", variant, name, expected)
}
}
func TestInstallPartition(t *testing.T) {
t.Parallel()
t.Helper()
ctx := testRust(t, `
rust_binary {
name: "sample_system",
crate_name: "sample",
srcs: ["foo.rs"],
}
rust_binary {
name: "sample_system_ext",
crate_name: "sample",
srcs: ["foo.rs"],
system_ext_specific: true,
}
rust_binary {
name: "sample_product",
crate_name: "sample",
srcs: ["foo.rs"],
product_specific: true,
}
rust_binary {
name: "sample_vendor",
crate_name: "sample",
srcs: ["foo.rs"],
vendor: true,
}
rust_binary {
name: "sample_odm",
crate_name: "sample",
srcs: ["foo.rs"],
device_specific: true,
}
rust_binary {
name: "sample_all_available",
crate_name: "sample",
srcs: ["foo.rs"],
vendor_available: true,
product_available: true,
}
`)
checkInstallPartition(t, ctx, "sample_system", binaryCoreVariant, "system")
checkInstallPartition(t, ctx, "sample_system_ext", binaryCoreVariant, "system_ext")
checkInstallPartition(t, ctx, "sample_product", binaryProductVariant, "product")
checkInstallPartition(t, ctx, "sample_vendor", binaryVendorVariant, "vendor")
checkInstallPartition(t, ctx, "sample_odm", binaryVendorVariant, "odm")
checkInstallPartition(t, ctx, "sample_all_available", binaryCoreVariant, "system")
}

View File

@@ -83,6 +83,10 @@ const (
rlibVendorVariant = "android_vendor.29_arm64_armv8-a_rlib_rlib-std"
sharedRecoveryVariant = "android_recovery_arm64_armv8-a_shared"
rlibRecoveryVariant = "android_recovery_arm64_armv8-a_rlib_rlib-std"
binaryCoreVariant = "android_arm64_armv8-a"
binaryVendorVariant = "android_vendor.29_arm64_armv8-a"
binaryProductVariant = "android_product.29_arm64_armv8-a"
binaryRecoveryVariant = "android_recovery_arm64_armv8-a"
)
func testRustVndkFs(t *testing.T, bp string, fs android.MockFS) *android.TestContext {

View File

@@ -104,6 +104,7 @@ func GatherRequiredDepsForTest() string {
crate_name: "std",
srcs: ["foo.rs"],
no_stdlibs: true,
product_available: true,
host_supported: true,
vendor_available: true,
vendor_ramdisk_available: true,