-
Notifications
You must be signed in to change notification settings - Fork 12.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add host build for aarch64-linux-android #41149
Conversation
r? @brson (rust_highfive has picked a reviewer for you, use r? to override) |
@alexcrichton There are some points that need to be discussed. The ndk update was necessary to fix a crash in openssl build. The minimum version of the ndk api level to build Considering the recent split of some builders, I've create one builder for each arch. Maybe we are reaching the limit? I used I left out host build for arm. I think that most hardware out there supports armv7, but maybe there is interest in running rustc on it. Some manifestation about android rustc support: termux/termux-packages#261, https://www.reddit.com/r/rust/comments/631bl2/exciting_rust_coming_to_android_and_chromebooks/ |
Thanks for working on this, @malbarbo. This is exciting! I'm not Alex (:smile:) but let me share my thoughts: Disclaimer: I'm not familiar with Android's NDKs and API levels.
Just to confirm, these rustc / Cargo binaries would be usable not only on Android phones but also on Chromebooks (Chrome OS)? That's what I understood from the linked reddit thread.
I think building is not the problem here. We could have two docker images using different NDKs with different API levels and build only std on one and the whole toolchain+Cargo on the other. The problem, I think, is uploading the binaries because both builders would produce a Perhaps we could, somehow, let the
Q: Is this NDK update different than raising the API level?
Could you say more about why older API level didn't work. I thought that API levels were more related to functionality like accessing sensors so I'm curious about why this didn't work. Perhaps Android's API levels are a bit like glibc's symbol versioning? |
Thanks for the PR @malbarbo! The changes here look great to me. Unfortunately though, yeah, we're running at the limit of our capacity and I think we'll need to allocate more before landing this. This is a pretty significant investment, three new compiler builds, and it won't be cheap to support. @rust-lang/tools, any particular thoughts here on that aspect? As to API versioning and whatnot, I think our story here is sort of up in the air. We have historically attempted to just be as compatible as possible, resorting to runtime checks for incompatibilities across NDK revisions. In that sense Gecko requested version 9 compatibility, but we maybe able to increase that (we'd just want to check with them). I think we'll still want the standard library to be "as compatible as possible" but I don't mind making the compiler require a newer version. The OSX tests today, for example, compile libstd for 10.7 and the compiler for 10.8. We unfortunately don't have any method of indicating the version in the target right now, though, so we'll just have to pick one and stick to it. I don't think we're ready to add multiple targets for multiple revisions just yet. |
@malbarbo also if you'd like I'd be fine landing the rustbuild changes ahead of the docker config changes, that way we don't have to block that commit. |
Ok so we're currently using 41/45 of our capacity on Travis on each PR. I think we need to leave some breathing room for projects like Cargo/libc and PRs to have capacity as well, so until we get more capacity or shuffle around what we have already I don't think we'll be able to expand our test coverage unfortunately. Unfortunately compiling entire compilers is pretty serious and requires whole separate builders, so I don't know of an easy way to slot this in with the existing builds. cc @aturon |
☔ The latest upstream changes (presumably #41267) made this pull request unmergeable. Please resolve the merge conflicts. |
Oh, I was just pinging Alex, every one is welcome!
Yes. According to this android apps can be installed in many Chromebooks. Installing a terminal emulator like termux would allow running rustup (which supports android!) and install rustc and cargo. The only missing part is publish rustc (and cargo) for android.
Running ldd on rustc we can see that rustc is dynamic linked with std. Cargo is static linked (maybe this will change because cargo will be build using --enable-extend in the rust builder). Anyway, I think this is not a problem. libstd can be build with older api level. The problem is that llvm need api level 21 (I fixed the first post).
Yes. A ndk update means updating the tool chains (gcc, etc). A new ndk generally support all previous api levels, so it can be used to target (almost) any android version.
Android uses bionic libc, each api level correspond to a new version of bionic and each new version of bonic implements more libc (posix) functions. So using old api level means that some libc functions may be missing. Also some functions was declared static when it should not be, see this. Trying to build llvm with an api level older than 21 produces error related with stat/fstat functions and structures. Instead of using two different builders, I'm trying to build rustc using to different api levels. Let's see. |
@alexcrichton Thanks for the feedback. I understand the limited capacity issue. Considering that there are interest in running rustc in android and that it will allow programming in rust using chomebooks, I think we should try to add at least one builder. We can add the builder for aarch64 (the PR needs to be updated). I'm trying to build armv7 using two different api level, if I make it we will have two options. Considering that our capacity is limited I think we need a policy to decide where the capacity will be used. It seems that for now the policy is FCFS. It would be great to have download statistics so we could decide which new target add to the builders and which ones to retire. |
To echo what @alexcrichton is saying: while we can potentially grow our capacity further, we need to figure out a sustainable model going forward as we add an increasing number of platforms; the costs add up quickly. I'll be working with the core team and Mozilla to develop a strategy here, but it will take some time. If we can find other avenues in the meantime, that'd be great. |
@malbarbo ok yeah starting out conservatively seems fine with just an aarch64 builder. And yes we definitely need a policy in this regard! |
@alexcrichton I noticed that there is a difference from rust-std packages for targets that have host support and targets that do not have. Can you tell me if this in intentional? Here is the list of files in a rust-std tarball for target only build. And here is a list of additional files for a host build. It seems odd to have rustc artifacts when installing a target using rustup. This happens for example, when install |
Yeah while unfortunate it's intentional right now. We never got around to having separate packages for rustc and libstd crates, so the "rust-std" package is actually "all compiled libraries for this target" which may or may not include the rustc libs depending on what we're distributing. |
Also update sscache to 2017-04-04 and reorganize Dockerfile so we can share some image layers
@alexcrichton Changed the PR to only add aarch64 builder. |
Ok thanks @malbarbo, in the meantime I've tagged this as waiting on the core team while we figure out a way to get more capacity. |
☔ The latest upstream changes (presumably #41445) made this pull request unmergeable. Please resolve the merge conflicts. |
Merge conflicts! Moving this back to you @malbarbo :) |
@carols10cents after #41864 to add an aarch64 android builder is just move a dir out of disabled and add a entry to .travis.yml. I was waiting on the team decision. Should I close this PR and open an issue to track the team decision? |
@malbarbo Ah, I see. I'll poke people! |
@malbarbo thanks for your contribution! As you suggested, it's probably better to track this in some other way, especially as we are still figuring out the best way to support adding more and more build types to the Rust build system. I'm going to close this PR for now. 😿 |
I solved it according to termux/termux-packages#8214 . I just installed binutils. |
Some care was taken writing the Dockerfiles so the images can share layers.