inference_lib.cmake 7.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14
# Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

L
Luo Tao 已提交
15
# make package for paddle fluid shared and static library
L
Luo Tao 已提交
16 17 18 19 20
function(copy TARGET)
    set(options "")
    set(oneValueArgs "")
    set(multiValueArgs SRCS DSTS DEPS)
    cmake_parse_arguments(copy_lib "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
21
    set(inference_lib_dist_dep ${TARGET} ${inference_lib_dist_dep} PARENT_SCOPE)
L
Luo Tao 已提交
22 23 24 25 26 27 28

    list(LENGTH copy_lib_SRCS copy_lib_SRCS_len)
    list(LENGTH copy_lib_DSTS copy_lib_DSTS_len)
    if(NOT ${copy_lib_SRCS_len} EQUAL ${copy_lib_DSTS_len})
        message(FATAL_ERROR "${TARGET} source numbers are not equal to destination numbers")
    endif()
    math(EXPR len "${copy_lib_SRCS_len} - 1")
29

L
Luo Tao 已提交
30 31 32 33
    add_custom_target(${TARGET} DEPENDS ${copy_lib_DEPS})
    foreach(index RANGE ${len})
        list(GET copy_lib_SRCS ${index} src)
        list(GET copy_lib_DSTS ${index} dst)
D
dzhwinter 已提交
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
        
        if (WIN32) 
        # windows cmd shell will not expand wildcard automatically.
        # below expand the files,libs and copy them by rules.
        file(GLOB header_files ${src} "*.h")
        file(GLOB static_lib_files ${src} "*.lib")
        file(GLOB dll_lib_files ${src} "*.dll")
        set(src_files ${header_files} ${static_lib_files} ${dll_lib_files})

        if (NOT "${src_files}" STREQUAL "")
        list(REMOVE_DUPLICATES src_files)
        endif()
        #string(REPLACE ";" " " src_files ${src_files})
        add_custom_command(TARGET ${TARGET} PRE_BUILD 
          COMMAND ${CMAKE_COMMAND} -E make_directory  "${dst}"
          )
        foreach(src_file ${src_files}) 
          add_custom_command(TARGET ${TARGET} PRE_BUILD 
          COMMAND ${CMAKE_COMMAND} -E copy "${src_file}" "${dst}"
          COMMENT "copying ${src_file} -> ${dst}")
        endforeach()
        else() # not windows
56
        add_custom_command(TARGET ${TARGET} PRE_BUILD 
D
dzhwinter 已提交
57
          COMMAND ${CMAKE_COMMAND} -E make_directory  "${dst}"
D
dzhwinter 已提交
58
          COMMAND ${CMAKE_COMMAND} -E copy "${src_files}" "${dst}"
59
          COMMENT "copying ${src} -> ${dst}")
D
dzhwinter 已提交
60
        endif(WIN32)
L
Luo Tao 已提交
61 62 63
    endforeach()
endfunction()

L
Luo Tao 已提交
64
# third party
65
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/eigen3")
L
Luo Tao 已提交
66 67 68
copy(eigen3_lib
  SRCS ${EIGEN_INCLUDE_DIR}/Eigen/Core ${EIGEN_INCLUDE_DIR}/Eigen/src ${EIGEN_INCLUDE_DIR}/unsupported/Eigen
  DSTS ${dst_dir}/Eigen ${dst_dir}/Eigen ${dst_dir}/unsupported
T
tensor-tang 已提交
69
  DEPS eigen3
L
Luo Tao 已提交
70 71
)

72
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/gflags")
L
Luo Tao 已提交
73 74 75
copy(gflags_lib
  SRCS ${GFLAGS_INCLUDE_DIR} ${GFLAGS_LIBRARIES}
  DSTS ${dst_dir} ${dst_dir}/lib
T
tensor-tang 已提交
76
  DEPS gflags
L
Luo Tao 已提交
77 78
)

79
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/glog")
L
Luo Tao 已提交
80 81 82
copy(glog_lib
  SRCS ${GLOG_INCLUDE_DIR} ${GLOG_LIBRARIES}
  DSTS ${dst_dir} ${dst_dir}/lib
T
tensor-tang 已提交
83
  DEPS glog
L
Luo Tao 已提交
84 85
)

86
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/boost/")
Q
qiaolongfei 已提交
87
copy(boost_lib
Q
qiaolongfei 已提交
88
  SRCS ${BOOST_INCLUDE_DIR}/boost
Q
qiaolongfei 已提交
89
  DSTS ${dst_dir}
T
tensor-tang 已提交
90
  DEPS boost
Q
qiaolongfei 已提交
91 92
)

93
if(NOT PROTOBUF_FOUND)
94
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/protobuf")
L
Luo Tao 已提交
95
    copy(protobuf_lib
96
      SRCS ${PROTOBUF_INCLUDE_DIR} ${PROTOBUF_LIBRARY}
L
Luo Tao 已提交
97
      DSTS ${dst_dir} ${dst_dir}/lib
T
tensor-tang 已提交
98
      DEPS extern_protobuf
L
Luo Tao 已提交
99
    )
100 101 102
endif()

if(NOT CBLAS_FOUND)
103
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/openblas")
104 105 106
    copy(openblas_lib
      SRCS ${CBLAS_INSTALL_DIR}/lib ${CBLAS_INSTALL_DIR}/include
      DSTS ${dst_dir} ${dst_dir}
T
tensor-tang 已提交
107
      DEPS extern_openblas
108
    )
L
Luo Tao 已提交
109
elseif (WITH_MKLML)
110
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/mklml")
111
    copy(mklml_lib
L
Luo Tao 已提交
112 113
      SRCS ${MKLML_LIB} ${MKLML_IOMP_LIB} ${MKLML_INC_DIR}
      DSTS ${dst_dir}/lib ${dst_dir}/lib ${dst_dir}
T
tensor-tang 已提交
114
      DEPS mklml
115
    )
116
endif()
L
Luo Tao 已提交
117

Q
qiaolongfei 已提交
118
if(WITH_MKLDNN)
119
  set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/mkldnn")
Q
qiaolongfei 已提交
120
  copy(mkldnn_lib
Q
qiaolongfei 已提交
121
    SRCS ${MKLDNN_INC_DIR} ${MKLDNN_SHARED_LIB}
Q
qiaolongfei 已提交
122
    DSTS ${dst_dir} ${dst_dir}/lib
T
tensor-tang 已提交
123
    DEPS mkldnn
Q
qiaolongfei 已提交
124 125 126
  )
endif()

D
dzhwinter 已提交
127
if (NOT WIN32)
128
if(NOT MOBILE_INFERENCE AND NOT RPI)
129
  set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/snappy")
130 131
  copy(snappy_lib
    SRCS ${SNAPPY_INCLUDE_DIR} ${SNAPPY_LIBRARIES}
T
tensor-tang 已提交
132 133
    DSTS ${dst_dir} ${dst_dir}/lib
    DEPS snappy)
134

135
  set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/snappystream")
136 137
  copy(snappystream_lib
    SRCS ${SNAPPYSTREAM_INCLUDE_DIR} ${SNAPPYSTREAM_LIBRARIES}
T
tensor-tang 已提交
138 139
    DSTS ${dst_dir} ${dst_dir}/lib
    DEPS snappystream)
140

141
  set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/zlib")
142 143
  copy(zlib_lib
    SRCS ${ZLIB_INCLUDE_DIR} ${ZLIB_LIBRARIES}
T
tensor-tang 已提交
144 145
    DSTS ${dst_dir} ${dst_dir}/lib
    DEPS zlib)
146
endif()
D
dzhwinter 已提交
147
endif(NOT WIN32)
148

L
Luo Tao 已提交
149
# paddle fluid module
150
set(src_dir "${PADDLE_SOURCE_DIR}/paddle/fluid")
151
set(dst_dir "${FLUID_INSTALL_DIR}/paddle/fluid")
L
Luo Tao 已提交
152
set(module "framework")
D
dzhwinter 已提交
153
if (NOT WIN32)
L
Luo Tao 已提交
154
copy(framework_lib DEPS framework_py_proto 
155
  SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/details/*.h ${PADDLE_BINARY_DIR}/paddle/fluid/framework/framework.pb.h
L
Luo Tao 已提交
156
  DSTS ${dst_dir}/${module} ${dst_dir}/${module}/details ${dst_dir}/${module}
L
Luo Tao 已提交
157
)
D
dzhwinter 已提交
158 159 160 161 162 163
else()
copy(framework_lib
  SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/details/*.h ${PADDLE_BINARY_DIR}/paddle/fluid/framework/framework.pb.h
  DSTS ${dst_dir}/${module} ${dst_dir}/${module}/details ${dst_dir}/${module}
)
endif(NOT WIN32)
L
Luo Tao 已提交
164

L
Luo Tao 已提交
165 166 167 168
set(module "memory")
copy(memory_lib
  SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/detail/*.h
  DSTS ${dst_dir}/${module} ${dst_dir}/${module}/detail
L
Luo Tao 已提交
169 170
)

Y
Yan Chunwei 已提交
171
set(inference_deps paddle_fluid_shared paddle_fluid)
L
Luo Tao 已提交
172

173 174 175 176 177
set(module "inference/api")
if (WITH_ANAKIN AND WITH_GPU)
    copy(anakin_inference_lib DEPS paddle_inference_api inference_anakin_api
        SRCS
        ${PADDLE_BINARY_DIR}/paddle/fluid/inference/api/libinference_anakin_api* # compiled anakin api
L
Luo Tao 已提交
178
        ${ANAKIN_INSTALL_DIR} # anakin release
179 180
        DSTS ${dst_dir}/inference/anakin ${dst_dir}/inference/anakin)
     list(APPEND inference_deps anakin_inference_lib)
181 182
endif()

Y
Yan Chunwei 已提交
183 184 185
set(module "inference")
copy(inference_lib DEPS ${inference_deps}
  SRCS ${src_dir}/${module}/*.h ${PADDLE_BINARY_DIR}/paddle/fluid/inference/libpaddle_fluid.*
186 187
       ${src_dir}/${module}/api/paddle_inference_api.h ${src_dir}/${module}/api/demo_ci
  DSTS ${dst_dir}/${module} ${dst_dir}/${module} ${dst_dir}/${module} ${dst_dir}/${module}
Y
Yan Chunwei 已提交
188 189
)

L
Luo Tao 已提交
190
set(module "platform")
X
Xin Pan 已提交
191
copy(platform_lib DEPS profiler_py_proto
L
Luo Tao 已提交
192 193 194
  SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/dynload/*.h ${src_dir}/${module}/details/*.h
  DSTS ${dst_dir}/${module} ${dst_dir}/${module}/dynload ${dst_dir}/${module}/details
)
L
Luo Tao 已提交
195

L
Luo Tao 已提交
196 197 198 199
set(module "string")
copy(string_lib
  SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/tinyformat/*.h
  DSTS ${dst_dir}/${module} ${dst_dir}/${module}/tinyformat
L
Luo Tao 已提交
200 201
)

202 203
set(module "pybind")
copy(pybind_lib
Q
qiaolongfei 已提交
204
  SRCS ${CMAKE_CURRENT_BINARY_DIR}/paddle/fluid/${module}/pybind.h
205 206 207
  DSTS ${dst_dir}/${module}
)

208 209 210
# CMakeCache Info
copy(cmake_cache
  SRCS ${CMAKE_CURRENT_BINARY_DIR}/CMakeCache.txt
211
  DSTS ${FLUID_INSTALL_DIR})
212

213
add_custom_target(inference_lib_dist DEPENDS ${inference_lib_dist_dep}) 
214 215 216 217

# paddle fluid version
execute_process(
  COMMAND ${GIT_EXECUTABLE} log --pretty=format:%H -1
L
Luo Tao 已提交
218
  WORKING_DIRECTORY ${PADDLE_SOURCE_DIR}
219
  OUTPUT_VARIABLE PADDLE_GIT_COMMIT)
220
set(version_file ${FLUID_INSTALL_DIR}/version.txt)
221 222 223 224 225 226 227 228 229
file(WRITE ${version_file}
  "GIT COMMIT ID: ${PADDLE_GIT_COMMIT}\n"
  "WITH_MKL: ${WITH_MKL}\n"
  "WITH_GPU: ${WITH_GPU}\n")
if(WITH_GPU)
  file(APPEND ${version_file}
    "CUDA version: ${CUDA_VERSION}\n"
    "CUDNN version: v${CUDNN_MAJOR_VERSION}\n")
endif()