From 6f951bb11a4dc3e0b48662d68dd4e8e1dfba5acb Mon Sep 17 00:00:00 2001 From: Andrea Cavalli Date: Thu, 11 May 2023 17:23:48 +0200 Subject: [PATCH] Add armhf and arm64 ssl3 --- ...natives.yaml => platform_natives.yaml.off} | 9 +- .../scripts/build_linux_arm64_ssl3.sh | 87 +++++++++++++++++++ .../scripts/build_linux_armhf_ssl3.sh | 87 +++++++++++++++++++ .../scripts/install_deps_linux_arm64_ssl1.sh | 6 +- .../scripts/install_deps_linux_arm64_ssl3.sh | 30 +++++++ .../{tdapi_file.yaml => tdapi_file.yaml.off} | 0 .../toolchains/toolchain_arm64.cmake | 21 ++++- .../toolchains/toolchain_armhf.cmake | 75 ++++++++++++++++ 8 files changed, 304 insertions(+), 11 deletions(-) rename .github/workflows/{platform_natives.yaml => platform_natives.yaml.off} (97%) create mode 100755 .github/workflows/scripts/build_linux_arm64_ssl3.sh create mode 100755 .github/workflows/scripts/build_linux_armhf_ssl3.sh create mode 100755 .github/workflows/scripts/install_deps_linux_arm64_ssl3.sh rename .github/workflows/{tdapi_file.yaml => tdapi_file.yaml.off} (100%) create mode 100644 .github/workflows/toolchains/toolchain_armhf.cmake diff --git a/.github/workflows/platform_natives.yaml b/.github/workflows/platform_natives.yaml.off similarity index 97% rename from .github/workflows/platform_natives.yaml rename to .github/workflows/platform_natives.yaml.off index 27b881a..a238350 100644 --- a/.github/workflows/platform_natives.yaml +++ b/.github/workflows/platform_natives.yaml.off @@ -14,13 +14,14 @@ jobs: matrix: include: # todo: re-enable - #- { os: ubuntu-20.04, type: "linux-386-ssl1" } + - { os: ubuntu-20.04, type: "linux-386-ssl1" } - { os: ubuntu-20.04, type: "linux_amd64_ssl1" } - { os: ubuntu-20.04, type: "linux_arm64_ssl1" } - #- { os: ubuntu-20.04, type: "linux-s390x-ssl1" } - #- { os: ubuntu-20.04, type: "linux-ppc64le-ssl1" } + - { os: ubuntu-20.04, type: "linux-s390x-ssl1" } + - { os: ubuntu-20.04, type: "linux-ppc64le-ssl1" } + - { os: ubuntu-20.04, type: "linux-riscv64-ssl1" } - { os: ubuntu-22.04, type: "linux_amd64_ssl3" } - #- { os: ubuntu-22.04, type: "linux_arm64_ssl3" } + - { os: ubuntu-22.04, type: "linux_arm64_ssl3" } #- { os: windows-2019, type: "windows_amd64", vcpkgCommitId: "6ca56aeb457f033d344a7106cb3f9f1abf8f4e98", triplet: "x64-windows-static" } #- { os: macos-12, type: "macos-amd64" } steps: diff --git a/.github/workflows/scripts/build_linux_arm64_ssl3.sh b/.github/workflows/scripts/build_linux_arm64_ssl3.sh new file mode 100755 index 0000000..0976a1f --- /dev/null +++ b/.github/workflows/scripts/build_linux_arm64_ssl3.sh @@ -0,0 +1,87 @@ +#!/bin/bash -ex +# Ubuntu 22.04 +REVISION="${REVISION:-1.0.0.0-SNAPSHOT}" +TOOLCHAIN_FILE="$(readlink -e ./.github/workflows/toolchains/toolchain_arm64.cmake)" + +# Create missing dirs +rm -rf implementations/tdlight/td_tools_build implementations/tdlight/build api/target-legacy api/target api/.ci-friendly-pom.xml implementations/tdlight/td/generate/auto natives/src/main/java/it/tdlight/jni natives/build natives/tdjni_bin natives/tdjni_docs +mkdir -p implementations/tdlight/build implementations/tdlight/build/td_bin/bin implementations/tdlight/td_tools_build/java/it/tdlight/jni api/src/main/java-legacy/it/tdlight/jni api/src/main/java-sealed/it/tdlight/jni natives/src/main/java/it/tdlight/jni natives/build natives/tdjni_bin natives/tdjni_docs + +# machine-specific flags +HOST_CMAKE_C_COMPILER="/usr/bin/clang-14" +HOST_CMAKE_CXX_COMPILER="/usr/bin/clang++-14" +HOST_CMAKE_C_FLAGS="-fuse-ld=lld" +HOST_CMAKE_CXX_FLAGS="${HOST_CMAKE_C_FLAGS} -stdlib=libc++" +HOST_CMAKE_EXE_LINKER_FLAGS="-lc++ -lc++abi -fuse-ld=lld -rtlib=compiler-rt -unwindlib=libunwind" + +# Build tdlib tools +cd implementations/tdlight/td_tools_build +CXXFLAGS="-stdlib=libc++" CC="$HOST_CMAKE_C_COMPILER" CXX="$HOST_CMAKE_CXX_COMPILER" cmake \ + -DCMAKE_C_COMPILER="${HOST_CMAKE_C_COMPILER}" \ + -DCMAKE_CXX_COMPILER="${HOST_CMAKE_CXX_COMPILER}" \ + -DCMAKE_C_FLAGS="${CMAKE_C_FLAGS} ${HOST_CMAKE_C_FLAGS}" \ + -DCMAKE_CXX_FLAGS="${CMAKE_CXX_FLAGS} ${HOST_CMAKE_CXX_FLAGS}" \ + -DCMAKE_EXE_LINKER_FLAGS="${CMAKE_EXE_LINKER_FLAGS} ${HOST_CMAKE_EXE_LINKER_FLAGS}" \ + \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_C_COMPILER_LAUNCHER=sccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=sccache \ + -DCMAKE_C_FLAGS_RELEASE="" \ + -DCMAKE_CXX_FLAGS_RELEASE="-O0 -DNDEBUG" \ + -DTD_ENABLE_LTO=OFF \ + -DTD_ENABLE_JNI=ON \ + .. +cmake --build . --target prepare_cross_compiling "-j$(nproc)" +cmake --build . --target td_generate_java_api "-j$(nproc)" +cd ../../../ + +# Generate TdApi.java +./implementations/tdlight/td_tools_build/td/generate/td_generate_java_api TdApi "./implementations/tdlight/td/generate/auto/tlo/td_api.tlo" "./natives/src/main/java" "it/tdlight/jni" + + +# Optimization flags +export CMAKE_C_FLAGS="${CMAKE_C_FLAGS}" +export CMAKE_CXX_FLAGS="${CMAKE_CXX_FLAGS} -fno-omit-frame-pointer -ffunction-sections -fdata-sections -fno-exceptions -fno-rtti" +export CMAKE_SHARED_LINKER_FLAGS="${CMAKE_SHARED_LINKER_FLAGS} -Wl,--gc-sections -Wl,--exclude-libs,ALL" +export CMAKE_CXX_FLAGS="${CMAKE_CXX_FLAGS} -flto=thin -O3" + +# Build tdlib +cd implementations/tdlight/build +INSTALL_PREFIX="$(readlink -e ./td_bin/)" +INSTALL_BINDIR="$(readlink -e ./td_bin/bin)" +cmake \ + -DCMAKE_VERBOSE_MAKEFILE:BOOL=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_C_COMPILER_LAUNCHER=sccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=sccache \ + -DTD_SKIP_BENCHMARK=ON -DTD_SKIP_TEST=ON -DTD_SKIP_TG_CLI=ON \ + -DTD_ENABLE_LTO=ON \ + -DTD_ENABLE_JNI=ON \ + -DCMAKE_INSTALL_PREFIX:PATH="$INSTALL_PREFIX" \ + -DCMAKE_INSTALL_BINDIR:PATH="$INSTALL_BINDIR" \ + -DCMAKE_TOOLCHAIN_FILE="${TOOLCHAIN_FILE}" \ + .. +cmake --build . --target install --config Release "-j$(nproc)" +cd ../../../ + +cd natives/build +cmake \ + -DCMAKE_VERBOSE_MAKEFILE:BOOL=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_C_COMPILER_LAUNCHER=sccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=sccache \ + -DTD_GENERATED_BINARIES_DIR="$(readlink -e ../../implementations/tdlight/td_tools_build/td/generate)" \ + -DTD_SRC_DIR="$(readlink -e ../../implementations/tdlight)" \ + -DTD_ENABLE_LTO=ON \ + -DTDNATIVES_BIN_DIR="$(readlink -e ../tdjni_bin/)" \ + -DTDNATIVES_DOCS_BIN_DIR="$(readlink -e ../tdjni_docs/)" \ + -DTd_DIR:PATH="$(readlink -e ../../implementations/tdlight/build/td_bin/lib/cmake/Td)" \ + -DJAVA_SRC_DIR="$(readlink -e ../src/main/java)" \ + -DTDNATIVES_CPP_SRC_DIR="$(readlink -e ../src/main/cpp)" \ + -DCMAKE_TOOLCHAIN_FILE="${TOOLCHAIN_FILE}" \ + ../src/main/cpp +cmake --build . --target install --config Release "-j$(nproc)" +cd .. +mkdir -p src/main/resources/META-INF/tdlightjni/ +mv tdjni_bin/libtdjni.so src/main/resources/META-INF/tdlightjni/libtdjni.linux_arm64_ssl3.so +mvn -B -f pom.xml -Drevision="$REVISION" -Dnative.type.classifier=linux_arm64_ssl3 package diff --git a/.github/workflows/scripts/build_linux_armhf_ssl3.sh b/.github/workflows/scripts/build_linux_armhf_ssl3.sh new file mode 100755 index 0000000..f9259f1 --- /dev/null +++ b/.github/workflows/scripts/build_linux_armhf_ssl3.sh @@ -0,0 +1,87 @@ +#!/bin/bash -ex +# Ubuntu 22.04 +REVISION="${REVISION:-1.0.0.0-SNAPSHOT}" +TOOLCHAIN_FILE="$(readlink -e ./.github/workflows/toolchains/toolchain_armhf.cmake)" + +# Create missing dirs +rm -rf implementations/tdlight/td_tools_build implementations/tdlight/build api/target-legacy api/target api/.ci-friendly-pom.xml implementations/tdlight/td/generate/auto natives/src/main/java/it/tdlight/jni natives/build natives/tdjni_bin natives/tdjni_docs +mkdir -p implementations/tdlight/build implementations/tdlight/build/td_bin/bin implementations/tdlight/td_tools_build/java/it/tdlight/jni api/src/main/java-legacy/it/tdlight/jni api/src/main/java-sealed/it/tdlight/jni natives/src/main/java/it/tdlight/jni natives/build natives/tdjni_bin natives/tdjni_docs + +# machine-specific flags +HOST_CMAKE_C_COMPILER="/usr/bin/clang-14" +HOST_CMAKE_CXX_COMPILER="/usr/bin/clang++-14" +HOST_CMAKE_C_FLAGS="-fuse-ld=lld" +HOST_CMAKE_CXX_FLAGS="${HOST_CMAKE_C_FLAGS} -stdlib=libc++" +HOST_CMAKE_EXE_LINKER_FLAGS="-lc++ -lc++abi -fuse-ld=lld -rtlib=compiler-rt -unwindlib=libunwind" + +# Build tdlib tools +cd implementations/tdlight/td_tools_build +CXXFLAGS="-stdlib=libc++" CC="$HOST_CMAKE_C_COMPILER" CXX="$HOST_CMAKE_CXX_COMPILER" cmake \ + -DCMAKE_C_COMPILER="${HOST_CMAKE_C_COMPILER}" \ + -DCMAKE_CXX_COMPILER="${HOST_CMAKE_CXX_COMPILER}" \ + -DCMAKE_C_FLAGS="${CMAKE_C_FLAGS} ${HOST_CMAKE_C_FLAGS}" \ + -DCMAKE_CXX_FLAGS="${CMAKE_CXX_FLAGS} ${HOST_CMAKE_CXX_FLAGS}" \ + -DCMAKE_EXE_LINKER_FLAGS="${CMAKE_EXE_LINKER_FLAGS} ${HOST_CMAKE_EXE_LINKER_FLAGS}" \ + \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_C_COMPILER_LAUNCHER=sccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=sccache \ + -DCMAKE_C_FLAGS_RELEASE="" \ + -DCMAKE_CXX_FLAGS_RELEASE="-O0 -DNDEBUG" \ + -DTD_ENABLE_LTO=OFF \ + -DTD_ENABLE_JNI=ON \ + .. +cmake --build . --target prepare_cross_compiling "-j$(nproc)" +cmake --build . --target td_generate_java_api "-j$(nproc)" +cd ../../../ + +# Generate TdApi.java +./implementations/tdlight/td_tools_build/td/generate/td_generate_java_api TdApi "./implementations/tdlight/td/generate/auto/tlo/td_api.tlo" "./natives/src/main/java" "it/tdlight/jni" + + +# Optimization flags +export CMAKE_C_FLAGS="${CMAKE_C_FLAGS}" +export CMAKE_CXX_FLAGS="${CMAKE_CXX_FLAGS} -fno-omit-frame-pointer -ffunction-sections -fdata-sections -fno-exceptions -fno-rtti" +export CMAKE_SHARED_LINKER_FLAGS="${CMAKE_SHARED_LINKER_FLAGS} -Wl,--gc-sections -Wl,--exclude-libs,ALL" +export CMAKE_CXX_FLAGS="${CMAKE_CXX_FLAGS} -flto=thin -O3" + +# Build tdlib +cd implementations/tdlight/build +INSTALL_PREFIX="$(readlink -e ./td_bin/)" +INSTALL_BINDIR="$(readlink -e ./td_bin/bin)" +cmake \ + -DCMAKE_VERBOSE_MAKEFILE:BOOL=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_C_COMPILER_LAUNCHER=sccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=sccache \ + -DTD_SKIP_BENCHMARK=ON -DTD_SKIP_TEST=ON -DTD_SKIP_TG_CLI=ON \ + -DTD_ENABLE_LTO=ON \ + -DTD_ENABLE_JNI=ON \ + -DCMAKE_INSTALL_PREFIX:PATH="$INSTALL_PREFIX" \ + -DCMAKE_INSTALL_BINDIR:PATH="$INSTALL_BINDIR" \ + -DCMAKE_TOOLCHAIN_FILE="${TOOLCHAIN_FILE}" \ + .. +cmake --build . --target install --config Release "-j$(nproc)" +cd ../../../ + +cd natives/build +cmake \ + -DCMAKE_VERBOSE_MAKEFILE:BOOL=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_C_COMPILER_LAUNCHER=sccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=sccache \ + -DTD_GENERATED_BINARIES_DIR="$(readlink -e ../../implementations/tdlight/td_tools_build/td/generate)" \ + -DTD_SRC_DIR="$(readlink -e ../../implementations/tdlight)" \ + -DTD_ENABLE_LTO=ON \ + -DTDNATIVES_BIN_DIR="$(readlink -e ../tdjni_bin/)" \ + -DTDNATIVES_DOCS_BIN_DIR="$(readlink -e ../tdjni_docs/)" \ + -DTd_DIR:PATH="$(readlink -e ../../implementations/tdlight/build/td_bin/lib/cmake/Td)" \ + -DJAVA_SRC_DIR="$(readlink -e ../src/main/java)" \ + -DTDNATIVES_CPP_SRC_DIR="$(readlink -e ../src/main/cpp)" \ + -DCMAKE_TOOLCHAIN_FILE="${TOOLCHAIN_FILE}" \ + ../src/main/cpp +cmake --build . --target install --config Release "-j$(nproc)" +cd .. +mkdir -p src/main/resources/META-INF/tdlightjni/ +mv tdjni_bin/libtdjni.so src/main/resources/META-INF/tdlightjni/libtdjni.linux_armhf_ssl3.so +mvn -B -f pom.xml -Drevision="$REVISION" -Dnative.type.classifier=linux_armhf_ssl3 package diff --git a/.github/workflows/scripts/install_deps_linux_arm64_ssl1.sh b/.github/workflows/scripts/install_deps_linux_arm64_ssl1.sh index 078fa83..533f98c 100755 --- a/.github/workflows/scripts/install_deps_linux_arm64_ssl1.sh +++ b/.github/workflows/scripts/install_deps_linux_arm64_ssl1.sh @@ -5,9 +5,9 @@ export DEBIAN_FRONTEND=noninteractive dpkg --add-architecture arm64 sed 's/deb http/deb \[arch=amd64,i386\] http/' -i /etc/apt/sources.list -echo "deb [arch=arm64] http://ports.ubuntu.com/ $(lsb_release -cs) main universe restricted multiverse" >> /etc/apt/sources.list -echo "deb [arch=arm64] http://ports.ubuntu.com/ $(lsb_release -cs)-updates main universe restricted multiverse" >> /etc/apt/sources.list -echo "deb [arch=arm64] http://ports.ubuntu.com/ $(lsb_release -cs)-security main universe restricted multiverse" >> /etc/apt/sources.list +echo "deb [arch=arm64,armhf,ppc64el,riscv64,s390x] http://ports.ubuntu.com/ $(lsb_release -cs) main universe restricted multiverse" >> /etc/apt/sources.list +echo "deb [arch=arm64,armhf,ppc64el,riscv64,s390x] http://ports.ubuntu.com/ $(lsb_release -cs)-updates main universe restricted multiverse" >> /etc/apt/sources.list +echo "deb [arch=arm64,armhf,ppc64el,riscv64,s390x] http://ports.ubuntu.com/ $(lsb_release -cs)-security main universe restricted multiverse" >> /etc/apt/sources.list apt-get --assume-yes update diff --git a/.github/workflows/scripts/install_deps_linux_arm64_ssl3.sh b/.github/workflows/scripts/install_deps_linux_arm64_ssl3.sh new file mode 100755 index 0000000..e30f72d --- /dev/null +++ b/.github/workflows/scripts/install_deps_linux_arm64_ssl3.sh @@ -0,0 +1,30 @@ +#!/bin/bash -ex +# Ubuntu 22.04 + +export DEBIAN_FRONTEND=noninteractive + +dpkg --add-architecture arm64 +sed 's/deb http/deb \[arch=amd64,i386\] http/' -i /etc/apt/sources.list +echo "deb [arch=arm64,armhf,ppc64el,riscv64,s390x] http://ports.ubuntu.com/ $(lsb_release -cs) main universe restricted multiverse" >> /etc/apt/sources.list +echo "deb [arch=arm64,armhf,ppc64el,riscv64,s390x] http://ports.ubuntu.com/ $(lsb_release -cs)-updates main universe restricted multiverse" >> /etc/apt/sources.list +echo "deb [arch=arm64,armhf,ppc64el,riscv64,s390x] http://ports.ubuntu.com/ $(lsb_release -cs)-security main universe restricted multiverse" >> /etc/apt/sources.list + +apt-get --assume-yes update + +# Install and bypass a bug in the cross-platform libc++ packages +apt-get --assume-yes autoremove libc++-14-dev libc++abi-14-dev libc++1-14 libc++abi1-14 || true +apt-get --assume-yes -o Dpkg::Options::="--force-overwrite" install libc++-14-dev:arm64 libc++abi-14-dev:arm64 +rm -r /usr/lib/aarch64-linux-gnu/libc++.so.1.0 /usr/lib/aarch64-linux-gnu/libc++abi.so.1.0 /usr/lib/aarch64-linux-gnu/libc++abi.so +mv /usr/lib/llvm-14/lib/libc++.so.1.0 /usr/lib/aarch64-linux-gnu/ +mv /usr/lib/llvm-14/lib/libc++abi.so.1.0 /usr/lib/aarch64-linux-gnu/ +mv /usr/lib/llvm-14/lib/libc++abi.so /usr/lib/aarch64-linux-gnu/ +apt-get --assume-yes -o Dpkg::Options::="--force-overwrite" install libc++-14-dev libc++abi-14-dev +# End libc++ packages bugfix + +# Add arm64 common files +apt-get download libclang-common-14-dev:arm64 +dpkg-deb -xv libclang-common-14-dev_*_arm64.deb / + + +# Install dependencies +apt-get --assume-yes install libssl-dev:arm64 zlib1g-dev:arm64 openjdk-8-jdk-headless:arm64 libgcc-12-dev:arm64 libc6-dev:arm64 libunwind-14-dev:arm64 diff --git a/.github/workflows/tdapi_file.yaml b/.github/workflows/tdapi_file.yaml.off similarity index 100% rename from .github/workflows/tdapi_file.yaml rename to .github/workflows/tdapi_file.yaml.off diff --git a/.github/workflows/toolchains/toolchain_arm64.cmake b/.github/workflows/toolchains/toolchain_arm64.cmake index 3a1b348..703b2a7 100644 --- a/.github/workflows/toolchains/toolchain_arm64.cmake +++ b/.github/workflows/toolchains/toolchain_arm64.cmake @@ -3,13 +3,26 @@ SET(CMAKE_SYSTEM_NAME Linux) set(CMAKE_SYSTEM_PROCESSOR aarch64) set(TARGET_TRIPLE aarch64-linux-gnu) +if(EXISTS "/usr/bin/clang-10") + set(CMAKE_C_COMPILER /usr/bin/clang-10) + set(CMAKE_CXX_COMPILER /usr/bin/clang++-10) + set(CMAKE_ASM_COMPILER /usr/bin/clang-10) + set(CMAKE_AR "/usr/bin/llvm-ar-10" CACHE FILEPATH "" FORCE) +elseif(EXISTS "/usr/bin/clang-14") + set(CMAKE_C_COMPILER /usr/bin/clang-14) + set(CMAKE_CXX_COMPILER /usr/bin/clang++-14) + set(CMAKE_ASM_COMPILER /usr/bin/clang-14) + set(CMAKE_AR "/usr/bin/llvm-ar-14" CACHE FILEPATH "" FORCE) +else() + set(CMAKE_C_COMPILER /usr/bin/clang) + set(CMAKE_CXX_COMPILER /usr/bin/clang++) + set(CMAKE_ASM_COMPILER /usr/bin/clang) + set(CMAKE_AR "/usr/bin/llvm-ar" CACHE FILEPATH "" FORCE) +endif() + set(CMAKE_C_COMPILER_TARGET ${TARGET_TRIPLE}) -set(CMAKE_C_COMPILER /usr/bin/clang-10) set(CMAKE_CXX_COMPILER_TARGET ${TARGET_TRIPLE}) -set(CMAKE_CXX_COMPILER /usr/bin/clang++-10) set(CMAKE_ASM_COMPILER_TARGET ${TARGET_TRIPLE}) -set(CMAKE_ASM_COMPILER /usr/bin/clang-10) -set(CMAKE_AR "/usr/bin/llvm-ar-10" CACHE FILEPATH "" FORCE) set(CMAKE_FIND_ROOT_PATH /usr/aarch64-linux-gnu /usr/lib/aarch64-linux-gnu /usr/include/aarch64-linux-gnu /usr/bin/aarch64-linux-gnu) set(CMAKE_INCLUDE_PATH /usr/include/aarch64-linux-gnu) diff --git a/.github/workflows/toolchains/toolchain_armhf.cmake b/.github/workflows/toolchains/toolchain_armhf.cmake new file mode 100644 index 0000000..2ca5fc7 --- /dev/null +++ b/.github/workflows/toolchains/toolchain_armhf.cmake @@ -0,0 +1,75 @@ +set(CMAKE_CROSSCOMPILING TRUE) +SET(CMAKE_SYSTEM_NAME Linux) +set(CMAKE_SYSTEM_PROCESSOR arm) +set(TARGET_TRIPLE arm-linux-gnueabihf + +if(EXISTS "/usr/bin/clang-10") + set(CMAKE_C_COMPILER /usr/bin/clang-10) + set(CMAKE_CXX_COMPILER /usr/bin/clang++-10) + set(CMAKE_ASM_COMPILER /usr/bin/clang-10) + set(CMAKE_AR "/usr/bin/llvm-ar-10" CACHE FILEPATH "" FORCE) +elseif(EXISTS "/usr/bin/clang-14") + set(CMAKE_C_COMPILER /usr/bin/clang-14) + set(CMAKE_CXX_COMPILER /usr/bin/clang++-14) + set(CMAKE_ASM_COMPILER /usr/bin/clang-14) + set(CMAKE_AR "/usr/bin/llvm-ar-14" CACHE FILEPATH "" FORCE) +else() + set(CMAKE_C_COMPILER /usr/bin/clang) + set(CMAKE_CXX_COMPILER /usr/bin/clang++) + set(CMAKE_ASM_COMPILER /usr/bin/clang) + set(CMAKE_AR "/usr/bin/llvm-ar" CACHE FILEPATH "" FORCE) +endif() + +set(CMAKE_C_COMPILER_TARGET ${TARGET_TRIPLE}) +set(CMAKE_CXX_COMPILER_TARGET ${TARGET_TRIPLE}) +set(CMAKE_ASM_COMPILER_TARGET ${TARGET_TRIPLE}) + +set(CMAKE_FIND_ROOT_PATH /usr/aarch64-linux-gnu /usr/lib/aarch64-linux-gnu /usr/include/aarch64-linux-gnu /usr/bin/aarch64-linux-gnu) +set(CMAKE_INCLUDE_PATH /usr/include/aarch64-linux-gnu) +set(CMAKE_LIBRARY_PATH /usr/lib/aarch64-linux-gnu) +set(CMAKE_PROGRAM_PATH /usr/bin/aarch64-linux-gnu) +#set(CMAKE_SYSROOT /usr/lib/aarch64-linux-gnu) +#set(OPENSSL_INCLUDE_DIR /usr/include/openssl) +#include_directories("/usr/include/openssl") + + +# Set various compiler flags +set(CMAKE_EXE_LINKER_FLAGS_INIT "-fuse-ld=lld -rtlib=compiler-rt -unwindlib=libunwind") +set(CMAKE_MODULE_LINKER_FLAGS_INIT "-fuse-ld=lld -rtlib=compiler-rt -unwindlib=libunwind") +set(CMAKE_SHARED_LINKER_FLAGS_INIT "-fuse-ld=lld -rtlib=compiler-rt -unwindlib=libunwind") +set(CMAKE_CXX_FLAGS_INIT "-stdlib=libc++") + + +# Use our definitions for compiler tools +SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) + +# Search for libraries and headers in the target directories only +#SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) +#SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) +#SET(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY) + +# This must be set or compiler checks fail when linking +set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY) + +#include_directories("${CROSS_OPENJDK_PATH}/include/linux") + +SET(JAVA_HOME "/usr/lib/jvm/default-java/") +SET(JAVA_CROSS_HOME "/usr/lib/jvm/java-1.8.0-openjdk-arm64") +SET(JAVA_INCLUDE_PATH "${JAVA_HOME}/include") +SET(JAVA_AWT_INCLUDE_PATH "${JAVA_HOME}/include") +SET(JAVA_INCLUDE_PATH2 "${JAVA_HOME}/include/linux") + +SET(JAVA_JVM_LIBRARY "${JAVA_CROSS_HOME}/jre/lib/aarch64/server/libjvm.so") +SET(JAVA_AWT_LIBRARY "${JAVA_CROSS_HOME}/jre/lib/aarch64/libawt.so") + + +# Only on aarch64 & armhf architecture +set(CMAKE_THREAD_LIBS_INIT "-lpthread") +set(CMAKE_HAVE_THREADS_LIBRARY 1) +set(CMAKE_USE_WIN32_THREADS_INIT 0) +set(CMAKE_USE_PTHREADS_INIT 1) +set(THREADS_PREFER_PTHREAD_FLAG ON) + +# Use LLD on linux +#add_link_options("-fuse-ld=lld" "-rtlib=compiler-rt" "-unwindlib=libunwind" "-Wl,--as-needed") +#add_link_options("-fuse-ld=lld")