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.

do_build.sh 2.5 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. #!/bin/bash -e
  2. ALL_PYTHON=${ALL_PYTHON}
  3. if [[ -z ${ALL_PYTHON} ]]
  4. then
  5. ALL_PYTHON="35m 36m 37m 38"
  6. fi
  7. BUILD_WHL_CPU_ONLY=${BUILD_WHL_CPU_ONLY}
  8. if [[ -z ${BUILD_WHL_CPU_ONLY} ]]
  9. then
  10. BUILD_WHL_CPU_ONLY="OFF"
  11. fi
  12. SRC_DIR=$(readlink -f "`dirname $0`/../../../")
  13. BUILD_DIR=${SRC_DIR}/build_dir/host/MGE_WITH_CUDA_OFF/MGE_INFERENCE_ONLY_OFF/Release/build/
  14. if [ ${BUILD_WHL_CPU_ONLY} = "OFF" ]; then
  15. BUILD_DIR=${SRC_DIR}/build_dir/host/MGE_WITH_CUDA_ON/MGE_INFERENCE_ONLY_OFF/Release/build/
  16. fi
  17. NEW_LIB_PATH=core/lib
  18. function handle_strip() {
  19. echo "now handle strip $1"
  20. objcopy --only-keep-debug $1 $1.dbg
  21. strip -s $1
  22. objcopy --add-gnu-debuglink=$1.dbg $1
  23. rm $1.dbg
  24. }
  25. for ver in ${ALL_PYTHON}
  26. do
  27. python_ver=${ver:0:2}
  28. MAJOR=${python_ver:0:1}
  29. MINOR=${ver:1}
  30. PYTHON_DIR=/opt/python/cp${python_ver}-cp${ver}/
  31. export EXTRA_CMAKE_ARGS="${EXTRA_CMAKE_ARGS} -DCMAKE_BUILD_TYPE=RelWithDebInfo"
  32. export EXTRA_CMAKE_ARGS="${EXTRA_CMAKE_ARGS} -DCMAKE_PREFIX_PATH=${PYTHON_DIR}"
  33. export EXTRA_CMAKE_ARGS="${EXTRA_CMAKE_ARGS} -DPYTHON_EXECUTABLE=${PYTHON_DIR}/bin/python3"
  34. export EXTRA_CMAKE_ARGS="${EXTRA_CMAKE_ARGS} -DPYTHON_LIBRARY=${PYTHON_DIR}lib/"
  35. export EXTRA_CMAKE_ARGS="${EXTRA_CMAKE_ARGS} -DPYTHON_INCLUDE_DIR=${PYTHON_DIR}include/python${MAJOR}.${MINOR}"
  36. if [ ${BUILD_WHL_CPU_ONLY} = "OFF" ]; then
  37. ${SRC_DIR}/scripts/cmake-build/host_build.sh -c -t -r
  38. else
  39. ${SRC_DIR}/scripts/cmake-build/host_build.sh -t -r
  40. fi
  41. cd ${BUILD_DIR}
  42. rm -rf staging
  43. mkdir -p staging
  44. cp -a imperative/python/{megengine,setup.py,requires.txt,requires-style.txt,requires-test.txt} staging/
  45. if [ ${BUILD_WHL_CPU_ONLY} = "OFF" ]; then
  46. cd ${BUILD_DIR}/dnn/cuda-stub/
  47. strip -s libcuda.so
  48. ln -sf libcuda.so libcuda.so.1
  49. fi
  50. handle_strip ${BUILD_DIR}/src/libmegengine_export.so
  51. cd ${BUILD_DIR}/staging/megengine/core
  52. handle_strip _imperative_rt.so
  53. mkdir -p lib/ucx
  54. if [ ${BUILD_WHL_CPU_ONLY} = "OFF" ]; then
  55. cp -L /usr/local/cuda/lib*/libnvrtc-builtins.so lib
  56. fi
  57. cd ${BUILD_DIR}/staging/
  58. ${PYTHON_DIR}/bin/python setup.py bdist_wheel
  59. cd /home/output
  60. LD_LIBRARY_PATH=${BUILD_DIR}/dnn/cuda-stub:$LD_LIBRARY_PATH auditwheel repair -L ${NEW_LIB_PATH} ${BUILD_DIR}/staging/dist/Meg*.whl
  61. chown -R ${UID}.${UID} .
  62. # compat for root-less docker env to remove output at host side
  63. chmod -R 777 .
  64. done

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