You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

cross_build_linux_arm_inference.sh 6.2 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. #!/usr/bin/env bash
  2. set -e
  3. ARCHS=("arm64-v8a" "armeabi-v7a-softfp" "armeabi-v7a-hardfp")
  4. BUILD_TYPE=Release
  5. MGE_WITH_CUDA=OFF
  6. MGE_ARMV8_2_FEATURE_FP16=OFF
  7. MGE_DISABLE_FLOAT16=OFF
  8. ARCH=arm64-v8a
  9. REMOVE_OLD_BUILD=false
  10. NINJA_VERBOSE=OFF
  11. NINJA_DRY_RUN=OFF
  12. SPECIFIED_TARGET="install/strip"
  13. CMAKE_C_FLAGS="-Wno-psabi"
  14. CMAKE_CXX_FLAGS="-Wno-psabi"
  15. READLINK=readlink
  16. OS=$(uname -s)
  17. if [ $OS = "Darwin" ];then
  18. READLINK=greadlink
  19. fi
  20. SRC_DIR=$($READLINK -f "`dirname $0`/../../")
  21. source $SRC_DIR/scripts/cmake-build/utils/utils.sh
  22. config_ninja_default_max_jobs
  23. echo "EXTRA_CMAKE_ARGS: ${EXTRA_CMAKE_ARGS}"
  24. function usage() {
  25. echo "$0 args1 args2 .."
  26. echo "available args detail:"
  27. echo "-d : Build with Debug mode, default Release mode"
  28. echo "-c : Build with CUDA, default without CUDA(for arm with cuda, example tx1)"
  29. echo "-f : enable MGE_ARMV8_2_FEATURE_FP16 for ARM64, need toolchain and hardware support"
  30. echo "-k : open MGE_DISABLE_FLOAT16 for NEON "
  31. echo "-a : config build arch available: ${ARCHS[@]}"
  32. echo "-r : remove old build dir before make, default off"
  33. echo "-v : ninja with verbose and explain, default off"
  34. echo "-n : ninja with -n dry run (don't run commands but act like they succeeded)"
  35. echo "-j : run N jobs in parallel for ninja, defaut is cpu_number + 2"
  36. echo "-e : build a specified target (always for debug, NOTICE: do not do strip/install target when use -e)"
  37. echo "-l : list CMakeLists.txt all options, can be use to config EXTRA_CMAKE_ARGS"
  38. echo "-h : show usage"
  39. echo "append other cmake config by config EXTRA_CMAKE_ARGS, for example, enable MGE_WITH_TEST and build with Debug mode:"
  40. echo "EXTRA_CMAKE_ARGS=\"-DMGE_WITH_TEST=ON\" $0 -d"
  41. exit -1
  42. }
  43. while getopts "lnvrkhdcfa:e:j:" arg
  44. do
  45. case $arg in
  46. j)
  47. NINJA_MAX_JOBS=$OPTARG
  48. echo "config NINJA_MAX_JOBS to ${NINJA_MAX_JOBS}"
  49. ;;
  50. l)
  51. echo "list CMakeLists.txt all options, can be used to config EXTRA_CMAKE_ARGS"
  52. show_cmakelist_options
  53. exit 0
  54. ;;
  55. d)
  56. echo "Build with Debug mode"
  57. BUILD_TYPE=Debug
  58. ;;
  59. c)
  60. echo "Build with CUDA"
  61. MGE_WITH_CUDA=ON
  62. ;;
  63. f)
  64. echo "enable MGE_ARMV8_2_FEATURE_FP16 for ARM64"
  65. MGE_ARMV8_2_FEATURE_FP16=ON
  66. ;;
  67. k)
  68. echo "open MGE_DISABLE_FLOAT16 for NEON"
  69. MGE_DISABLE_FLOAT16=ON
  70. ;;
  71. a)
  72. tmp_arch=null
  73. for arch in ${ARCHS[@]}; do
  74. if [ "$arch" = "$OPTARG" ]; then
  75. echo "CONFIG BUILD ARCH to : $OPTARG"
  76. tmp_arch=$OPTARG
  77. ARCH=$OPTARG
  78. break
  79. fi
  80. done
  81. if [ "$tmp_arch" = "null" ]; then
  82. echo "ERR args for arch (-a)"
  83. echo "available arch list: ${ARCHS[@]}"
  84. usage
  85. fi
  86. ;;
  87. h)
  88. echo "show usage"
  89. usage
  90. ;;
  91. r)
  92. echo "config REMOVE_OLD_BUILD=true"
  93. REMOVE_OLD_BUILD=true
  94. ;;
  95. v)
  96. echo "config NINJA_VERBOSE=ON"
  97. NINJA_VERBOSE=ON
  98. ;;
  99. n)
  100. echo "config NINJA_DRY_RUN=ON"
  101. NINJA_DRY_RUN=ON
  102. ;;
  103. e)
  104. SPECIFIED_TARGET=$OPTARG
  105. ;;
  106. ?)
  107. echo "unkonw argument"
  108. usage
  109. ;;
  110. esac
  111. done
  112. echo "----------------------------------------------------"
  113. echo "build config summary:"
  114. echo "BUILD_TYPE: $BUILD_TYPE"
  115. echo "MGE_WITH_CUDA: $MGE_WITH_CUDA"
  116. echo "MGE_ARMV8_2_FEATURE_FP16: $MGE_ARMV8_2_FEATURE_FP16"
  117. echo "MGE_DISABLE_FLOAT16: $MGE_DISABLE_FLOAT16"
  118. echo "SPECIFIED_TARGET: ${SPECIFIED_TARGET}"
  119. echo "NINJA_MAX_JOBS: ${NINJA_MAX_JOBS}"
  120. echo "ARCH: $ARCH"
  121. echo "----------------------------------------------------"
  122. if [[ $OS =~ "NT" ]]; then
  123. echo "BUILD in NT ..."
  124. fi
  125. if [ ! $OS = "Linux" ] && [ $MGE_WITH_CUDA = "ON" ];then
  126. echo "cross build for arm with cuda only support from Linux"
  127. exit -1
  128. fi
  129. if [ $MGE_WITH_CUDA = "ON" ] && [ ! $ARCH = "arm64-v8a" ];then
  130. echo "arm with cuda only support ARCH: arm64-v8a"
  131. exit -1
  132. fi
  133. if [ $MGE_WITH_CUDA = "OFF" ];then
  134. echo "config -Werror=unused-parameter when cuda off for CI check"
  135. CMAKE_C_FLAGS="-Werror=unused-parameter -Wno-psabi"
  136. CMAKE_CXX_FLAGS="-Werror=unused-parameter -Wno-psabi"
  137. fi
  138. function cmake_build() {
  139. BUILD_DIR=$SRC_DIR/build_dir/gnu-linux/MGE_WITH_CUDA_$3/$1/$BUILD_TYPE/build
  140. INSTALL_DIR=$BUILD_DIR/../install
  141. TOOLCHAIN=$SRC_DIR/toolchains/$2
  142. MGE_WITH_CUDA=$3
  143. echo "build dir: $BUILD_DIR"
  144. echo "install dir: $INSTALL_DIR"
  145. echo "build type: $BUILD_TYPE"
  146. echo "build toolchain: $TOOLCHAIN"
  147. echo "MGE_WITH_CUDA: $MGE_WITH_CUDA"
  148. try_remove_old_build $REMOVE_OLD_BUILD $BUILD_DIR $INSTALL_DIR
  149. echo "create build dir"
  150. mkdir -p $BUILD_DIR
  151. mkdir -p $INSTALL_DIR
  152. cd_real_build_dir $BUILD_DIR
  153. bash -c "cmake -G Ninja \
  154. -DCMAKE_C_FLAGS=$CMAKE_C_FLAGS \
  155. -DCMAKE_CXX_FLAGS=$CMAKE_CXX_FLAGS \
  156. -DCMAKE_TOOLCHAIN_FILE=$TOOLCHAIN \
  157. -DCMAKE_BUILD_TYPE=$BUILD_TYPE \
  158. -DMGE_INFERENCE_ONLY=ON \
  159. -DMGE_WITH_CUDA=$MGE_WITH_CUDA \
  160. -DMGE_ARMV8_2_FEATURE_FP16=$MGE_ARMV8_2_FEATURE_FP16 \
  161. -DMGE_DISABLE_FLOAT16=$MGE_DISABLE_FLOAT16 \
  162. -DCMAKE_INSTALL_PREFIX=$INSTALL_DIR \
  163. ${EXTRA_CMAKE_ARGS} \
  164. $SRC_DIR "
  165. config_ninja_target_cmd ${NINJA_VERBOSE} "OFF" "${SPECIFIED_TARGET}" ${NINJA_DRY_RUN} ${NINJA_MAX_JOBS}
  166. bash -c "${NINJA_CMD}"
  167. }
  168. build_flatc $SRC_DIR $REMOVE_OLD_BUILD
  169. toolchain=null
  170. if [ "$ARCH" = "arm64-v8a" ]; then
  171. toolchain="aarch64-linux-gnu.toolchain.cmake"
  172. elif [ "$ARCH" = "armeabi-v7a-hardfp" ]; then
  173. toolchain="arm-linux-gnueabihf.toolchain.cmake"
  174. elif [ "$ARCH" = "armeabi-v7a-softfp" ]; then
  175. toolchain="arm-linux-gnueabi.toolchain.cmake"
  176. else
  177. echo "ERR CONFIG ABORT NOW!!"
  178. exit -1
  179. fi
  180. cmake_build $ARCH $toolchain $MGE_WITH_CUDA

MegEngine 安装包中集成了使用 GPU 运行代码所需的 CUDA 环境,不用区分 CPU 和 GPU 版。 如果想要运行 GPU 程序,请确保机器本身配有 GPU 硬件设备并安装好驱动。 如果你想体验在云端 GPU 算力平台进行深度学习开发的感觉,欢迎访问 MegStudio 平台