inference_lib.cmake 11.1 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(fluid_lib_dist_dep ${TARGET} ${fluid_lib_dist_dep} PARENT_SCOPE)
L
Luo Tao 已提交
22 23 24

    list(LENGTH copy_lib_SRCS copy_lib_SRCS_len)
    list(LENGTH copy_lib_DSTS copy_lib_DSTS_len)
25
    if (NOT ${copy_lib_SRCS_len} EQUAL ${copy_lib_DSTS_len})
L
Luo Tao 已提交
26
        message(FATAL_ERROR "${TARGET} source numbers are not equal to destination numbers")
27
    endif ()
L
Luo Tao 已提交
28
    math(EXPR len "${copy_lib_SRCS_len} - 1")
29

L
Luo Tao 已提交
30
    add_custom_target(${TARGET} DEPENDS ${copy_lib_DEPS})
31
    foreach (index RANGE ${len})
L
Luo Tao 已提交
32 33
        list(GET copy_lib_SRCS ${index} src)
        list(GET copy_lib_DSTS ${index} dst)
34
        if (WIN32)
P
peizhilin 已提交
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
            if(IS_DIRECTORY ${src})
                get_filename_component(last_path ${src} NAME)
                string(APPEND dst "/" ${last_path})
                add_custom_command(TARGET ${TARGET} PRE_BUILD
                        COMMAND ${CMAKE_COMMAND} -E make_directory "${dst}"
                        )
                if(EXISTS ${src})
                    add_custom_command(TARGET ${TARGET} PRE_BUILD
                            COMMAND cmake -E copy_directory "${src}" "${dst}"
                            COMMENT "copying ${src} -> ${dst}")
                else()
                    message(WARNING "${src} not exist!")
                endif()
            else()
                # windows cmd shell will not expand wildcard automatically.
                # below expand the files, and copy them by rules.
                file(GLOB src_files ${src})
                if (NOT "${src_files}" STREQUAL "")
                    list(REMOVE_DUPLICATES src_files)
                endif ()
55
                add_custom_command(TARGET ${TARGET} PRE_BUILD
P
peizhilin 已提交
56 57 58 59 60 61 62 63
                        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 ()
            endif()
64 65 66 67 68 69 70
        else (WIN32) # not windows
            add_custom_command(TARGET ${TARGET} PRE_BUILD
                    COMMAND mkdir -p "${dst}"
                    COMMAND cp -r "${src}" "${dst}"
                    COMMENT "copying ${src} -> ${dst}")
        endif (WIN32) # not windows
    endforeach ()
L
Luo Tao 已提交
71 72
endfunction()

L
Luo Tao 已提交
73
# third party
74
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/eigen3")
L
Luo Tao 已提交
75
copy(eigen3_lib
76 77 78 79
        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
        DEPS eigen3
        )
L
Luo Tao 已提交
80

81
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/gflags")
L
Luo Tao 已提交
82
copy(gflags_lib
83 84 85 86
        SRCS ${GFLAGS_INCLUDE_DIR} ${GFLAGS_LIBRARIES}
        DSTS ${dst_dir} ${dst_dir}/lib
        DEPS gflags
        )
L
Luo Tao 已提交
87

88
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/glog")
L
Luo Tao 已提交
89
copy(glog_lib
90 91 92 93
        SRCS ${GLOG_INCLUDE_DIR} ${GLOG_LIBRARIES}
        DSTS ${dst_dir} ${dst_dir}/lib
        DEPS glog
        )
L
Luo Tao 已提交
94

95
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/boost/")
Q
qiaolongfei 已提交
96
copy(boost_lib
97 98 99 100
        SRCS ${BOOST_INCLUDE_DIR}/boost
        DSTS ${dst_dir}
        DEPS boost
        )
Q
qiaolongfei 已提交
101

102 103
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/xxhash")
copy(xxhash_lib
104 105 106 107
        SRCS ${XXHASH_INCLUDE_DIR} ${XXHASH_LIBRARIES}
        DSTS ${dst_dir} ${dst_dir}/lib
        DEPS xxhash
        )
108

P
peizhilin 已提交
109
if (NOT PROTOBUF_FOUND OR WIN32)
110
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/protobuf")
L
Luo Tao 已提交
111
    copy(protobuf_lib
112 113 114 115 116
            SRCS ${PROTOBUF_INCLUDE_DIR} ${PROTOBUF_LIBRARY}
            DSTS ${dst_dir} ${dst_dir}/lib
            DEPS extern_protobuf
            )
endif ()
117

P
peizhilin 已提交
118
if (WITH_MKLML)
119
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/mklml")
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
    if(WIN32)
        copy(mklml_lib
                SRCS ${MKLML_LIB} ${MKLML_IOMP_LIB} ${MKLML_SHARED_LIB}
                    ${MKLML_SHARED_LIB_DEPS} ${MKLML_SHARED_IOMP_LIB} ${MKLML_INC_DIR}
                DSTS ${dst_dir}/lib ${dst_dir}/lib ${dst_dir}/lib
                    ${dst_dir}/lib ${dst_dir}/lib ${dst_dir}
                DEPS mklml
                )
    else()
        copy(mklml_lib
                SRCS ${MKLML_LIB} ${MKLML_IOMP_LIB} ${MKLML_INC_DIR}
                DSTS ${dst_dir}/lib ${dst_dir}/lib ${dst_dir}
                DEPS mklml
                )
    endif()
P
peizhilin 已提交
135 136 137 138 139 140 141
elseif (NOT CBLAS_FOUND OR WIN32)
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/openblas")
    copy(openblas_lib
            SRCS ${CBLAS_INSTALL_DIR}/lib ${CBLAS_INSTALL_DIR}/include
            DSTS ${dst_dir} ${dst_dir}
            DEPS extern_openblas
            )
142 143 144 145
endif ()

if (WITH_MKLDNN)
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/mkldnn")
146 147 148 149 150 151 152 153 154 155 156 157 158
    if(WIN32)
        copy(mkldnn_lib
                SRCS ${MKLDNN_INC_DIR} ${MKLDNN_SHARED_LIB} ${MKLDNN_LIB}
                DSTS ${dst_dir} ${dst_dir}/lib ${dst_dir}/lib
                DEPS mkldnn_shared_lib
                )
    else()
        copy(mkldnn_lib
                SRCS ${MKLDNN_INC_DIR} ${MKLDNN_SHARED_LIB}
                DSTS ${dst_dir} ${dst_dir}/lib
                DEPS mkldnn_shared_lib
                )
    endif()
159
endif ()
Q
qiaolongfei 已提交
160

161 162 163 164 165 166 167 168 169
if (WITH_NGRAPH)
    set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/ngraph")
    copy(ngraph_lib
            SRCS ${NGRAPH_INC_DIR} ${NGRAPH_LIB_DIR}
            DSTS ${dst_dir} ${dst_dir}
            DEPS ngraph
            )
endif ()

T
Tao Luo 已提交
170 171 172 173 174
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/snappy")
copy(snappy_lib
        SRCS ${SNAPPY_INCLUDE_DIR} ${SNAPPY_LIBRARIES}
        DSTS ${dst_dir} ${dst_dir}/lib
        DEPS snappy)
175

T
Tao Luo 已提交
176 177 178 179 180
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/snappystream")
copy(snappystream_lib
        SRCS ${SNAPPYSTREAM_INCLUDE_DIR} ${SNAPPYSTREAM_LIBRARIES}
        DSTS ${dst_dir} ${dst_dir}/lib
        DEPS snappystream)
181

T
Tao Luo 已提交
182 183 184 185 186
set(dst_dir "${FLUID_INSTALL_DIR}/third_party/install/zlib")
copy(zlib_lib
        SRCS ${ZLIB_INCLUDE_DIR} ${ZLIB_LIBRARIES}
        DSTS ${dst_dir} ${dst_dir}/lib
        DEPS zlib)
187

L
Luo Tao 已提交
188
# paddle fluid module
189
set(src_dir "${PADDLE_SOURCE_DIR}/paddle/fluid")
190
set(dst_dir "${FLUID_INSTALL_DIR}/paddle/fluid")
L
Luo Tao 已提交
191
set(module "framework")
D
dzhwinter 已提交
192
if (NOT WIN32)
193 194
    set(framework_lib_deps framework_py_proto)
endif (NOT WIN32)
L
luotao1 已提交
195
copy(framework_lib DEPS ${framework_lib_deps}
196 197 198 199
        SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/details/*.h ${PADDLE_BINARY_DIR}/paddle/fluid/framework/framework.pb.h
        ${src_dir}/${module}/ir/*.h
        DSTS ${dst_dir}/${module} ${dst_dir}/${module}/details ${dst_dir}/${module} ${dst_dir}/${module}/ir
        )
L
Luo Tao 已提交
200

L
Luo Tao 已提交
201 202
set(module "memory")
copy(memory_lib
W
Wojciech Uss 已提交
203 204
        SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/detail/*.h ${src_dir}/${module}/allocation/*.h
        DSTS ${dst_dir}/${module} ${dst_dir}/${module}/detail ${dst_dir}/${module}/allocation
205
        )
L
Luo Tao 已提交
206

Y
Yan Chunwei 已提交
207
set(inference_deps paddle_fluid_shared paddle_fluid)
L
Luo Tao 已提交
208

209
set(module "inference/api")
210
if (WITH_ANAKIN AND WITH_MKL)
211
    copy(anakin_inference_lib DEPS paddle_inference_api inference_anakin_api
212 213 214 215 216 217
            SRCS
            ${PADDLE_BINARY_DIR}/paddle/fluid/inference/api/libinference_anakin_api* # compiled anakin api
            ${ANAKIN_INSTALL_DIR} # anakin release
            DSTS ${FLUID_INSTALL_DIR}/third_party/install/anakin ${FLUID_INSTALL_DIR}/third_party/install/anakin)
    list(APPEND inference_deps anakin_inference_lib)
endif ()
218

N
nhzlx 已提交
219 220
if (TENSORRT_FOUND)
    copy(tensorrt_lib DEPS ${inference_deps} 
221
        SRCS ${TENSORRT_ROOT}/include/Nv*.h ${TENSORRT_ROOT}/lib/*nvinfer*
N
nhzlx 已提交
222 223 224 225
        DSTS ${FLUID_INSTALL_DIR}/third_party/install/tensorrt/include ${FLUID_INSTALL_DIR}/third_party/install/tensorrt/lib)
endif ()


Y
Yan Chunwei 已提交
226
set(module "inference")
P
peizhilin 已提交
227 228 229 230 231
if(WIN32)
    set(paddle_fluid_lib ${PADDLE_BINARY_DIR}/paddle/fluid/inference/${CMAKE_BUILD_TYPE}/libpaddle_fluid.*)
else(WIN32)
    set(paddle_fluid_lib ${PADDLE_BINARY_DIR}/paddle/fluid/inference/libpaddle_fluid.*)
endif(WIN32)
Y
Yan Chunwei 已提交
232
copy(inference_lib DEPS ${inference_deps}
P
peizhilin 已提交
233
  SRCS ${src_dir}/${module}/*.h ${paddle_fluid_lib}
234
       ${src_dir}/${module}/api/paddle_*.h
T
Tao Luo 已提交
235
  DSTS ${dst_dir}/${module} ${dst_dir}/${module} ${dst_dir}/${module}
P
peizhilin 已提交
236
        )
Y
Yan Chunwei 已提交
237

L
Luo Tao 已提交
238
set(module "platform")
X
Xin Pan 已提交
239
copy(platform_lib DEPS profiler_py_proto
240 241 242
        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 已提交
243

L
Luo Tao 已提交
244 245
set(module "string")
copy(string_lib
246 247 248
        SRCS ${src_dir}/${module}/*.h ${src_dir}/${module}/tinyformat/*.h
        DSTS ${dst_dir}/${module} ${dst_dir}/${module}/tinyformat
        )
L
Luo Tao 已提交
249

250 251
set(module "pybind")
copy(pybind_lib
252 253 254
        SRCS ${CMAKE_CURRENT_BINARY_DIR}/paddle/fluid/${module}/pybind.h
        DSTS ${dst_dir}/${module}
        )
255

256 257
# CMakeCache Info
copy(cmake_cache
258 259
        SRCS ${CMAKE_CURRENT_BINARY_DIR}/CMakeCache.txt
        DSTS ${FLUID_INSTALL_DIR})
260

261
# This command generates a complete fluid library for both train and inference
262
add_custom_target(fluid_lib_dist DEPENDS ${fluid_lib_dist_dep})
263

T
Tao Luo 已提交
264 265 266
# Following commands generate a inference-only fluid library
# third_party, version.txt and CMakeCache.txt are the same position with ${FLUID_INSTALL_DIR}
copy(third_party DEPS fluid_lib_dist
267 268 269
        SRCS ${FLUID_INSTALL_DIR}/third_party ${FLUID_INSTALL_DIR}/CMakeCache.txt
        DSTS ${FLUID_INFERENCE_INSTALL_DIR} ${FLUID_INFERENCE_INSTALL_DIR}
        )
T
Tao Luo 已提交
270

271
# only need libpaddle_fluid.so/a and paddle_*.h for inference-only library
T
Tao Luo 已提交
272
copy(inference_api_lib DEPS fluid_lib_dist
P
peizhilin 已提交
273
  SRCS ${paddle_fluid_lib}
274
       ${FLUID_INSTALL_DIR}/paddle/fluid/inference/paddle_*.h
T
Tao Luo 已提交
275 276 277 278 279
  DSTS ${FLUID_INFERENCE_INSTALL_DIR}/paddle/lib ${FLUID_INFERENCE_INSTALL_DIR}/paddle/include
)

add_custom_target(inference_lib_dist DEPENDS third_party inference_api_lib)

280
# paddle fluid version
T
Tao Luo 已提交
281
function(version version_file)
282 283 284 285 286 287 288 289 290 291 292 293 294 295
    execute_process(
            COMMAND ${GIT_EXECUTABLE} log --pretty=format:%H -1
            WORKING_DIRECTORY ${PADDLE_SOURCE_DIR}
            OUTPUT_VARIABLE PADDLE_GIT_COMMIT)
    file(WRITE ${version_file}
            "GIT COMMIT ID: ${PADDLE_GIT_COMMIT}\n"
            "WITH_MKL: ${WITH_MKL}\n"
            "WITH_MKLDNN: ${WITH_MKLDNN}\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 ()
T
Tao Luo 已提交
296 297 298
endfunction()
version(${FLUID_INSTALL_DIR}/version.txt)
version(${FLUID_INFERENCE_INSTALL_DIR}/version.txt)