summaryrefslogtreecommitdiff
path: root/rust/compiler.go
diff options
context:
space:
mode:
author Ivan Lozano <ivanlozano@google.com> 2020-12-09 23:32:37 +0000
committer Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> 2020-12-09 23:32:37 +0000
commiteb114e6509da83f4f7de4df6965d41512557a17b (patch)
tree7c8ab9d78b265e629337edeefed6d20952d4325a /rust/compiler.go
parent8f474b0c345646a8904079bb3abfedcfdb1caf7d (diff)
parent366cb49b9fa3113f893b4dbdf0e21006f438f48d (diff)
Merge "Move prefer_rlib from binary to base compiler." am: 366cb49b9f
Original change: https://android-review.googlesource.com/c/platform/build/soong/+/1518620 MUST ONLY BE SUBMITTED BY AUTOMERGER Change-Id: Ic82eb1788b20c35995e138d2fea2c1b38b9a3e7e
Diffstat (limited to 'rust/compiler.go')
-rw-r--r--rust/compiler.go19
1 files changed, 18 insertions, 1 deletions
diff --git a/rust/compiler.go b/rust/compiler.go
index 8d2f09c2b..4312452d2 100644
--- a/rust/compiler.go
+++ b/rust/compiler.go
@@ -122,6 +122,17 @@ type BaseCompilerProperties struct {
// whether to suppress inclusion of standard crates - defaults to false
No_stdlibs *bool
+
+ // Change the rustlibs linkage to select rlib linkage by default for device targets.
+ // Also link libstd as an rlib as well on device targets.
+ // Note: This is the default behavior for host targets.
+ //
+ // This is primarily meant for rust_binary and rust_ffi modules where the default
+ // linkage of libstd might need to be overridden in some use cases. This should
+ // generally be avoided with other module types since it may cause collisions at
+ // linkage if all dependencies of the root binary module do not link against libstd\
+ // the same way.
+ Prefer_rlib *bool `android:"arch_variant"`
}
type baseCompiler struct {
@@ -154,9 +165,15 @@ func (compiler *baseCompiler) coverageOutputZipPath() android.OptionalPath {
panic("baseCompiler does not implement coverageOutputZipPath()")
}
+func (compiler *baseCompiler) preferRlib() bool {
+ return Bool(compiler.Properties.Prefer_rlib)
+}
+
func (compiler *baseCompiler) stdLinkage(ctx *depsContext) RustLinkage {
// For devices, we always link stdlibs in as dylibs by default.
- if ctx.Device() {
+ if compiler.preferRlib() {
+ return RlibLinkage
+ } else if ctx.Device() {
return DylibLinkage
} else {
return RlibLinkage