Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
1ce96fa1
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
1ce96fa1
编写于
2月 23, 2021
作者:
C
Chen Weihang
提交者:
GitHub
2月 24, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[CustomOp] Add new paddle custom op so (#31141)
* add new custom op so * fix use new method error * fix test failed
上级
ebbdf525
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
61 addition
and
15 deletion
+61
-15
paddle/fluid/framework/CMakeLists.txt
paddle/fluid/framework/CMakeLists.txt
+36
-2
python/paddle/fluid/tests/custom_op/test_custom_relu_op_jit.py
...n/paddle/fluid/tests/custom_op/test_custom_relu_op_jit.py
+4
-2
python/paddle/fluid/tests/custom_op/test_dispatch_jit.py
python/paddle/fluid/tests/custom_op/test_dispatch_jit.py
+3
-2
python/paddle/fluid/tests/custom_op/test_multi_out_jit.py
python/paddle/fluid/tests/custom_op/test_multi_out_jit.py
+3
-2
python/paddle/utils/cpp_extension/cpp_extension.py
python/paddle/utils/cpp_extension/cpp_extension.py
+0
-3
python/paddle/utils/cpp_extension/extension_utils.py
python/paddle/utils/cpp_extension/extension_utils.py
+10
-4
python/setup.py.in
python/setup.py.in
+5
-0
未找到文件。
paddle/fluid/framework/CMakeLists.txt
浏览文件 @
1ce96fa1
...
@@ -320,9 +320,9 @@ message(STATUS "branch: ${PADDLE_BRANCH}")
...
@@ -320,9 +320,9 @@ message(STATUS "branch: ${PADDLE_BRANCH}")
configure_file
(
commit.h.in commit.h
)
configure_file
(
commit.h.in commit.h
)
cc_library
(
custom_tensor SRCS ../extension/src/tensor.cc DEPS lod_tensor
)
cc_library
(
custom_tensor SRCS ../extension/src/tensor.cc DEPS lod_tensor
memory enforce
)
cc_library
(
op_meta_info SRCS ../extension/src/op_meta_info.cc DEPS custom_tensor
)
cc_library
(
op_meta_info SRCS ../extension/src/op_meta_info.cc DEPS custom_tensor
)
cc_library
(
custom_operator SRCS custom_operator.cc DEPS
operator op_registry device_context dynamic_load
er custom_tensor op_meta_info
)
cc_library
(
custom_operator SRCS custom_operator.cc DEPS
tensor attribute framework_proto op_registry operator dynamic_loader string_help
er custom_tensor op_meta_info
)
cc_test
(
custom_tensor_test SRCS custom_tensor_test.cc DEPS custom_tensor glog
)
cc_test
(
custom_tensor_test SRCS custom_tensor_test.cc DEPS custom_tensor glog
)
set
(
FLUID_FRAMEWORK_MODULES proto_desc memory lod_tensor executor data_feed_proto layer dynamic_loader custom_operator
)
set
(
FLUID_FRAMEWORK_MODULES proto_desc memory lod_tensor executor data_feed_proto layer dynamic_loader custom_operator
)
...
@@ -361,3 +361,37 @@ endif()
...
@@ -361,3 +361,37 @@ endif()
if
(
WITH_TESTING AND TEST selected_rows_test
)
if
(
WITH_TESTING AND TEST selected_rows_test
)
set_tests_properties
(
selected_rows_test PROPERTIES TIMEOUT 120
)
set_tests_properties
(
selected_rows_test PROPERTIES TIMEOUT 120
)
endif
()
endif
()
# New custom op extension mechanism related
# if not deps `layer`, will cause: undefined symbol: _ZN6paddle10imperative7VarBase9name_set_
set
(
PADDLE_CUSTOM_OP_MODULES custom_tensor op_meta_info custom_operator layer
)
cc_library
(
paddle_custom_op_shared
SHARED SRCS custom_operator.cc ../extension/src/tensor.cc ../extension/src/op_meta_info.cc
${
CMAKE_SOURCE_DIR
}
/paddle/fluid/imperative/layer.cc
DEPS
${
PADDLE_CUSTOM_OP_MODULES
}
)
get_property
(
os_dependency_modules GLOBAL PROPERTY OS_DEPENDENCY_MODULES
)
set_target_properties
(
paddle_custom_op_shared PROPERTIES OUTPUT_NAME paddle_custom_op
)
target_link_libraries
(
paddle_custom_op_shared
${
os_dependency_modules
}
)
if
(
LINUX
)
set
(
PADDLE_CUSTOM_OP_SHARED_LIB
${
PADDLE_BINARY_DIR
}
/paddle/fluid/framework/libpaddle_custom_op.so
CACHE INTERNAL
"Paddle custom op lib"
)
endif
()
if
(
WIN32
)
set
(
PADDLE_CUSTOM_OP_SHARED_LIB
${
PADDLE_BINARY_DIR
}
/paddle/fluid/framework/
${
CMAKE_BUILD_TYPE
}
/paddle_custom_op.lib
CACHE INTERNAL
"Paddle custom op lib"
)
set
(
PADDLE_CUSTOM_OP_SHARED_LIB
${
PADDLE_BINARY_DIR
}
/paddle/fluid/framework/
${
CMAKE_BUILD_TYPE
}
/paddle_custom_op.dll
CACHE INTERNAL
"Paddle custom op dll"
)
endif
()
if
(
APPLE
)
set
(
PADDLE_CUSTOM_OP_SHARED_LIB
${
PADDLE_BINARY_DIR
}
/paddle/fluid/framework/paddle_custom_op.dylib
CACHE INTERNAL
"Paddle custom op lib"
)
endif
()
python/paddle/fluid/tests/custom_op/test_custom_relu_op_jit.py
浏览文件 @
1ce96fa1
...
@@ -24,8 +24,10 @@ from test_custom_relu_op_setup import custom_relu_dynamic, custom_relu_static
...
@@ -24,8 +24,10 @@ from test_custom_relu_op_setup import custom_relu_dynamic, custom_relu_static
# Because Windows don't use docker, the shared lib already exists in the
# Because Windows don't use docker, the shared lib already exists in the
# cache dir, it will not be compiled again unless the shared lib is removed.
# cache dir, it will not be compiled again unless the shared lib is removed.
if
os
.
name
==
'nt'
:
file
=
'{}
\\
custom_relu_module_jit
\\
custom_relu_module_jit.pyd'
.
format
(
cmd
=
'del {}
\\
custom_relu_module_jit.pyd'
.
format
(
get_build_directory
())
get_build_directory
())
if
os
.
name
==
'nt'
and
os
.
path
.
isfile
(
file
):
cmd
=
'del {}'
.
format
(
file
)
run_cmd
(
cmd
,
True
)
run_cmd
(
cmd
,
True
)
# Compile and load custom op Just-In-Time.
# Compile and load custom op Just-In-Time.
...
...
python/paddle/fluid/tests/custom_op/test_dispatch_jit.py
浏览文件 @
1ce96fa1
...
@@ -22,8 +22,9 @@ from paddle.utils.cpp_extension.extension_utils import run_cmd
...
@@ -22,8 +22,9 @@ from paddle.utils.cpp_extension.extension_utils import run_cmd
# Because Windows don't use docker, the shared lib already exists in the
# Because Windows don't use docker, the shared lib already exists in the
# cache dir, it will not be compiled again unless the shared lib is removed.
# cache dir, it will not be compiled again unless the shared lib is removed.
if
os
.
name
==
'nt'
:
file
=
'{}
\\
dispatch_op
\\
dispatch_op.pyd'
.
format
(
get_build_directory
())
cmd
=
'del {}
\\
dispatch_op.pyd'
.
format
(
get_build_directory
())
if
os
.
name
==
'nt'
and
os
.
path
.
isfile
(
file
):
cmd
=
'del {}'
.
format
(
file
)
run_cmd
(
cmd
,
True
)
run_cmd
(
cmd
,
True
)
dispatch_op
=
load
(
dispatch_op
=
load
(
...
...
python/paddle/fluid/tests/custom_op/test_multi_out_jit.py
浏览文件 @
1ce96fa1
...
@@ -25,8 +25,9 @@ from utils import paddle_includes, extra_compile_args
...
@@ -25,8 +25,9 @@ from utils import paddle_includes, extra_compile_args
# Because Windows don't use docker, the shared lib already exists in the
# Because Windows don't use docker, the shared lib already exists in the
# cache dir, it will not be compiled again unless the shared lib is removed.
# cache dir, it will not be compiled again unless the shared lib is removed.
if
os
.
name
==
'nt'
:
file
=
'{}
\\
multi_out_jit
\\
multi_out_jit.pyd'
.
format
(
get_build_directory
())
cmd
=
'del {}
\\
multi_out_jit.pyd'
.
format
(
get_build_directory
())
if
os
.
name
==
'nt'
and
os
.
path
.
isfile
(
file
):
cmd
=
'del {}'
.
format
(
file
)
run_cmd
(
cmd
,
True
)
run_cmd
(
cmd
,
True
)
# Compile and load custom op Just-In-Time.
# Compile and load custom op Just-In-Time.
...
...
python/paddle/utils/cpp_extension/cpp_extension.py
浏览文件 @
1ce96fa1
...
@@ -219,9 +219,6 @@ class BuildExtension(build_ext, object):
...
@@ -219,9 +219,6 @@ class BuildExtension(build_ext, object):
super
(
BuildExtension
,
self
).
__init__
(
*
args
,
**
kwargs
)
super
(
BuildExtension
,
self
).
__init__
(
*
args
,
**
kwargs
)
self
.
no_python_abi_suffix
=
kwargs
.
get
(
"no_python_abi_suffix"
,
True
)
self
.
no_python_abi_suffix
=
kwargs
.
get
(
"no_python_abi_suffix"
,
True
)
self
.
output_dir
=
kwargs
.
get
(
"output_dir"
,
None
)
self
.
output_dir
=
kwargs
.
get
(
"output_dir"
,
None
)
# for compatible two custom op define method
use_new_custom_op_load_method
(
kwargs
.
get
(
"use_new_method"
,
use_new_custom_op_load_method
()))
def
initialize_options
(
self
):
def
initialize_options
(
self
):
super
(
BuildExtension
,
self
).
initialize_options
()
super
(
BuildExtension
,
self
).
initialize_options
()
...
...
python/paddle/utils/cpp_extension/extension_utils.py
浏览文件 @
1ce96fa1
...
@@ -288,7 +288,10 @@ def normalize_extension_kwargs(kwargs, use_cuda=False):
...
@@ -288,7 +288,10 @@ def normalize_extension_kwargs(kwargs, use_cuda=False):
# append link flags
# append link flags
extra_link_args
=
kwargs
.
get
(
'extra_link_args'
,
[])
extra_link_args
=
kwargs
.
get
(
'extra_link_args'
,
[])
extra_link_args
.
append
(
'-lpaddle_framework'
)
if
use_new_custom_op_load_method
():
extra_link_args
.
append
(
'-lpaddle_custom_op'
)
else
:
extra_link_args
.
append
(
'-lpaddle_framework'
)
if
use_cuda
:
if
use_cuda
:
extra_link_args
.
append
(
'-lcudart'
)
extra_link_args
.
append
(
'-lcudart'
)
...
@@ -592,6 +595,10 @@ def _write_setup_file(name,
...
@@ -592,6 +595,10 @@ def _write_setup_file(name,
import os
import os
from paddle.utils.cpp_extension import CppExtension, CUDAExtension, BuildExtension, setup
from paddle.utils.cpp_extension import CppExtension, CUDAExtension, BuildExtension, setup
from paddle.utils.cpp_extension import get_build_directory
from paddle.utils.cpp_extension import get_build_directory
from paddle.utils.cpp_extension.extension_utils import use_new_custom_op_load_method
use_new_custom_op_load_method({use_new_method})
setup(
setup(
name='{name}',
name='{name}',
ext_modules=[
ext_modules=[
...
@@ -601,9 +608,8 @@ def _write_setup_file(name,
...
@@ -601,9 +608,8 @@ def _write_setup_file(name,
extra_compile_args={extra_compile_args},
extra_compile_args={extra_compile_args},
extra_link_args={extra_link_args})],
extra_link_args={extra_link_args})],
cmdclass={{"build_ext" : BuildExtension.with_options(
cmdclass={{"build_ext" : BuildExtension.with_options(
output_dir='{build_dir}',
output_dir=r'{build_dir}',
no_python_abi_suffix=True,
no_python_abi_suffix=True)
use_new_method={use_new_method})
}})"""
).
lstrip
()
}})"""
).
lstrip
()
with_cuda
=
False
with_cuda
=
False
...
...
python/setup.py.in
浏览文件 @
1ce96fa1
...
@@ -340,6 +340,11 @@ if sys.platform.startswith('linux'):
...
@@ -340,6 +340,11 @@ if sys.platform.startswith('linux'):
shutil.copy('${FLUID_FRAMEWORK_SHARED_LIB}', libs_path)
shutil.copy('${FLUID_FRAMEWORK_SHARED_LIB}', libs_path)
package_data['paddle.libs'] += ['libpaddle_framework.so']
package_data['paddle.libs'] += ['libpaddle_framework.so']
# copy libpaddle_custom_op.so to libs on linux
if sys.platform.startswith('linux'):
shutil.copy('${PADDLE_CUSTOM_OP_SHARED_LIB}', libs_path)
package_data['paddle.libs'] += ['libpaddle_custom_op.so']
# copy paddle_framework.lib/paddle_framework.dll to libs on windows
# copy paddle_framework.lib/paddle_framework.dll to libs on windows
if os.name == 'nt':
if os.name == 'nt':
shutil.copy('${FLUID_FRAMEWORK_IMPORT_LIB}', libs_path)
shutil.copy('${FLUID_FRAMEWORK_IMPORT_LIB}', libs_path)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录