xpu.cmake 5.3 KB
Newer Older
1 2
if(NOT WITH_XPU)
  return()
3 4
endif()

5 6 7 8
include(ExternalProject)
set(XPU_PROJECT "extern_xpu")
set(XPU_API_LIB_NAME "libxpuapi.so")
set(XPU_RT_LIB_NAME "libxpurt.so")
9

H
houj04 已提交
10
if(NOT DEFINED XPU_BASE_URL)
11
  set(XPU_BASE_URL_WITHOUT_DATE
H
houj04 已提交
12
      "https://baidu-kunlun-product.su.bcebos.com/KL-SDK/klsdk-dev")
13
  set(XPU_BASE_URL "${XPU_BASE_URL_WITHOUT_DATE}/20221110")
H
houj04 已提交
14
else()
15
  set(XPU_BASE_URL "${XPU_BASE_URL}")
H
houj04 已提交
16 17 18 19
endif()

# ubuntu and centos: use output by XDNN API team
if(NOT DEFINED XPU_XDNN_BASE_URL)
20 21
  set(XPU_XDNN_BASE_URL_WITHOUT_DATE
      "https://klx-sdk-release-public.su.bcebos.com/xdnn/dev")
22
  set(XPU_XDNN_BASE_URL "${XPU_XDNN_BASE_URL_WITHOUT_DATE}/20221109")
H
houj04 已提交
23
else()
24
  set(XPU_XDNN_BASE_URL "${XPU_XDNN_BASE_URL}")
H
houj04 已提交
25 26
endif()

27
set(XPU_XCCL_BASE_URL
Z
zhangxiaoci 已提交
28
    "https://klx-sdk-release-public.su.bcebos.com/xccl/release/1.0.0")
29

30 31
if(WITH_AARCH64)
  set(XPU_XRE_DIR_NAME "xre-kylin_aarch64")
32
  set(XPU_XDNN_DIR_NAME "xdnn-kylin_aarch64")
33 34 35 36 37 38 39 40 41 42 43 44 45
  set(XPU_XCCL_DIR_NAME "xccl-kylin_aarch64")
  set(XPU_XDNN_URL
      "${XPU_XDNN_BASE_URL}/${XPU_XDNN_DIR_NAME}.tar.gz"
      CACHE STRING "" FORCE)
elseif(WITH_SUNWAY)
  set(XPU_XRE_DIR_NAME "xre-deepin_sw6_64")
  set(XPU_XDNN_DIR_NAME "xdnn-deepin_sw6_64")
  set(XPU_XCCL_DIR_NAME "xccl-deepin_sw6_64")
  set(XPU_XDNN_URL
      "${XPU_BASE_URL}/${XPU_XDNN_DIR_NAME}.tar.gz"
      CACHE STRING "" FORCE)
elseif(WITH_BDCENTOS)
  set(XPU_XRE_DIR_NAME "xre-bdcentos_x86_64")
46
  set(XPU_XDNN_DIR_NAME "xdnn-bdcentos_x86_64")
47
  set(XPU_XCCL_DIR_NAME "xccl-bdcentos_x86_64")
H
houj04 已提交
48
  # ubuntu and centos: use output by XDNN API team
49 50 51 52 53
  set(XPU_XDNN_URL
      "${XPU_XDNN_BASE_URL}/${XPU_XDNN_DIR_NAME}.tar.gz"
      CACHE STRING "" FORCE)
elseif(WITH_UBUNTU)
  set(XPU_XRE_DIR_NAME "xre-ubuntu_x86_64")
54
  set(XPU_XDNN_DIR_NAME "xdnn-ubuntu_x86_64")
H
houj04 已提交
55
  set(XPU_XCCL_DIR_NAME "xccl-ubuntu_x86_64")
H
houj04 已提交
56
  # ubuntu and centos: use output by XDNN API team
57 58 59 60 61
  set(XPU_XDNN_URL
      "${XPU_XDNN_BASE_URL}/${XPU_XDNN_DIR_NAME}.tar.gz"
      CACHE STRING "" FORCE)
elseif(WITH_CENTOS)
  set(XPU_XRE_DIR_NAME "xre-centos7_x86_64")
62
  set(XPU_XDNN_DIR_NAME "xdnn-bdcentos_x86_64")
63
  set(XPU_XCCL_DIR_NAME "xccl-bdcentos_x86_64")
H
houj04 已提交
64
  # ubuntu and centos: use output by XDNN API team
65 66 67 68 69
  set(XPU_XDNN_URL
      "${XPU_XDNN_BASE_URL}/${XPU_XDNN_DIR_NAME}.tar.gz"
      CACHE STRING "" FORCE)
else()
  set(XPU_XRE_DIR_NAME "xre-ubuntu_x86_64")
70
  set(XPU_XDNN_DIR_NAME "xdnn-ubuntu_x86_64")
H
houj04 已提交
71
  set(XPU_XCCL_DIR_NAME "xccl-ubuntu_x86_64")
H
houj04 已提交
72
  # default: use output by XDNN API team
73 74 75 76
  set(XPU_XDNN_URL
      "${XPU_XDNN_BASE_URL}/${XPU_XDNN_DIR_NAME}.tar.gz"
      CACHE STRING "" FORCE)
endif()
T
TTerror 已提交
77

78 79 80 81
set(XPU_XRE_URL
    "${XPU_BASE_URL}/${XPU_XRE_DIR_NAME}.tar.gz"
    CACHE STRING "" FORCE)
set(XPU_XCCL_URL
82
    "${XPU_XCCL_BASE_URL}/${XPU_XCCL_DIR_NAME}.tar.gz"
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
    CACHE STRING "" FORCE)
set(XPU_PACK_DEPENCE_URL
    "https://baidu-kunlun-public.su.bcebos.com/paddle_depence/pack_paddle_depence.sh"
    CACHE STRING "" FORCE)

set(SNAPPY_PREFIX_DIR "${THIRD_PARTY_PATH}/xpu")
set(XPU_DOWNLOAD_DIR "${SNAPPY_PREFIX_DIR}/src/${XPU_PROJECT}")
set(XPU_INSTALL_DIR "${THIRD_PARTY_PATH}/install/xpu")
set(XPU_INC_DIR "${THIRD_PARTY_PATH}/install/xpu/include")
set(XPU_LIB_DIR "${THIRD_PARTY_PATH}/install/xpu/lib")

set(XPU_API_LIB "${XPU_LIB_DIR}/${XPU_API_LIB_NAME}")
set(XPU_RT_LIB "${XPU_LIB_DIR}/${XPU_RT_LIB_NAME}")

set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_RPATH}" "${XPU_INSTALL_DIR}/lib")

file(
  WRITE ${XPU_DOWNLOAD_DIR}/CMakeLists.txt
  "PROJECT(XPU)\n" "cmake_minimum_required(VERSION 3.0)\n"
T
TTerror 已提交
102 103 104 105
  "install(DIRECTORY xpu/include xpu/lib \n"
  "        DESTINATION ${XPU_INSTALL_DIR})\n")

ExternalProject_Add(
106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
  ${XPU_PROJECT}
  ${EXTERNAL_PROJECT_LOG_ARGS}
  PREFIX ${SNAPPY_PREFIX_DIR}
  DOWNLOAD_DIR ${XPU_DOWNLOAD_DIR}
  DOWNLOAD_COMMAND
    wget ${XPU_PACK_DEPENCE_URL} && bash pack_paddle_depence.sh ${XPU_XRE_URL}
    ${XPU_XRE_DIR_NAME} ${XPU_XDNN_URL} ${XPU_XDNN_DIR_NAME} ${XPU_XCCL_URL}
    ${XPU_XCCL_DIR_NAME}
  DOWNLOAD_NO_PROGRESS 1
  UPDATE_COMMAND ""
  CMAKE_ARGS -DCMAKE_INSTALL_PREFIX=${XPU_INSTALL_ROOT}
  CMAKE_CACHE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${XPU_INSTALL_ROOT}
  BUILD_BYPRODUCTS ${XPU_API_LIB}
  BUILD_BYPRODUCTS ${XPU_RT_LIB})

include_directories(${XPU_INC_DIR})
add_library(shared_xpuapi SHARED IMPORTED GLOBAL)
123 124 125 126 127 128
set_property(TARGET shared_xpuapi PROPERTY IMPORTED_LOCATION "${XPU_API_LIB}")

# generate a static dummy target to track xpulib dependencies
# for cc_library(xxx SRCS xxx.c DEPS xpulib)
generate_dummy_static_lib(LIB_NAME "xpulib" GENERATOR "xpu.cmake")

129
target_link_libraries(xpulib ${XPU_API_LIB} ${XPU_RT_LIB})
130

131 132 133
if(WITH_XPU_BKCL)
  message(STATUS "Compile with XPU BKCL!")
  add_definitions(-DPADDLE_WITH_XPU_BKCL)
134

135 136 137 138 139
  set(XPU_BKCL_LIB_NAME "libbkcl.so")
  set(XPU_BKCL_LIB "${XPU_LIB_DIR}/${XPU_BKCL_LIB_NAME}")
  set(XPU_BKCL_INC_DIR "${THIRD_PARTY_PATH}/install/xpu/include")
  include_directories(${XPU_BKCL_INC_DIR})
  target_link_libraries(xpulib ${XPU_API_LIB} ${XPU_RT_LIB} ${XPU_BKCL_LIB})
W
Wilber 已提交
140
else()
141
  target_link_libraries(xpulib ${XPU_API_LIB} ${XPU_RT_LIB})
W
Wilber 已提交
142
endif()
143

144
add_dependencies(xpulib ${XPU_PROJECT})
145 146

# Ensure that xpu/api.h can be included without dependency errors.
147 148 149 150 151 152
file(
  GENERATE
  OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/.xpu_headers_dummy.cc
  CONTENT "")
add_library(xpu_headers_dummy STATIC
            ${CMAKE_CURRENT_BINARY_DIR}/.xpu_headers_dummy.cc)
153 154
add_dependencies(xpu_headers_dummy extern_xpu)
link_libraries(xpu_headers_dummy)