|
|
|
@ -14,27 +14,31 @@ function(op_library TARGET)
|
|
|
|
|
cmake_parse_arguments(op_library "${options}" "${oneValueArgs}"
|
|
|
|
|
"${multiValueArgs}" ${ARGN})
|
|
|
|
|
|
|
|
|
|
foreach(src ${op_library_SRCS})
|
|
|
|
|
if (${src} MATCHES ".*\\.cu$")
|
|
|
|
|
list(APPEND cu_srcs ${src})
|
|
|
|
|
elseif(${src} MATCHES ".*\\.cc$")
|
|
|
|
|
list(APPEND cc_srcs ${src})
|
|
|
|
|
else()
|
|
|
|
|
message(FATAL_ERROR "${TARGET} Source file ${src} should only be .cc or .cu")
|
|
|
|
|
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)
|
|
|
|
|
endif()
|
|
|
|
|
endforeach()
|
|
|
|
|
if (EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${TARGET}.cu)
|
|
|
|
|
list(APPEND cu_srcs ${TARGET}.cc)
|
|
|
|
|
endif()
|
|
|
|
|
else()
|
|
|
|
|
foreach(src ${op_library_SRCS})
|
|
|
|
|
if (${src} MATCHES ".*\\.cu$")
|
|
|
|
|
list(APPEND cu_srcs ${src})
|
|
|
|
|
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()
|
|
|
|
|
|
|
|
|
|
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()
|
|
|
|
|
|
|
|
|
|
list(LENGTH cu_srcs cu_srcs_len)
|
|
|
|
|
list(LENGTH op_library_DEPS dep_len)
|
|
|
|
|
if (${cu_srcs_len} EQUAL 0 AND ${dep_len} EQUAL 0)
|
|
|
|
|
message(WARNING "The op library ${TARGET} not support GPU!")
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
if (WITH_GPU)
|
|
|
|
|
nv_library(${TARGET} SRCS ${cc_srcs} ${cu_srcs} DEPS ${op_library_DEPS}
|
|
|
|
|
${op_common_deps})
|
|
|
|
@ -46,32 +50,22 @@ endfunction()
|
|
|
|
|
|
|
|
|
|
add_subdirectory(math)
|
|
|
|
|
|
|
|
|
|
set(ONLYCPU_OPS
|
|
|
|
|
net_op
|
|
|
|
|
gather_op
|
|
|
|
|
scatter_op)
|
|
|
|
|
foreach(src ${ONLYCPU_OPS})
|
|
|
|
|
op_library(${src} SRCS ${src}.cc)
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
|
|
set(DEPS_OPS
|
|
|
|
|
identity_op
|
|
|
|
|
minus_op
|
|
|
|
|
mul_op
|
|
|
|
|
recurrent_op
|
|
|
|
|
scale_op)
|
|
|
|
|
op_library(identity_op SRCS identity_op.cc DEPS scale_op)
|
|
|
|
|
op_library(minus_op SRCS minus_op.cc minus_op.cu DEPS scale_op)
|
|
|
|
|
op_library(mul_op SRCS mul_op.cc mul_op.cu DEPS math_function)
|
|
|
|
|
op_library(identity_op DEPS scale_op)
|
|
|
|
|
op_library(minus_op DEPS scale_op)
|
|
|
|
|
op_library(mul_op DEPS math_function)
|
|
|
|
|
op_library(recurrent_op SRCS recurrent_op.cc rnn/recurrent_op_utils.cc
|
|
|
|
|
DEPS framework_proto tensor operator net_op)
|
|
|
|
|
op_library(scale_op SRCS scale_op.cc scale_op.cu DEPS net_op)
|
|
|
|
|
op_library(scale_op DEPS net_op)
|
|
|
|
|
|
|
|
|
|
list(REMOVE_ITEM GENERAL_OPS
|
|
|
|
|
${ONLYCPU_OPS}
|
|
|
|
|
${DEPS_OPS})
|
|
|
|
|
list(REMOVE_ITEM GENERAL_OPS ${DEPS_OPS})
|
|
|
|
|
foreach(src ${GENERAL_OPS})
|
|
|
|
|
op_library(${src} SRCS ${src}.cc ${src}.cu)
|
|
|
|
|
op_library(${src})
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
|
|
set(GLOB_OP_LIB ${OP_LIBRARY} CACHE INTERNAL "Global OP library")
|
|
|
|
|