Merge pull request #6262 from rustdesk/revert-6257-android-fixes

Revert "Fixes for Android (ndk r26b)"
This commit is contained in:
RustDesk 2023-11-02 09:50:34 +08:00 committed by GitHub
commit 6782f92703
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 46 additions and 75 deletions

View File

@ -41,7 +41,7 @@ fn build_manifest() {
} }
} }
fn install_android_deps() { fn install_oboe() {
let target_os = std::env::var("CARGO_CFG_TARGET_OS").unwrap(); let target_os = std::env::var("CARGO_CFG_TARGET_OS").unwrap();
if target_os != "android" { if target_os != "android" {
return; return;
@ -49,8 +49,6 @@ fn install_android_deps() {
let mut target_arch = std::env::var("CARGO_CFG_TARGET_ARCH").unwrap(); let mut target_arch = std::env::var("CARGO_CFG_TARGET_ARCH").unwrap();
if target_arch == "x86_64" { if target_arch == "x86_64" {
target_arch = "x64".to_owned(); target_arch = "x64".to_owned();
} else if target_arch == "x86" {
target_arch = "x86".to_owned();
} else if target_arch == "aarch64" { } else if target_arch == "aarch64" {
target_arch = "arm64".to_owned(); target_arch = "arm64".to_owned();
} else { } else {
@ -68,7 +66,6 @@ fn install_android_deps() {
path.join("lib").to_str().unwrap() path.join("lib").to_str().unwrap()
) )
); );
println!("cargo:rustc-link-lib=ndk_compat");
println!("cargo:rustc-link-lib=oboe"); println!("cargo:rustc-link-lib=oboe");
println!("cargo:rustc-link-lib=c++"); println!("cargo:rustc-link-lib=c++");
println!("cargo:rustc-link-lib=OpenSLES"); println!("cargo:rustc-link-lib=OpenSLES");
@ -81,7 +78,7 @@ fn install_android_deps() {
fn main() { fn main() {
hbb_common::gen_version(); hbb_common::gen_version();
install_android_deps(); install_oboe();
// there is problem with cfg(target_os) in build.rs, so use our workaround // there is problem with cfg(target_os) in build.rs, so use our workaround
// let target_os = std::env::var("CARGO_CFG_TARGET_OS").unwrap(); // let target_os = std::env::var("CARGO_CFG_TARGET_OS").unwrap();
// if target_os == "android" || target_os == "ios" { // if target_os == "android" || target_os == "ios" {

View File

@ -1,7 +1,5 @@
#!/bin/bash #!/bin/bash
ANDROID_ABI=$1
# Build libyuv / opus / libvpx / oboe for Android # Build libyuv / opus / libvpx / oboe for Android
# Required: # Required:
# 1. set VCPKG_ROOT / ANDROID_NDK path environment variables # 1. set VCPKG_ROOT / ANDROID_NDK path environment variables
@ -26,25 +24,9 @@ TOOLCHAIN=$ANDROID_NDK/toolchains/llvm/prebuilt/$HOST_TAG
function build { function build {
ANDROID_ABI=$1 ANDROID_ABI=$1
VCPKG_TARGET=$2
case "$ANDROID_ABI" in NDK_LLVM_TARGET=$3
arm64-v8a) LIBVPX_TARGET=$4
ABI=aarch64-linux-android$API_LEVEL
VCPKG_TARGET=arm64-android
;;
armeabi-v7a)
ABI=armv7a-linux-androideabi$API_LEVEL
VCPKG_TARGET=arm-neon-android
;;
x86_64)
ABI=x86_64-linux-android$API_LEVEL
VCPKG_TARGET=x64-android
;;
x86)
ABI=i686-linux-android$API_LEVEL
VCPKG_TARGET=x86-android
;;
esac
PREFIX=$VCPKG_ROOT/installed/$VCPKG_TARGET/ PREFIX=$VCPKG_ROOT/installed/$VCPKG_TARGET/
@ -54,45 +36,29 @@ function build {
pushd $VCPKG_ROOT pushd $VCPKG_ROOT
$VCPKG_ROOT/vcpkg install opus --triplet $VCPKG_TARGET $VCPKG_ROOT/vcpkg install opus --triplet $VCPKG_TARGET
$VCPKG_ROOT/vcpkg install libyuv --triplet $VCPKG_TARGET $VCPKG_ROOT/vcpkg install libyuv --triplet $VCPKG_TARGET
$VCPKG_ROOT/vcpkg install aom --triplet $VCPKG_TARGET
$VCPKG_ROOT/vcpkg install cpu-features --triplet $VCPKG_TARGET
popd popd
echo "*** [$ANDROID_ABI][Finished] Build opus / libyuv from vcpkg" echo "*** [$ANDROID_ABI][Finished] Build opus / libyuv from vcpkg"
# 2 # 2
echo "*** [$ANDROID_ABI][Start] Build libvpx" echo "*** [$ANDROID_ABI][Start] Build libvpx"
pushd build/libvpx pushd build/libvpx
export AR=$TOOLCHAIN/bin/${NDK_LLVM_TARGET}-ar
export AS=$TOOLCHAIN/bin/${NDK_LLVM_TARGET}-as
export LD=$TOOLCHAIN/bin/${NDK_LLVM_TARGET}-ld.gold # if ndk < 22, use aarch64-linux-android-ld
export RANLIB=$TOOLCHAIN/bin/${NDK_LLVM_TARGET}-ranlib
export STRIP=$TOOLCHAIN/bin/${NDK_LLVM_TARGET}-strip
export AR=$TOOLCHAIN/bin/llvm-ar if [ $NDK_LLVM_TARGET == "arm-linux-androideabi" ]
export CC=$TOOLCHAIN/bin/"$ABI"-clang then
export CXX=$TOOLCHAIN/bin/"$ABI"-clang++ export CC=$TOOLCHAIN/bin/armv7a-linux-androideabi${API_LEVEL}-clang
export LD=$TOOLCHAIN/bin/"$ABI"-clang export CXX=$TOOLCHAIN/bin/armv7a-linux-androideabi${API_LEVEL}-clang++
export RANLIB=$TOOLCHAIN/bin/llvm-ranlib else
export STRIP=$TOOLCHAIN/bin/llvm-strip export CC=$TOOLCHAIN/bin/${NDK_LLVM_TARGET}${API_LEVEL}-clang
export CXX=$TOOLCHAIN/bin/${NDK_LLVM_TARGET}${API_LEVEL}-clang++
case "$ANDROID_ABI" in fi
arm64-v8a)
export AS=$TOOLCHAIN/bin/llvm-as
LIBVPX_EXTRA_BUILD_FLAGS="--target=arm64-android-gcc --enable-thumb --disable-runtime-cpu-detect"
;;
armeabi-v7a)
export AS=$TOOLCHAIN/bin/llvm-as
LIBVPX_EXTRA_BUILD_FLAGS="--target=armv7-android-gcc --enable-thumb --disable-neon --disable-runtime-cpu-detect"
;;
x86_64)
export AS=$TOOLCHAIN/bin/yasm
LIBVPX_EXTRA_BUILD_FLAGS="--target=x86_64-android-gcc --disable-avx --disable-avx2 --disable-avx512"
;;
x86)
export AS=$TOOLCHAIN/bin/yasm
LIBVPX_EXTRA_BUILD_FLAGS="--target=x86-android-gcc --disable-sse4_1 --disable-avx --disable-avx2 --disable-avx512"
;;
esac
make clean make clean
./configure --target=$LIBVPX_TARGET \
./configure \ --enable-pic
--enable-pic \
--disable-webm-io \ --disable-webm-io \
--disable-unit-tests \ --disable-unit-tests \
--disable-examples \ --disable-examples \
@ -100,13 +66,10 @@ function build {
--disable-postproc \ --disable-postproc \
--disable-tools \ --disable-tools \
--disable-docs \ --disable-docs \
--prefix=$PREFIX \ --prefix=$PREFIX
$LIBVPX_EXTRA_BUILD_FLAGS make -j5
make -j
make install make install
unset AR CC CXX LD RANLIB STRIP
popd popd
echo "*** [$ANDROID_ABI][Finished] Build libvpx" echo "*** [$ANDROID_ABI][Finished] Build libvpx"
@ -122,7 +85,7 @@ function build {
-DCMAKE_INSTALL_PREFIX=$PREFIX \ -DCMAKE_INSTALL_PREFIX=$PREFIX \
-DANDROID_ABI=$ANDROID_ABI \ -DANDROID_ABI=$ANDROID_ABI \
-DANDROID_PLATFORM=android-$API_LEVEL -DANDROID_PLATFORM=android-$API_LEVEL
make -j make -j5
make install make install
mv $PREFIX/lib/$ANDROID_ABI/liboboe.a $PREFIX/lib/ mv $PREFIX/lib/$ANDROID_ABI/liboboe.a $PREFIX/lib/
popd popd
@ -131,20 +94,31 @@ function build {
echo "*** [$ANDROID_ABI][All Finished]" echo "*** [$ANDROID_ABI][All Finished]"
} }
# Bump libvpx to 1.13.1 to fix CVE-2023-5217 git clone -b v1.11.0 --depth=1 https://github.com/webmproject/libvpx.git build/libvpx
git clone -b v1.13.1 --depth=1 https://github.com/webmproject/libvpx.git build/libvpx
git clone -b 1.6.1 --depth=1 https://github.com/google/oboe build/oboe git clone -b 1.6.1 --depth=1 https://github.com/google/oboe build/oboe
patch -N -d build/oboe -p1 < ../src/oboe.patch patch -N -d build/oboe -p1 < ../src/oboe.patch
if [ ! -z "$ANDROID_ABI" ]; then # VCPKG_TARGET ANDROID_ABI
build "$ANDROID_ABI" # arm64-android arm64-v8a
else # arm-android armeabi-v7a
build arm64-v8a # x64-android x86_64
build armeabi-v7a # x86-android x86
build x86_64
build x86
fi
[ -d "$VCPKG_ROOT/installed/arm-neon-android" ] && mv "$VCPKG_ROOT/installed/arm-neon-android" "$VCPKG_ROOT/installed/arm-android" # NDK_LLVM_TARGET
# aarch64-linux-android
# arm-linux-androideabi
# x86_64-linux-android
# i686-linux-android
rm -rf build # LIBVPX_TARGET :
# arm64-android-gcc
# armv7-android-gcc
# x86_64-android-gcc
# x86-android-gcc
# args: ANDROID_ABI VCPKG_TARGET NDK_LLVM_TARGET LIBVPX_TARGET
build arm64-v8a arm64-android aarch64-linux-android arm64-android-gcc
build armeabi-v7a arm-android arm-linux-androideabi armv7-android-gcc
# rm -rf build/libvpx
# rm -rf build/oboe