Loading rust/Android.bp +2 −0 Original line number Diff line number Diff line Loading @@ -15,6 +15,7 @@ bootstrap_go_package { "clippy.go", "compiler.go", "coverage.go", "image.go", "library.go", "prebuilt.go", "proc_macro.go", Loading @@ -33,6 +34,7 @@ bootstrap_go_package { "clippy_test.go", "compiler_test.go", "coverage_test.go", "image_test.go", "library_test.go", "project_json_test.go", "protobuf_test.go", Loading rust/androidmk.go +1 −0 Original line number Diff line number Diff line Loading @@ -58,6 +58,7 @@ func (mod *Module) AndroidMkEntries() []android.AndroidMkEntries { entries.AddStrings("LOCAL_PROC_MACRO_LIBRARIES", mod.Properties.AndroidMkProcMacroLibs...) entries.AddStrings("LOCAL_SHARED_LIBRARIES", mod.Properties.AndroidMkSharedLibs...) entries.AddStrings("LOCAL_STATIC_LIBRARIES", mod.Properties.AndroidMkStaticLibs...) entries.AddStrings("LOCAL_SOONG_LINK_TYPE", mod.makeLinkType) }, }, } Loading rust/image.go 0 → 100644 +153 −0 Original line number Diff line number Diff line // Copyright 2020 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package rust import ( "strings" "android/soong/android" "android/soong/cc" ) var _ android.ImageInterface = (*Module)(nil) func (mod *Module) VendorRamdiskVariantNeeded(ctx android.BaseModuleContext) bool { return false } func (mod *Module) CoreVariantNeeded(ctx android.BaseModuleContext) bool { return mod.Properties.CoreVariantNeeded } func (mod *Module) RamdiskVariantNeeded(android.BaseModuleContext) bool { return mod.InRamdisk() } func (mod *Module) RecoveryVariantNeeded(android.BaseModuleContext) bool { return mod.InRecovery() } func (mod *Module) ExtraImageVariations(android.BaseModuleContext) []string { return mod.Properties.ExtraVariants } func (ctx *moduleContext) ProductSpecific() bool { return false } func (mod *Module) InRecovery() bool { // TODO(b/165791368) return false } func (mod *Module) OnlyInRamdisk() bool { // TODO(b/165791368) return false } func (mod *Module) OnlyInRecovery() bool { // TODO(b/165791368) return false } func (mod *Module) OnlyInVendorRamdisk() bool { return false } // Returns true when this module is configured to have core and vendor variants. func (mod *Module) HasVendorVariant() bool { return mod.IsVndk() || Bool(mod.VendorProperties.Vendor_available) } func (c *Module) VendorAvailable() bool { return Bool(c.VendorProperties.Vendor_available) } func (c *Module) InProduct() bool { return false } func (mod *Module) SetImageVariation(ctx android.BaseModuleContext, variant string, module android.Module) { m := module.(*Module) if strings.HasPrefix(variant, cc.VendorVariationPrefix) { m.Properties.ImageVariationPrefix = cc.VendorVariationPrefix m.Properties.VndkVersion = strings.TrimPrefix(variant, cc.VendorVariationPrefix) // Makefile shouldn't know vendor modules other than BOARD_VNDK_VERSION. // Hide other vendor variants to avoid collision. vndkVersion := ctx.DeviceConfig().VndkVersion() if vndkVersion != "current" && vndkVersion != "" && vndkVersion != m.Properties.VndkVersion { m.Properties.HideFromMake = true m.SkipInstall() } } } func (mod *Module) ImageMutatorBegin(mctx android.BaseModuleContext) { vendorSpecific := mctx.SocSpecific() || mctx.DeviceSpecific() platformVndkVersion := mctx.DeviceConfig().PlatformVndkVersion() // Rust does not support installing to the product image yet. if mod.VendorProperties.Product_available != nil { mctx.PropertyErrorf("product_available", "Rust modules do not yet support being available to the product image") } else if mctx.ProductSpecific() { mctx.PropertyErrorf("product_specific", "Rust modules do not yet support installing to the product image.") } else if mod.VendorProperties.Double_loadable != nil { mctx.PropertyErrorf("double_loadable", "Rust modules do not yet support double loading") } coreVariantNeeded := true var vendorVariants []string if mod.VendorProperties.Vendor_available != nil { if vendorSpecific { mctx.PropertyErrorf("vendor_available", "doesn't make sense at the same time as `vendor: true`, `proprietary: true`, or `device_specific:true`") } if lib, ok := mod.compiler.(libraryInterface); ok { // Explicitly disallow rust_ffi variants which produce shared libraries from setting vendor_available. // Vendor variants do not produce an error for dylibs, rlibs with dylib-std linkage are disabled in the respective library // mutators until support is added. // // We can't check shared() here because image mutator is called before the library mutator, so we need to // check buildShared() if lib.buildShared() { mctx.PropertyErrorf("vendor_available", "vendor_available can only be set for rust_ffi_static modules.") } else if Bool(mod.VendorProperties.Vendor_available) == true { vendorVariants = append(vendorVariants, platformVndkVersion) } } } if vendorSpecific { if lib, ok := mod.compiler.(libraryInterface); !ok || (ok && !lib.static()) { mctx.ModuleErrorf("Rust vendor specific modules are currently only supported for rust_ffi_static modules.") } else { coreVariantNeeded = false vendorVariants = append(vendorVariants, platformVndkVersion) } } mod.Properties.CoreVariantNeeded = coreVariantNeeded for _, variant := range android.FirstUniqueStrings(vendorVariants) { mod.Properties.ExtraVariants = append(mod.Properties.ExtraVariants, cc.VendorVariationPrefix+variant) } } rust/image_test.go 0 → 100644 +73 −0 Original line number Diff line number Diff line // Copyright 2020 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package rust import ( "testing" "android/soong/android" "android/soong/cc" ) // Test that cc_binaries can link against rust_ffi_static libraries. func TestVendorLinkage(t *testing.T) { ctx := testRust(t, ` cc_binary { name: "fizz_vendor", static_libs: ["libfoo_vendor"], soc_specific: true, } rust_ffi_static { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor_available: true, } `) vendorBinary := ctx.ModuleForTests("fizz_vendor", "android_arm64_armv8-a").Module().(*cc.Module) if !android.InList("libfoo_vendor", vendorBinary.Properties.AndroidMkStaticLibs) { t.Errorf("vendorBinary should have a dependency on libfoo_vendor") } } // Test that shared libraries cannot be made vendor available until proper support is added. func TestForbiddenVendorLinkage(t *testing.T) { testRustError(t, "vendor_available can only be set for rust_ffi_static modules", ` rust_ffi_shared { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor_available: true, } `) testRustError(t, "Rust vendor specific modules are currently only supported for rust_ffi_static modules.", ` rust_ffi { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor: true, } `) testRustError(t, "Rust vendor specific modules are currently only supported for rust_ffi_static modules.", ` rust_library { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor: true, } `) } rust/library.go +11 −0 Original line number Diff line number Diff line Loading @@ -604,6 +604,11 @@ func LibraryMutator(mctx android.BottomUpMutatorContext) { v.(*Module).compiler.(libraryInterface).setRlib() case dylibVariation: v.(*Module).compiler.(libraryInterface).setDylib() if v.(*Module).ModuleBase.ImageVariation().Variation != android.CoreVariation { // TODO(b/165791368) // Disable dylib non-core variations until we support these. v.(*Module).Disable() } case "source": v.(*Module).compiler.(libraryInterface).setSource() // The source variant does not produce any library. Loading Loading @@ -640,6 +645,12 @@ func LibstdMutator(mctx android.BottomUpMutatorContext) { dylib := modules[1].(*Module) rlib.compiler.(libraryInterface).setRlibStd() dylib.compiler.(libraryInterface).setDylibStd() if dylib.ModuleBase.ImageVariation().Variation != android.CoreVariation { // TODO(b/165791368) // Disable rlibs that link against dylib-std on non-core variations until non-core dylib // variants are properly supported. dylib.Disable() } rlib.Properties.SubName += RlibStdlibSuffix dylib.Properties.SubName += DylibStdlibSuffix } Loading Loading
rust/Android.bp +2 −0 Original line number Diff line number Diff line Loading @@ -15,6 +15,7 @@ bootstrap_go_package { "clippy.go", "compiler.go", "coverage.go", "image.go", "library.go", "prebuilt.go", "proc_macro.go", Loading @@ -33,6 +34,7 @@ bootstrap_go_package { "clippy_test.go", "compiler_test.go", "coverage_test.go", "image_test.go", "library_test.go", "project_json_test.go", "protobuf_test.go", Loading
rust/androidmk.go +1 −0 Original line number Diff line number Diff line Loading @@ -58,6 +58,7 @@ func (mod *Module) AndroidMkEntries() []android.AndroidMkEntries { entries.AddStrings("LOCAL_PROC_MACRO_LIBRARIES", mod.Properties.AndroidMkProcMacroLibs...) entries.AddStrings("LOCAL_SHARED_LIBRARIES", mod.Properties.AndroidMkSharedLibs...) entries.AddStrings("LOCAL_STATIC_LIBRARIES", mod.Properties.AndroidMkStaticLibs...) entries.AddStrings("LOCAL_SOONG_LINK_TYPE", mod.makeLinkType) }, }, } Loading
rust/image.go 0 → 100644 +153 −0 Original line number Diff line number Diff line // Copyright 2020 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package rust import ( "strings" "android/soong/android" "android/soong/cc" ) var _ android.ImageInterface = (*Module)(nil) func (mod *Module) VendorRamdiskVariantNeeded(ctx android.BaseModuleContext) bool { return false } func (mod *Module) CoreVariantNeeded(ctx android.BaseModuleContext) bool { return mod.Properties.CoreVariantNeeded } func (mod *Module) RamdiskVariantNeeded(android.BaseModuleContext) bool { return mod.InRamdisk() } func (mod *Module) RecoveryVariantNeeded(android.BaseModuleContext) bool { return mod.InRecovery() } func (mod *Module) ExtraImageVariations(android.BaseModuleContext) []string { return mod.Properties.ExtraVariants } func (ctx *moduleContext) ProductSpecific() bool { return false } func (mod *Module) InRecovery() bool { // TODO(b/165791368) return false } func (mod *Module) OnlyInRamdisk() bool { // TODO(b/165791368) return false } func (mod *Module) OnlyInRecovery() bool { // TODO(b/165791368) return false } func (mod *Module) OnlyInVendorRamdisk() bool { return false } // Returns true when this module is configured to have core and vendor variants. func (mod *Module) HasVendorVariant() bool { return mod.IsVndk() || Bool(mod.VendorProperties.Vendor_available) } func (c *Module) VendorAvailable() bool { return Bool(c.VendorProperties.Vendor_available) } func (c *Module) InProduct() bool { return false } func (mod *Module) SetImageVariation(ctx android.BaseModuleContext, variant string, module android.Module) { m := module.(*Module) if strings.HasPrefix(variant, cc.VendorVariationPrefix) { m.Properties.ImageVariationPrefix = cc.VendorVariationPrefix m.Properties.VndkVersion = strings.TrimPrefix(variant, cc.VendorVariationPrefix) // Makefile shouldn't know vendor modules other than BOARD_VNDK_VERSION. // Hide other vendor variants to avoid collision. vndkVersion := ctx.DeviceConfig().VndkVersion() if vndkVersion != "current" && vndkVersion != "" && vndkVersion != m.Properties.VndkVersion { m.Properties.HideFromMake = true m.SkipInstall() } } } func (mod *Module) ImageMutatorBegin(mctx android.BaseModuleContext) { vendorSpecific := mctx.SocSpecific() || mctx.DeviceSpecific() platformVndkVersion := mctx.DeviceConfig().PlatformVndkVersion() // Rust does not support installing to the product image yet. if mod.VendorProperties.Product_available != nil { mctx.PropertyErrorf("product_available", "Rust modules do not yet support being available to the product image") } else if mctx.ProductSpecific() { mctx.PropertyErrorf("product_specific", "Rust modules do not yet support installing to the product image.") } else if mod.VendorProperties.Double_loadable != nil { mctx.PropertyErrorf("double_loadable", "Rust modules do not yet support double loading") } coreVariantNeeded := true var vendorVariants []string if mod.VendorProperties.Vendor_available != nil { if vendorSpecific { mctx.PropertyErrorf("vendor_available", "doesn't make sense at the same time as `vendor: true`, `proprietary: true`, or `device_specific:true`") } if lib, ok := mod.compiler.(libraryInterface); ok { // Explicitly disallow rust_ffi variants which produce shared libraries from setting vendor_available. // Vendor variants do not produce an error for dylibs, rlibs with dylib-std linkage are disabled in the respective library // mutators until support is added. // // We can't check shared() here because image mutator is called before the library mutator, so we need to // check buildShared() if lib.buildShared() { mctx.PropertyErrorf("vendor_available", "vendor_available can only be set for rust_ffi_static modules.") } else if Bool(mod.VendorProperties.Vendor_available) == true { vendorVariants = append(vendorVariants, platformVndkVersion) } } } if vendorSpecific { if lib, ok := mod.compiler.(libraryInterface); !ok || (ok && !lib.static()) { mctx.ModuleErrorf("Rust vendor specific modules are currently only supported for rust_ffi_static modules.") } else { coreVariantNeeded = false vendorVariants = append(vendorVariants, platformVndkVersion) } } mod.Properties.CoreVariantNeeded = coreVariantNeeded for _, variant := range android.FirstUniqueStrings(vendorVariants) { mod.Properties.ExtraVariants = append(mod.Properties.ExtraVariants, cc.VendorVariationPrefix+variant) } }
rust/image_test.go 0 → 100644 +73 −0 Original line number Diff line number Diff line // Copyright 2020 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package rust import ( "testing" "android/soong/android" "android/soong/cc" ) // Test that cc_binaries can link against rust_ffi_static libraries. func TestVendorLinkage(t *testing.T) { ctx := testRust(t, ` cc_binary { name: "fizz_vendor", static_libs: ["libfoo_vendor"], soc_specific: true, } rust_ffi_static { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor_available: true, } `) vendorBinary := ctx.ModuleForTests("fizz_vendor", "android_arm64_armv8-a").Module().(*cc.Module) if !android.InList("libfoo_vendor", vendorBinary.Properties.AndroidMkStaticLibs) { t.Errorf("vendorBinary should have a dependency on libfoo_vendor") } } // Test that shared libraries cannot be made vendor available until proper support is added. func TestForbiddenVendorLinkage(t *testing.T) { testRustError(t, "vendor_available can only be set for rust_ffi_static modules", ` rust_ffi_shared { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor_available: true, } `) testRustError(t, "Rust vendor specific modules are currently only supported for rust_ffi_static modules.", ` rust_ffi { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor: true, } `) testRustError(t, "Rust vendor specific modules are currently only supported for rust_ffi_static modules.", ` rust_library { name: "libfoo_vendor", crate_name: "foo", srcs: ["foo.rs"], vendor: true, } `) }
rust/library.go +11 −0 Original line number Diff line number Diff line Loading @@ -604,6 +604,11 @@ func LibraryMutator(mctx android.BottomUpMutatorContext) { v.(*Module).compiler.(libraryInterface).setRlib() case dylibVariation: v.(*Module).compiler.(libraryInterface).setDylib() if v.(*Module).ModuleBase.ImageVariation().Variation != android.CoreVariation { // TODO(b/165791368) // Disable dylib non-core variations until we support these. v.(*Module).Disable() } case "source": v.(*Module).compiler.(libraryInterface).setSource() // The source variant does not produce any library. Loading Loading @@ -640,6 +645,12 @@ func LibstdMutator(mctx android.BottomUpMutatorContext) { dylib := modules[1].(*Module) rlib.compiler.(libraryInterface).setRlibStd() dylib.compiler.(libraryInterface).setDylibStd() if dylib.ModuleBase.ImageVariation().Variation != android.CoreVariation { // TODO(b/165791368) // Disable rlibs that link against dylib-std on non-core variations until non-core dylib // variants are properly supported. dylib.Disable() } rlib.Properties.SubName += RlibStdlibSuffix dylib.Properties.SubName += DylibStdlibSuffix } Loading