Merge pull request #6262 from rustdesk/revert-6257-android-fixes
Revert "Fixes for Android (ndk r26b)"
This commit is contained in:
		
						commit
						6782f92703
					
				
							
								
								
									
										7
									
								
								build.rs
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								build.rs
									
									
									
									
									
								
							| @ -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" {
 | ||||||
|  | |||||||
| @ -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 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user