CMakeLists.txt 9.4 KB
Newer Older
L
Luo Tao 已提交
1 2
file(GLOB GENERAL_OPS RELATIVE "${CMAKE_CURRENT_SOURCE_DIR}" "*_op.cc")
string(REPLACE ".cc" "" GENERAL_OPS "${GENERAL_OPS}")
3
set(DEPS_OPS "")
4
set(pybind_file ${PADDLE_SOURCE_DIR}/paddle/fluid/pybind/pybind.h)
L
Luo Tao 已提交
5
file(WRITE ${pybind_file} "// Generated by the paddle/operator/CMakeLists.txt.  DO NOT EDIT!\n\n")
Y
Yu Yang 已提交
6 7 8 9
function(op_library TARGET)
    # op_library is a function to create op library. The interface is same as
    # cc_library. But it handle split GPU/CPU code and link some common library
    # for ops.
L
Luo Tao 已提交
10
    set(OP_LIBRARY ${TARGET} ${OP_LIBRARY} PARENT_SCOPE)
Y
Yu Yang 已提交
11 12
    set(cc_srcs)
    set(cu_srcs)
13
    set(cu_cc_srcs)
C
chengduoZH 已提交
14
    set(cudnn_cu_cc_srcs)
Y
update  
Yancey1989 已提交
15
    set(op_common_deps operator op_registry math_function)
Y
Yu Yang 已提交
16 17 18
    set(options "")
    set(oneValueArgs "")
    set(multiValueArgs SRCS DEPS)
L
Luo Tao 已提交
19
    set(pybind_flag 0)
Y
Yu Yang 已提交
20 21 22
    cmake_parse_arguments(op_library "${options}" "${oneValueArgs}"
            "${multiValueArgs}" ${ARGN})

23 24 25 26
    list(LENGTH op_library_SRCS op_library_SRCS_len)
    if (${op_library_SRCS_len} EQUAL 0)
        if (EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${TARGET}.cc)
            list(APPEND cc_srcs ${TARGET}.cc)
Y
Yu Yang 已提交
27
        endif()
28 29 30
        if (EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${TARGET}.cu.cc)
            list(APPEND cu_cc_srcs ${TARGET}.cu.cc)
        endif()
31
        if (EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${TARGET}.cu)
32
            list(APPEND cu_srcs ${TARGET}.cu)
33 34 35 36 37
        endif()
    else()
        foreach(src ${op_library_SRCS})
            if (${src} MATCHES ".*\\.cu$")
                list(APPEND cu_srcs ${src})
C
chengduoZH 已提交
38 39
            elseif(${src} MATCHES ".*_cudnn_op.cu.cc$")
                list(APPEND cudnn_cu_cc_srcs ${src})
40 41
            elseif(${src} MATCHES ".*\\.cu.cc$")
                list(APPEND cu_cc_srcs ${src})
42 43 44 45 46 47 48
            elseif(${src} MATCHES ".*\\.cc$")
                list(APPEND cc_srcs ${src})
            else()
                message(FATAL_ERROR "${TARGET} Source file ${src} should only be .cc or .cu")
            endif()
        endforeach()
    endif()
Y
Yu Yang 已提交
49 50 51 52 53 54

    list(LENGTH cc_srcs cc_srcs_len)
    if (${cc_srcs_len} EQUAL 0)
        message(FATAL_ERROR "The op library ${TARGET} should contains at least one .cc file")
    endif()

55 56 57 58
    list(LENGTH op_library_DEPS op_library_DEPS_len)
    if (${op_library_DEPS_len} GREATER 0)
        set(DEPS_OPS ${TARGET} ${DEPS_OPS} PARENT_SCOPE)
    endif()
Y
Yu Yang 已提交
59
    if (WITH_GPU)
C
chengduoZH 已提交
60
        nv_library(${TARGET} SRCS ${cc_srcs} ${cu_cc_srcs} ${cudnn_cu_cc_srcs} ${cu_srcs} DEPS ${op_library_DEPS}
Y
Yu Yang 已提交
61 62 63 64 65
                ${op_common_deps})
    else()
        cc_library(${TARGET} SRCS ${cc_srcs} DEPS ${op_library_DEPS}
                ${op_common_deps})
    endif()
L
Luo Tao 已提交
66

67
    # Define operators that don't need pybind here.
F
fengjiayi 已提交
68
    foreach(manual_pybind_op "net_op" "compare_op" "logical_op" "nccl_op" "tensor_array_read_write_op" "create_reader_op")
69 70 71 72
        if ("${TARGET}" STREQUAL "${manual_pybind_op}")
            set(pybind_flag 1)
        endif()
    endforeach()
Q
qijun 已提交
73

74 75 76
    # The registration of USE_OP, please refer to paddle/framework/op_registry.h.
    # Note that it's enough to just adding one operator to pybind in a *_op.cc file.
    # And for detail pybind information, please see generated paddle/pybind/pybind.h.
77 78 79 80 81 82 83 84
    file(READ ${TARGET}.cc TARGET_CONTENT)
    string(REGEX MATCH "REGISTER_OP\\(.*REGISTER_OP\\(" multi_register "${TARGET_CONTENT}")
    string(REGEX MATCH "REGISTER_OP\\([a-z0-9_]*," one_register "${multi_register}")
    if (one_register STREQUAL "")
        string(REPLACE "_op" "" TARGET "${TARGET}")
    else ()
        string(REPLACE "REGISTER_OP(" "" TARGET "${one_register}")
        string(REPLACE "," "" TARGET "${TARGET}")
Y
Yu Yang 已提交
85 86
    endif()

L
Luo Tao 已提交
87
    # pybind USE_NO_KERNEL_OP
T
typhoonzero 已提交
88
    # HACK: if REGISTER_OP_CPU_KERNEL presents the operator must have kernel
T
typhoonzero 已提交
89
    string(REGEX MATCH "REGISTER_OP_CPU_KERNEL" regex_result "${TARGET_CONTENT}")
L
Luo Tao 已提交
90 91 92 93 94 95 96 97
    string(REPLACE "_op" "" TARGET "${TARGET}")
    if (${pybind_flag} EQUAL 0 AND regex_result STREQUAL "")
        file(APPEND ${pybind_file} "USE_NO_KERNEL_OP(${TARGET});\n")
        set(pybind_flag 1)
    endif()

    # pybind USE_CPU_ONLY_OP
    list(LENGTH cu_srcs cu_srcs_len)
98 99
    list(LENGTH cu_cc_srcs cu_cc_srcs_len)
    if (${pybind_flag} EQUAL 0 AND ${cu_srcs_len} EQUAL 0 AND ${cu_cc_srcs_len} EQUAL 0)
L
Luo Tao 已提交
100 101 102 103
        file(APPEND ${pybind_file} "USE_CPU_ONLY_OP(${TARGET});\n")
        set(pybind_flag 1)
    endif()

C
chengduoZH 已提交
104 105 106 107 108 109
    # pybind USE_OP_DEVICE_KERNEL for CUDNN
    list(LENGTH cudnn_cu_cc_srcs cudnn_cu_cc_srcs_len)
    if (${cudnn_cu_cc_srcs_len} GREATER 0)
        file(APPEND ${pybind_file} "USE_OP_DEVICE_KERNEL(${TARGET}, CUDNN);\n")
    endif()

L
Luo Tao 已提交
110 111 112 113
    # pybind USE_OP
    if (${pybind_flag} EQUAL 0)
        file(APPEND ${pybind_file} "USE_OP(${TARGET});\n")
    endif()
Y
Yu Yang 已提交
114 115
endfunction()

Q
qijun 已提交
116
add_subdirectory(math)
D
Dong Zhihong 已提交
117
add_subdirectory(nccl)
118

L
Luo Tao 已提交
119 120
if(WITH_GPU)
    op_library(nccl_op DEPS nccl_common)
121
    file(APPEND ${pybind_file} "USE_CUDA_ONLY_OP(ncclAllReduce);\n")
L
Luo Tao 已提交
122 123 124
else()
    set(DEPS_OPS ${DEPS_OPS} nccl_op)
endif()
Q
QI JUN 已提交
125

T
typhoonzero 已提交
126
if(WITH_DISTRIBUTE)
127 128 129 130 131 132 133
    add_subdirectory(detail)
    set(DISTRIBUTE_DEPS sendrecvop_grpc grpc++_unsecure grpc_unsecure gpr cares zlib_target protobuf)
    set(DISTRIBUTE_COMPILE_FLAGS "-Wno-non-virtual-dtor -Wno-error=non-virtual-dtor -Wno-error=delete-non-virtual-dtor")
    op_library(send_op DEPS ${DISTRIBUTE_DEPS})
    set_source_files_properties(send_op.cc PROPERTIES COMPILE_FLAGS ${DISTRIBUTE_COMPILE_FLAGS})
    op_library(recv_op DEPS ${DISTRIBUTE_DEPS})
    set_source_files_properties(recv_op.cc PROPERTIES COMPILE_FLAGS ${DISTRIBUTE_COMPILE_FLAGS})
134 135 136
    op_library(listen_and_serv_op DEPS ${DISTRIBUTE_DEPS})
    set_source_files_properties(listen_and_serv_op.cc PROPERTIES COMPILE_FLAGS ${DISTRIBUTE_COMPILE_FLAGS})
    cc_test(test_send_recv SRCS send_recv_op_test.cc DEPS send_op listen_and_serv_op sum_op executor)
137
else()
138
    set(DEPS_OPS ${DEPS_OPS} send_op recv_op listen_and_serv_op)
T
typhoonzero 已提交
139 140
endif()

141
op_library(cond_op DEPS framework_proto tensor net_op)
142 143
op_library(cross_entropy_op DEPS cross_entropy)
op_library(softmax_with_cross_entropy_op DEPS cross_entropy softmax)
144
op_library(softmax_op DEPS softmax)
S
sweetsky0901 已提交
145
op_library(detection_output_op DEPS softmax)
146
op_library(sequence_softmax_op DEPS softmax)
Q
QI JUN 已提交
147 148
op_library(sum_op DEPS selected_rows_functor)
op_library(sgd_op DEPS selected_rows_functor)
Y
Yan Chunwei 已提交
149
op_library(print_op DEPS lod_tensor)
Q
QI JUN 已提交
150
op_library(adagrad_op DEPS selected_rows_functor)
W
wanghaox 已提交
151
op_library(maxout_op DEPS maxouting)
S
sweetsky0901 已提交
152
op_library(unpool_op DEPS unpooling)
C
chengduoZH 已提交
153
op_library(pool_with_index_op DEPS pooling)
154 155 156 157
op_library(lod_rank_table_op DEPS lod_rank_table)
op_library(lod_tensor_to_array_op DEPS lod_rank_table_op)
op_library(array_to_lod_tensor_op DEPS lod_rank_table_op)
op_library(max_sequence_len_op DEPS lod_rank_table)
C
chengduoZH 已提交
158
op_library(sequence_conv_op DEPS context_project)
159
op_library(sequence_pool_op DEPS sequence_pooling)
D
dangqingqing 已提交
160
op_library(lstm_op DEPS sequence2batch lstm_compute)
161
op_library(lstmp_op DEPS sequence2batch lstm_compute)
G
guosheng 已提交
162
op_library(gru_op DEPS sequence2batch gru_compute)
163
op_library(recurrent_op DEPS executor)
W
wanghaoshuang 已提交
164
op_library(warpctc_op DEPS dynload_warpctc sequence_padding sequence_scale math_function)
C
chengduoZH 已提交
165
op_library(cos_sim_op DEPS cos_sim_functor)
Y
Yang Yang 已提交
166
op_library(parallel_do_op DEPS executor)
F
fengjiayi 已提交
167
op_library(create_reader_op DEPS reader)
168 169 170

# Regist multiple Kernel to pybind
if (WITH_GPU)
C
chengduoZH 已提交
171 172 173 174 175 176
    op_library(conv_op SRCS conv_op.cc conv_op.cu.cc conv_cudnn_op.cu.cc DEPS
        vol2col depthwise_conv)
    op_library(edit_distance_op SRCS edit_distance_op.cc edit_distance_op.cu DEPS math_function)
    op_library(pool_op SRCS pool_op.cc pool_op.cu.cc pool_cudnn_op.cu.cc DEPS pooling)
    op_library(conv_transpose_op SRCS conv_transpose_op.cc conv_transpose_op.cu.cc
      conv_transpose_cudnn_op.cu.cc DEPS vol2col)
177
else()
C
chengduoZH 已提交
178 179 180
    op_library(conv_op SRCS conv_op.cc DEPS vol2col)
    op_library(pool_op SRCS pool_op.cc DEPS pooling)
    op_library(conv_transpose_op SRCS conv_transpose_op.cc DEPS vol2col)
181 182
endif()

183 184 185 186 187 188 189 190 191 192 193 194 195 196
cc_library(batch_size_like SRCS batch_size_like.cc DEPS op_registry)

op_library(fill_constant_batch_size_like_op
  SRCS fill_constant_batch_size_like_op.cc fill_constant_batch_size_like_op.cu.cc
  DEPS batch_size_like)

op_library(uniform_random_batch_size_like_op
  SRCS uniform_random_batch_size_like_op.cc
  DEPS batch_size_like uniform_random_op)

op_library(gaussian_random_batch_size_like_op
  SRCS gaussian_random_batch_size_like_op.cc
  DEPS batch_size_like gaussian_random_op)

武毅 已提交
197 198 199
# FIXME(typhoonzero): save/load depends lodtensor serialization functions
op_library(save_op DEPS lod_tensor)
op_library(load_op DEPS lod_tensor)
200 201
op_library(save_combine_op DEPS lod_tensor)
op_library(load_combine_op DEPS lod_tensor)
武毅 已提交
202

203
list(REMOVE_ITEM GENERAL_OPS ${DEPS_OPS})
L
Luo Tao 已提交
204
foreach(src ${GENERAL_OPS})
205
    op_library(${src})
L
Luo Tao 已提交
206
endforeach()
F
fengjiayi 已提交
207
file(APPEND ${pybind_file} "USE_OP(less_than);\nUSE_OP(logical_and);\nUSE_NO_KERNEL_OP(read_from_array);\nUSE_NO_KERNEL_OP(create_random_data_generator);\n")
208

L
Luo Tao 已提交
209 210
set(GLOB_OP_LIB ${OP_LIBRARY} CACHE INTERNAL "Global OP library")

211 212 213
cc_test(gather_test SRCS gather_test.cc DEPS tensor)
cc_test(net_op_test SRCS net_op_test.cc DEPS net_op)
cc_test(scatter_test SRCS scatter_test.cc DEPS tensor)
Q
Qiao Longfei 已提交
214
cc_test(beam_search_decode_op_test SRCS beam_search_decode_op_test.cc DEPS lod_tensor)
Y
Yan Chunwei 已提交
215
cc_test(beam_search_op_test SRCS beam_search_op_test.cc DEPS lod_tensor beam_search_op)
216
cc_test(strided_memcpy_test SRCS strided_memcpy_test.cc DEPS tensor paddle_memory)
D
Dong Zhihong 已提交
217
if(WITH_GPU)
218
    cc_test(nccl_op_test SRCS nccl_op_test.cu.cc DEPS nccl_op gpu_info device_context)
D
Dong Zhihong 已提交
219
endif()
Y
Yu Yang 已提交
220
cc_test(save_load_op_test SRCS save_load_op_test.cc DEPS save_op load_op)
221
cc_test(save_load_combine_op_test SRCS save_load_combine_op_test.cc DEPS save_combine_op load_combine_op)