Auto merge of #105716 - chriswailes:ndk-update-redux, r=pietroalbini
Ndk update redux Blocked on https://github.com/rust-lang/blog.rust-lang.org/pull/1055
This commit is contained in:
commit
333ee6c466
@ -47,6 +47,8 @@ fn cc2ar(cc: &Path, target: TargetSelection) -> Option<PathBuf> {
|
|||||||
Some(PathBuf::from("ar"))
|
Some(PathBuf::from("ar"))
|
||||||
} else if target.contains("vxworks") {
|
} else if target.contains("vxworks") {
|
||||||
Some(PathBuf::from("wr-ar"))
|
Some(PathBuf::from("wr-ar"))
|
||||||
|
} else if target.contains("android") {
|
||||||
|
Some(cc.parent().unwrap().join(PathBuf::from("llvm-ar")))
|
||||||
} else {
|
} else {
|
||||||
let parent = cc.parent().unwrap();
|
let parent = cc.parent().unwrap();
|
||||||
let file = cc.file_name().unwrap().to_str().unwrap();
|
let file = cc.file_name().unwrap().to_str().unwrap();
|
||||||
@ -219,12 +221,22 @@ fn set_compiler(
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn ndk_compiler(compiler: Language, triple: &str, ndk: &Path) -> PathBuf {
|
pub(crate) fn ndk_compiler(compiler: Language, triple: &str, ndk: &Path) -> PathBuf {
|
||||||
let triple_translated = triple
|
let mut triple_iter = triple.split("-");
|
||||||
.replace("armv7neon", "arm")
|
let triple_translated = if let Some(arch) = triple_iter.next() {
|
||||||
.replace("armv7", "arm")
|
let arch_new = match arch {
|
||||||
.replace("thumbv7neon", "arm")
|
"arm" | "armv7" | "armv7neon" | "thumbv7" | "thumbv7neon" => "armv7a",
|
||||||
.replace("thumbv7", "arm");
|
other => other,
|
||||||
let compiler = format!("{}-{}", triple_translated, compiler.clang());
|
};
|
||||||
|
std::iter::once(arch_new).chain(triple_iter).collect::<Vec<&str>>().join("-")
|
||||||
|
} else {
|
||||||
|
triple.to_string()
|
||||||
|
};
|
||||||
|
|
||||||
|
// API 19 is the earliest API level supported by NDK r25b but AArch64 and x86_64 support
|
||||||
|
// begins at API level 21.
|
||||||
|
let api_level =
|
||||||
|
if triple.contains("aarch64") || triple.contains("x86_64") { "21" } else { "19" };
|
||||||
|
let compiler = format!("{}{}-{}", triple_translated, api_level, compiler.clang());
|
||||||
ndk.join("bin").join(compiler)
|
ndk.join("bin").join(compiler)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
FROM ubuntu:22.04
|
FROM ubuntu:22.10
|
||||||
|
|
||||||
ARG DEBIAN_FRONTEND=noninteractive
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
COPY scripts/android-base-apt-get.sh /scripts/
|
COPY scripts/android-base-apt-get.sh /scripts/
|
||||||
@ -6,7 +6,7 @@ RUN sh /scripts/android-base-apt-get.sh
|
|||||||
|
|
||||||
COPY scripts/android-ndk.sh /scripts/
|
COPY scripts/android-ndk.sh /scripts/
|
||||||
RUN . /scripts/android-ndk.sh && \
|
RUN . /scripts/android-ndk.sh && \
|
||||||
download_and_make_toolchain android-ndk-r15c-linux-x86_64.zip arm 14
|
download_ndk android-ndk-r25b-linux.zip
|
||||||
|
|
||||||
RUN dpkg --add-architecture i386 && \
|
RUN dpkg --add-architecture i386 && \
|
||||||
apt-get update && \
|
apt-get update && \
|
||||||
@ -30,7 +30,7 @@ ENV PATH=$PATH:/android/sdk/platform-tools
|
|||||||
|
|
||||||
ENV TARGETS=arm-linux-androideabi
|
ENV TARGETS=arm-linux-androideabi
|
||||||
|
|
||||||
ENV RUST_CONFIGURE_ARGS --arm-linux-androideabi-ndk=/android/ndk/arm-14
|
ENV RUST_CONFIGURE_ARGS --arm-linux-androideabi-ndk=/android/ndk/toolchains/llvm/prebuilt/linux-x86_64/
|
||||||
|
|
||||||
ENV SCRIPT python3 ../x.py --stage 2 test --host='' --target $TARGETS
|
ENV SCRIPT python3 ../x.py --stage 2 test --host='' --target $TARGETS
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
FROM ubuntu:22.04
|
FROM ubuntu:22.10
|
||||||
|
|
||||||
COPY scripts/android-base-apt-get.sh /scripts/
|
COPY scripts/android-base-apt-get.sh /scripts/
|
||||||
RUN sh /scripts/android-base-apt-get.sh
|
RUN sh /scripts/android-base-apt-get.sh
|
||||||
@ -6,14 +6,7 @@ RUN sh /scripts/android-base-apt-get.sh
|
|||||||
# ndk
|
# ndk
|
||||||
COPY scripts/android-ndk.sh /scripts/
|
COPY scripts/android-ndk.sh /scripts/
|
||||||
RUN . /scripts/android-ndk.sh && \
|
RUN . /scripts/android-ndk.sh && \
|
||||||
download_ndk android-ndk-r15c-linux-x86_64.zip && \
|
download_ndk android-ndk-r25b-linux.zip
|
||||||
make_standalone_toolchain arm 14 && \
|
|
||||||
make_standalone_toolchain x86 14 && \
|
|
||||||
make_standalone_toolchain arm 21 && \
|
|
||||||
make_standalone_toolchain x86 21 && \
|
|
||||||
make_standalone_toolchain arm64 21 && \
|
|
||||||
make_standalone_toolchain x86_64 21 && \
|
|
||||||
remove_ndk
|
|
||||||
|
|
||||||
# env
|
# env
|
||||||
ENV TARGETS=arm-linux-androideabi
|
ENV TARGETS=arm-linux-androideabi
|
||||||
@ -26,12 +19,12 @@ ENV TARGETS=$TARGETS,x86_64-linux-android
|
|||||||
ENV RUST_CONFIGURE_ARGS \
|
ENV RUST_CONFIGURE_ARGS \
|
||||||
--enable-extended \
|
--enable-extended \
|
||||||
--enable-profiler \
|
--enable-profiler \
|
||||||
--arm-linux-androideabi-ndk=/android/ndk/arm-14 \
|
--arm-linux-androideabi-ndk=/android/ndk/toolchains/llvm/prebuilt/linux-x86_64/ \
|
||||||
--armv7-linux-androideabi-ndk=/android/ndk/arm-14 \
|
--armv7-linux-androideabi-ndk=/android/ndk/toolchains/llvm/prebuilt/linux-x86_64/ \
|
||||||
--thumbv7neon-linux-androideabi-ndk=/android/ndk/arm-14 \
|
--thumbv7neon-linux-androideabi-ndk=/android/ndk/toolchains/llvm/prebuilt/linux-x86_64/ \
|
||||||
--i686-linux-android-ndk=/android/ndk/x86-14 \
|
--i686-linux-android-ndk=/android/ndk/toolchains/llvm/prebuilt/linux-x86_64/ \
|
||||||
--aarch64-linux-android-ndk=/android/ndk/arm64-21 \
|
--aarch64-linux-android-ndk=/android/ndk/toolchains/llvm/prebuilt/linux-x86_64/ \
|
||||||
--x86_64-linux-android-ndk=/android/ndk/x86_64-21 \
|
--x86_64-linux-android-ndk=/android/ndk/toolchains/llvm/prebuilt/linux-x86_64/ \
|
||||||
--disable-docs
|
--disable-docs
|
||||||
|
|
||||||
ENV SCRIPT python3 ../x.py dist --host='' --target $TARGETS
|
ENV SCRIPT python3 ../x.py dist --host='' --target $TARGETS
|
||||||
|
@ -4,28 +4,10 @@ set -ex
|
|||||||
URL=https://dl.google.com/android/repository
|
URL=https://dl.google.com/android/repository
|
||||||
|
|
||||||
download_ndk() {
|
download_ndk() {
|
||||||
mkdir -p /android/ndk
|
mkdir /android/
|
||||||
cd /android/ndk
|
cd /android
|
||||||
curl -fO $URL/$1
|
curl -fO $URL/$1
|
||||||
unzip -q $1
|
unzip -q $1
|
||||||
rm $1
|
rm $1
|
||||||
mv android-ndk-* ndk
|
mv android-ndk-* ndk
|
||||||
}
|
}
|
||||||
|
|
||||||
make_standalone_toolchain() {
|
|
||||||
# See https://developer.android.com/ndk/guides/standalone_toolchain.htm
|
|
||||||
python3 /android/ndk/ndk/build/tools/make_standalone_toolchain.py \
|
|
||||||
--install-dir /android/ndk/$1-$2 \
|
|
||||||
--arch $1 \
|
|
||||||
--api $2
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_ndk() {
|
|
||||||
rm -rf /android/ndk/ndk
|
|
||||||
}
|
|
||||||
|
|
||||||
download_and_make_toolchain() {
|
|
||||||
download_ndk $1 && \
|
|
||||||
make_standalone_toolchain $2 $3 && \
|
|
||||||
remove_ndk
|
|
||||||
}
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user