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.

build.sh 16 kB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  1. #!/bin/bash
  2. # Copyright 2019 Huawei Technologies Co., Ltd
  3. #
  4. # Licensed under the Apache License, Version 2.0 (the "License");
  5. # you may not use this file except in compliance with the License.
  6. # You may obtain a copy of the License at
  7. #
  8. # http://www.apache.org/licenses/LICENSE-2.0
  9. #
  10. # Unless required by applicable law or agreed to in writing, software
  11. # distributed under the License is distributed on an "AS IS" BASIS,
  12. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. # See the License for the specific language governing permissions and
  14. # limitations under the License.
  15. # ============================================================================
  16. set -e
  17. BASEPATH=$(cd "$(dirname $0)"; pwd)
  18. CUDA_PATH=""
  19. CUDNN_PATH=""
  20. export BUILD_PATH="${BASEPATH}/build/"
  21. # print usage message
  22. usage()
  23. {
  24. echo "Usage:"
  25. echo "bash build.sh [-d] [-r] [-v] [-c on|off] [-t on|off] [-g on|off] [-h] [-b ge] [-m infer|train] \\"
  26. echo " [-a on|off] [-Q on|off] [-p on|off] [-i] [-L] [-R] [-D on|off] [-j[n]] [-e gpu|d|cpu] \\"
  27. echo " [-P on|off] [-z [on|off]] [-M on|off] [-V 9.2|10.1] [-I] [-K] [-B on|off]"
  28. echo ""
  29. echo "Options:"
  30. echo " -d Debug mode"
  31. echo " -r Release mode, default mode"
  32. echo " -v Display build command"
  33. echo " -c Enable code coverage, default off"
  34. echo " -t Run testcases, default on"
  35. echo " -g Use glog to output log, default on"
  36. echo " -h Print usage"
  37. echo " -b Select other backend, available: \\"
  38. echo " ge:graph engine"
  39. echo " -m Select graph engine backend mode, available: infer, train, default is infer"
  40. echo " -a Enable ASAN, default off"
  41. echo " -p Enable pipeline profile, print to stdout, default off"
  42. echo " -R Enable pipeline profile, record to json, default off"
  43. echo " -i Enable increment building, default off"
  44. echo " -L Enable load ANF-IR as input of 'infer', default off"
  45. echo " -j[n] Set the threads when building (Default: -j8)"
  46. echo " -e Use gpu, d or cpu"
  47. echo " -P Enable dump anf graph to file in ProtoBuffer format, default on"
  48. echo " -Q Enable dump memory, default off"
  49. echo " -D Enable dumping of function graph ir, default on"
  50. echo " -z Compile dataset & mindrecord, default on"
  51. echo " -M Enable MPI and NCCL for GPU training, gpu default on"
  52. echo " -V Specify the minimum required cuda version, default CUDA 10.1"
  53. echo " -I Compile predict, default off"
  54. echo " -K Compile with AKG, default off"
  55. echo " -s Enable serving module, default off"
  56. echo " -B Enable debugger, default off"
  57. }
  58. # check value of input is 'on' or 'off'
  59. # usage: check_on_off arg_value arg_name
  60. check_on_off()
  61. {
  62. if [[ "X$1" != "Xon" && "X$1" != "Xoff" ]]; then
  63. echo "Invalid value $1 for option -$2"
  64. usage
  65. exit 1
  66. fi
  67. }
  68. # check and set options
  69. checkopts()
  70. {
  71. # Init default values of build options
  72. THREAD_NUM=8
  73. DEBUG_MODE="off"
  74. VERBOSE=""
  75. ENABLE_COVERAGE="off"
  76. RUN_TESTCASES="off"
  77. ENABLE_BACKEND=""
  78. TRAIN_MODE="INFER"
  79. ENABLE_ASAN="off"
  80. ENABLE_PROFILE="off"
  81. INC_BUILD="off"
  82. ENABLE_LOAD_IR="off"
  83. ENABLE_TIMELINE="off"
  84. ENABLE_DUMP2PROTO="on"
  85. ENABLE_DUMPE2E="off"
  86. ENABLE_DUMP_IR="on"
  87. COMPILE_MINDDATA="on"
  88. ENABLE_MPI="off"
  89. CUDA_VERSION="10.1"
  90. COMPILE_PREDICT="off"
  91. USE_GLOG="on"
  92. PREDICT_PLATFORM=""
  93. ENABLE_AKG="on"
  94. ENABLE_SERVING="off"
  95. ENABLE_DEBUGGER="off"
  96. # Process the options
  97. while getopts 'drvj:c:t:hsb:a:g:p:ie:m:I:LRP:Q:D:zM:V:K:sB:' opt
  98. do
  99. OPTARG=$(echo ${OPTARG} | tr '[A-Z]' '[a-z]')
  100. case "${opt}" in
  101. d)
  102. DEBUG_MODE="on"
  103. ;;
  104. r)
  105. DEBUG_MODE="off"
  106. ;;
  107. v)
  108. VERBOSE="VERBOSE=1"
  109. ;;
  110. j)
  111. THREAD_NUM=$OPTARG
  112. ;;
  113. c)
  114. check_on_off $OPTARG c
  115. ENABLE_COVERAGE="$OPTARG"
  116. ;;
  117. t)
  118. check_on_off $OPTARG t
  119. RUN_TESTCASES="$OPTARG"
  120. ;;
  121. g)
  122. check_on_off $OPTARG g
  123. USE_GLOG="$OPTARG"
  124. ;;
  125. h)
  126. usage
  127. exit 0
  128. ;;
  129. b)
  130. if [[ "X$OPTARG" != "Xge" && "X$OPTARG" != "Xcpu" ]]; then
  131. echo "Invalid value ${OPTARG} for option -b"
  132. usage
  133. exit 1
  134. fi
  135. ENABLE_BACKEND=$(echo "$OPTARG" | tr '[a-z]' '[A-Z]')
  136. if [[ "X$ENABLE_BACKEND" != "XCPU" ]]; then
  137. ENABLE_CPU="on"
  138. fi
  139. ;;
  140. a)
  141. check_on_off $OPTARG a
  142. ENABLE_ASAN="$OPTARG"
  143. ;;
  144. p)
  145. check_on_off $OPTARG p
  146. ENABLE_PROFILE="$OPTARG"
  147. ;;
  148. i)
  149. INC_BUILD="on"
  150. ;;
  151. m)
  152. if [[ "X$OPTARG" != "Xinfer" && "X$OPTARG" != "Xtrain" ]]; then
  153. echo "Invalid value ${OPTARG} for option -m"
  154. usage
  155. exit 1
  156. fi
  157. TRAIN_MODE=$(echo "$OPTARG" | tr '[a-z]' '[A-Z]')
  158. ;;
  159. L)
  160. ENABLE_LOAD_IR="on"
  161. echo "build with enable load anf ir"
  162. ;;
  163. R)
  164. ENABLE_TIMELINE="on"
  165. echo "enable time_line record"
  166. ;;
  167. e)
  168. if [[ "X$OPTARG" == "Xgpu" ]]; then
  169. ENABLE_GPU="on"
  170. ENABLE_CPU="on"
  171. ENABLE_MPI="on"
  172. elif [[ "X$OPTARG" == "Xd" || "X$OPTARG" == "Xascend" ]]; then
  173. ENABLE_D="on"
  174. ENABLE_CPU="on"
  175. elif [[ "X$OPTARG" == "Xcpu" ]]; then
  176. ENABLE_CPU="on"
  177. else
  178. echo "Invalid value ${OPTARG} for option -e"
  179. usage
  180. exit 1
  181. fi
  182. ;;
  183. M)
  184. check_on_off $OPTARG M
  185. ENABLE_MPI="$OPTARG"
  186. ;;
  187. V)
  188. if [[ "X$OPTARG" != "X9.2" && "X$OPTARG" != "X10.1" ]]; then
  189. echo "Invalid value ${OPTARG} for option -V"
  190. usage
  191. exit 1
  192. fi
  193. if [[ "X$OPTARG" == "X9.2" ]]; then
  194. echo "Unsupported CUDA version 9.2"
  195. exit 1
  196. fi
  197. CUDA_VERSION="$OPTARG"
  198. ;;
  199. P)
  200. check_on_off $OPTARG p
  201. ENABLE_DUMP2PROTO="$OPTARG"
  202. echo "enable dump anf graph to proto file"
  203. ;;
  204. Q)
  205. check_on_off $OPTARG Q
  206. ENABLE_DUMPE2E="$OPTARG"
  207. echo "enable dump end to end"
  208. ;;
  209. D)
  210. check_on_off $OPTARG D
  211. ENABLE_DUMP_IR="$OPTARG"
  212. echo "enable dump function graph ir"
  213. ;;
  214. z)
  215. eval ARG=\$\{$OPTIND\}
  216. if [[ -n $ARG && $ARG != -* ]]; then
  217. OPTARG=$ARG
  218. check_on_off $OPTARG z
  219. OPTIND=$((OPTIND + 1))
  220. else
  221. OPTARG=""
  222. fi
  223. if [[ "X$OPTARG" == "Xoff" ]]; then
  224. COMPILE_MINDDATA="off"
  225. fi
  226. ;;
  227. I)
  228. COMPILE_PREDICT="on"
  229. if [[ "$OPTARG" == "arm64" ]]; then
  230. PREDICT_PLATFORM="arm64"
  231. elif [[ "$OPTARG" == "x86_64" ]]; then
  232. PREDICT_PLATFORM="x86_64"
  233. else
  234. echo "-I parameter must be arm64 or x86_64"
  235. exit 1
  236. fi
  237. ;;
  238. K)
  239. ENABLE_AKG="on"
  240. echo "enable compile with akg"
  241. ;;
  242. s)
  243. ENABLE_SERVING="on"
  244. echo "enable serving"
  245. ;;
  246. B)
  247. check_on_off $OPTARG B
  248. ENABLE_DEBUGGER="on"
  249. echo "enable debugger"
  250. ;;
  251. *)
  252. echo "Unknown option ${opt}!"
  253. usage
  254. exit 1
  255. esac
  256. done
  257. }
  258. checkopts "$@"
  259. echo "---------------- MindSpore: build start ----------------"
  260. mkdir -pv "${BUILD_PATH}/package/mindspore/lib"
  261. git submodule update --init graphengine
  262. if [[ "X$ENABLE_AKG" = "Xon" ]] && [[ "X$ENABLE_D" = "Xon" ]]; then
  263. git submodule update --init --recursive akg
  264. fi
  265. build_exit()
  266. {
  267. echo "$@" >&2
  268. stty echo
  269. exit 1
  270. }
  271. # Create building path
  272. build_mindspore()
  273. {
  274. echo "start build mindspore project."
  275. mkdir -pv "${BUILD_PATH}/mindspore"
  276. cd "${BUILD_PATH}/mindspore"
  277. CMAKE_ARGS="-DDEBUG_MODE=$DEBUG_MODE -DBUILD_PATH=$BUILD_PATH"
  278. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_LOAD_ANF_IR=$ENABLE_LOAD_IR"
  279. if [[ "X$ENABLE_COVERAGE" = "Xon" ]]; then
  280. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_COVERAGE=ON"
  281. fi
  282. if [[ "X$RUN_TESTCASES" = "Xon" ]]; then
  283. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_TESTCASES=ON"
  284. fi
  285. if [[ -n "$ENABLE_BACKEND" ]]; then
  286. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_${ENABLE_BACKEND}=ON"
  287. fi
  288. if [[ -n "$TRAIN_MODE" ]]; then
  289. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_${TRAIN_MODE}=ON"
  290. fi
  291. if [[ "X$ENABLE_ASAN" = "Xon" ]]; then
  292. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_ASAN=ON"
  293. fi
  294. if [[ "X$ENABLE_PROFILE" = "Xon" ]]; then
  295. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_PROFILE=ON"
  296. fi
  297. if [[ "X$ENABLE_TIMELINE" = "Xon" ]]; then
  298. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_TIMELINE=ON"
  299. fi
  300. if [[ "X$ENABLE_DUMP2PROTO" = "Xon" ]]; then
  301. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_DUMP_PROTO=ON"
  302. fi
  303. if [[ "X$ENABLE_DUMPE2E" = "Xon" ]]; then
  304. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_DUMP_E2E=ON"
  305. fi
  306. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_DUMP_IR=${ENABLE_DUMP_IR}"
  307. if [[ "X$ENABLE_MPI" = "Xon" ]]; then
  308. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_MPI=ON"
  309. fi
  310. if [[ "X$ENABLE_D" = "Xon" ]]; then
  311. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_D=ON"
  312. fi
  313. if [[ "X$ENABLE_GPU" = "Xon" ]]; then
  314. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_GPU=ON -DCUDA_PATH=$CUDA_PATH -DCUDNN_PATH=$CUDNN_PATH -DMS_REQUIRE_CUDA_VERSION=${CUDA_VERSION}"
  315. fi
  316. if [[ "X$ENABLE_CPU" = "Xon" ]]; then
  317. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_CPU=ON"
  318. fi
  319. if [[ "X$COMPILE_MINDDATA" = "Xon" ]]; then
  320. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_MINDDATA=ON"
  321. fi
  322. if [[ "X$USE_GLOG" = "Xon" ]]; then
  323. CMAKE_ARGS="${CMAKE_ARGS} -DUSE_GLOG=ON"
  324. fi
  325. if [[ "X$ENABLE_AKG" = "Xon" ]] && [[ "X$ENABLE_D" = "Xon" ]]; then
  326. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_AKG=ON"
  327. fi
  328. if [[ "X$ENABLE_SERVING" = "Xon" ]]; then
  329. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_SERVING=ON"
  330. fi
  331. if [[ "X$ENABLE_DEBUGGER" = "Xon" ]]; then
  332. CMAKE_ARGS="${CMAKE_ARGS} -DENABLE_DEBUGGER=ON"
  333. fi
  334. echo "${CMAKE_ARGS}"
  335. if [[ "X$INC_BUILD" = "Xoff" ]]; then
  336. cmake ${CMAKE_ARGS} ../..
  337. fi
  338. if [[ -n "$VERBOSE" ]]; then
  339. CMAKE_VERBOSE="--verbose"
  340. fi
  341. cmake --build . --target package ${CMAKE_VERBOSE} -j$THREAD_NUM
  342. echo "success to build mindspore project!"
  343. }
  344. build_predict()
  345. {
  346. git submodule update --init --recursive third_party/incubator-tvm
  347. echo "start build predict project"
  348. git submodule update --init --recursive third_party/flatbuffers
  349. git submodule update --init --recursive third_party/googletest
  350. git submodule update --init --recursive third_party/protobuf
  351. rm -rf "${BASEPATH}/predict/build"
  352. mkdir -pv "${BASEPATH}/predict/build"
  353. rm -rf "${BASEPATH}/predict/output"
  354. mkdir -pv "${BASEPATH}/predict/output"
  355. if [[ "$PREDICT_PLATFORM" == "arm64" ]]; then
  356. if [ "${ANDROID_NDK}" ]; then
  357. echo -e "\e[31mANDROID_NDK_PATH=$ANDROID_NDK \e[0m"
  358. else
  359. echo -e "\e[31mplease set ANDROID_NDK_PATH in environment variable for example: export ANDROID_NDK=/root/usr/android-ndk-r16b/ \e[0m"
  360. exit 1
  361. fi
  362. fi
  363. #build flatbuf
  364. cd "${BASEPATH}/third_party/flatbuffers"
  365. rm -rf build && mkdir -p build && cd build && cmake .. && make -j$THREAD_NUM
  366. FLATC="${BASEPATH}"/third_party/flatbuffers/build/flatc
  367. cd "${BASEPATH}"/predict/schema && mkdir -p "${BASEPATH}"/predict/schema/inner
  368. find . -name "*.fbs" -print0 | xargs -0 "${FLATC}" -c -b
  369. find . -name "*.fbs" -print0 | xargs -0 "${FLATC}" -c -b --reflect-types --gen-mutable --reflect-names --gen-object-api -o ${BASEPATH}/predict/schema/inner
  370. # check LLVM_PATH
  371. if [ "${LLVM_PATH}" == "" ]; then
  372. echo "Please set LLVM_PATH in env for example export LLVM_PATH=/xxxx/bin/llvm-config"
  373. exit
  374. fi
  375. #build tvm
  376. tvm_open_source="${BASEPATH}/third_party/incubator-tvm"
  377. tvm_kernel_build="${BASEPATH}/predict/module/tvm_kernel"
  378. if [ ! -f "${tvm_kernel_build}"/incubator-tvm/build/libtvm.so ]; then
  379. rm -fr "${tvm_kernel_build}"/incubator-tvm
  380. cp -fr "${tvm_open_source}" "${tvm_kernel_build}"
  381. mkdir -p "${tvm_kernel_build}"/incubator-tvm/build
  382. patch -d "${tvm_kernel_build}"/incubator-tvm -p1 < "${BASEPATH}"/third_party/patch/predict/0001-RetBugFix-CustomRuntime_v06.patch
  383. cp "${tvm_kernel_build}"/lite/src/codegen/llvm/lite_rtfunc_reset.cc "${tvm_kernel_build}"/incubator-tvm/src/codegen/llvm/
  384. cp "${tvm_open_source}"/cmake/config.cmake "${tvm_kernel_build}"/incubator-tvm
  385. if [ "${LLVM_PATH}" ]; then
  386. sed -i "s#set(USE_LLVM .*)#set(USE_LLVM \"${LLVM_PATH}\")#g" "${tvm_kernel_build}"/incubator-tvm/config.cmake
  387. else
  388. echo "need set LLVM_PATH in env for example export LLVM_PATH=/xxxx/bin/llvm-config"
  389. fi
  390. cd "${tvm_kernel_build}"/incubator-tvm/build
  391. cmake ..
  392. make -j$THREAD_NUM
  393. else
  394. cd "${tvm_kernel_build}"/incubator-tvm/build
  395. make -j$THREAD_NUM
  396. fi
  397. #gen op
  398. predict_tvm_op_lib_path="${BASEPATH}/predict/module/tvm_kernel/build/lib_x86"
  399. predict_platform="x86"
  400. if [[ "$PREDICT_PLATFORM" == "arm64" ]]; then
  401. predict_tvm_op_lib_path="${BASEPATH}/predict/module/tvm_kernel/build/lib_arm64"
  402. predict_platform="arm64"
  403. fi
  404. need_get_libs=true
  405. if [ -d "${predict_tvm_op_lib_path}" ]; then
  406. file_list=$(ls "${predict_tvm_op_lib_path}")
  407. if [ -n "${file_list}" ]; then
  408. libstime=$(stat -c %Y "${predict_tvm_op_lib_path}"/* | sort -u | tail -n1)
  409. pythontime=$(find "${BASEPATH}"/predict/module/tvm_kernel/lite/python/ -name "*.py" -exec stat -c %Y {} \; |
  410. sort -u | tail -n1)
  411. if [ "${libstime}" -ge "${pythontime}" ]; then
  412. need_get_libs=false
  413. else
  414. rm -fr "${predict_tvm_op_lib_path}"
  415. fi
  416. fi
  417. fi
  418. if $need_get_libs; then
  419. PYTHONPATH_OLD=${PYTHONPATH}
  420. export PYTHONPATH="${tvm_kernel_build}/incubator-tvm/python:${tvm_kernel_build}/incubator-tvm/topi/python:${tvm_kernel_build}/incubator-tvm/nnvm/python:${tvm_kernel_build}/lite/python:"
  421. cd "${BASEPATH}"/predict/module/tvm_kernel/lite/python/at_ops
  422. python3 at_gen_strip.py ${predict_platform}
  423. export PYTHONPATH=${PYTHONPATH_OLD}
  424. fi
  425. cd "${BASEPATH}/predict/build"
  426. if [[ "$PREDICT_PLATFORM" == "arm64" ]]; then
  427. cmake -DCMAKE_TOOLCHAIN_FILE="${ANDROID_NDK}/build/cmake/android.toolchain.cmake" \
  428. -DANDROID_NATIVE_API_LEVEL=android-19 -DANDROID_NDK="${ANDROID_NDK}" \
  429. -DANDROID_TOOLCHAIN_NAME="aarch64-linux-android-clang" -DANDROID_STL="c++_shared" \
  430. -DANDROID_ABI="arm64-v8a" -DENABLE_PREDICT_ARM64=ON -DANDROID_ALLOW_UNDEFINED_SYMBOLS=TRUE ..
  431. elif [[ "$PREDICT_PLATFORM" == "x86_64" ]]; then
  432. cmake ..
  433. fi
  434. make ${VERBOSE} -j$THREAD_NUM
  435. if [[ "$PREDICT_PLATFORM" == "x86_64" ]]; then
  436. cd "${BASEPATH}/predict/build/test" && ./run_tests.sh
  437. fi
  438. # copy securec include files
  439. mkdir -p "${BASEPATH}/predict/output/include/securec/include"
  440. cp "${BASEPATH}"/third_party/securec/include/* "${BASEPATH}"/predict/output/include/securec/include
  441. cd "${BASEPATH}/predict/output/"
  442. if [[ "$PREDICT_PLATFORM" == "x86_64" ]]; then
  443. tar -cf MSPredict-0.5.0-linux_x86_64.tar.gz include/ lib/ --warning=no-file-changed
  444. elif [[ "$PREDICT_PLATFORM" == "arm64" ]]; then
  445. tar -cf MSPredict-0.5.0-linux_aarch64.tar.gz include/ lib/ --warning=no-file-changed
  446. fi
  447. echo "success to build predict project!"
  448. }
  449. if [[ "X$COMPILE_PREDICT" = "Xon" ]]; then
  450. build_predict
  451. echo "---------------- mindspore: build end ----------------"
  452. exit
  453. else
  454. build_mindspore
  455. fi
  456. cp -rf ${BUILD_PATH}/package/mindspore/lib ${BUILD_PATH}/../mindspore
  457. cp -rf ${BUILD_PATH}/package/mindspore/*.so ${BUILD_PATH}/../mindspore
  458. echo "---------------- mindspore: build end ----------------"