Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
d4822137
M
mindspore
项目概览
magicwindyyd
/
mindspore
与 Fork 源项目一致
Fork自
MindSpore / mindspore
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
mindspore
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
d4822137
编写于
4月 18, 2020
作者:
X
xiefangqi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix segment bug on windows
上级
d1b452cf
变更
6
显示空白变更内容
内联
并排
Showing
6 changed file
with
42 addition
and
17 deletion
+42
-17
mindspore/ccsrc/CMakeLists.txt
mindspore/ccsrc/CMakeLists.txt
+6
-14
mindspore/ccsrc/dataset/CMakeLists.txt
mindspore/ccsrc/dataset/CMakeLists.txt
+5
-2
mindspore/ccsrc/dataset/engine/datasetops/dataset_op.cc
mindspore/ccsrc/dataset/engine/datasetops/dataset_op.cc
+4
-0
mindspore/ccsrc/dataset/engine/datasetops/map_op.cc
mindspore/ccsrc/dataset/engine/datasetops/map_op.cc
+22
-0
mindspore/ccsrc/dataset/engine/datasetops/map_op.h
mindspore/ccsrc/dataset/engine/datasetops/map_op.h
+4
-0
mindspore/ccsrc/mindrecord/CMakeLists.txt
mindspore/ccsrc/mindrecord/CMakeLists.txt
+1
-1
未找到文件。
mindspore/ccsrc/CMakeLists.txt
浏览文件 @
d4822137
...
@@ -156,7 +156,7 @@ file(GLOB_RECURSE MINDSPORE_SRC_LIST RELATIVE ${CMAKE_CURRENT_SOURCE_DIR}
...
@@ -156,7 +156,7 @@ file(GLOB_RECURSE MINDSPORE_SRC_LIST RELATIVE ${CMAKE_CURRENT_SOURCE_DIR}
)
)
if
(
ENABLE_CPU
)
if
(
ENABLE_CPU
)
list
(
REMOVE_ITEM MINDSPORE_SRC_LIST
"device/gpu/distribution/collective_init.cc"
)
list
(
REMOVE_ITEM MINDSPORE_SRC_LIST
"device/gpu/distribution/collective_init.cc"
)
if
(
WIN32
)
if
(
${
CMAKE_SYSTEM_NAME
}
MATCHES
"Windows"
)
list
(
REMOVE_ITEM MINDSPORE_SRC_LIST
"kernel/kernel_query.cc"
)
list
(
REMOVE_ITEM MINDSPORE_SRC_LIST
"kernel/kernel_query.cc"
)
endif
()
endif
()
endif
()
endif
()
...
@@ -337,19 +337,19 @@ if (ENABLE_D)
...
@@ -337,19 +337,19 @@ if (ENABLE_D)
target_link_libraries
(
mindspore mindspore::protobuf
)
target_link_libraries
(
mindspore mindspore::protobuf
)
endif
()
endif
()
if
(
WIN32
)
if
(
${
CMAKE_SYSTEM_NAME
}
MATCHES
"Windows"
)
target_link_libraries
(
mindspore
${
PYTHON_LIBRARIES
}
mindspore_gvar
)
target_link_libraries
(
mindspore
${
PYTHON_LIBRARIES
}
mindspore_gvar
)
endif
()
endif
()
# set c_expression building
# set c_expression building
if
(
WIN32
)
if
(
${
CMAKE_SYSTEM_NAME
}
MATCHES
"Windows"
)
set
(
PYTHON_MODULE_SOURCE
${
MS_GVAR_SRC_LIST
}
set
(
PYTHON_MODULE_SOURCE
${
MS_GVAR_SRC_LIST
}
pipeline/init.cc
pipeline/init.cc
kernel/oplib/oplib.cc
kernel/oplib/oplib.cc
${
MINDSPORE_SRC_LIST
}
${
MS_STEPS_SRC_LIST
}
${
MS_CCE_SRC_LIST
}
${
MS_AICPU_SRC_LIST
}
${
MS_TASKINFO_LIST
}
${
MS_RT_SRC_LIST
}
${
MINDSPORE_SRC_LIST
}
${
MS_STEPS_SRC_LIST
}
${
MS_CCE_SRC_LIST
}
${
MS_AICPU_SRC_LIST
}
${
MS_TASKINFO_LIST
}
${
MS_RT_SRC_LIST
}
${
GPU_NCCL_LIST
}
${
MS_HCCL_SRC_LIST
}
${
MS_PREDICT_SRC_LIST
}
${
CPU_SRC_LIST
}
${
MEM_REUSE_SRC_LIST
}
${
GPU_KERNEL_SRC_LIST
}
)
${
GPU_NCCL_LIST
}
${
MS_HCCL_SRC_LIST
}
${
MS_PREDICT_SRC_LIST
}
${
CPU_SRC_LIST
}
${
MEM_REUSE_SRC_LIST
}
${
GPU_KERNEL_SRC_LIST
}
)
else
()
else
()
set
(
PYTHON_MODULE_SOURCE
set
(
PYTHON_MODULE_SOURCE
pipeline/init.cc
pipeline/init.cc
kernel/oplib/oplib.cc
kernel/oplib/oplib.cc
${
MS_STEPS_SRC_LIST
}
${
MS_CCE_SRC_LIST
}
${
MS_AICPU_SRC_LIST
}
${
MS_TASKINFO_LIST
}
${
MS_RT_SRC_LIST
}
${
MS_STEPS_SRC_LIST
}
${
MS_CCE_SRC_LIST
}
${
MS_AICPU_SRC_LIST
}
${
MS_TASKINFO_LIST
}
${
MS_RT_SRC_LIST
}
...
@@ -426,13 +426,5 @@ endif()
...
@@ -426,13 +426,5 @@ endif()
if
(
ENABLE_MINDDATA
)
if
(
ENABLE_MINDDATA
)
add_subdirectory
(
mindrecord
)
add_subdirectory
(
mindrecord
)
if
(
WIN32
)
set
(
_md_tmp_CMAKE_CXX_FLAGS_RELEASE
${
CMAKE_CXX_FLAGS_RELEASE
}
)
set
(
CMAKE_CXX_FLAGS_RELEASE
"$ENV{CXXFLAGS} -O0 -Wl,--allow-shlib-undefined -DHALF_ENABLE_CPP11_USER_LITERALS=0"
)
set
(
CMAKE_CXX_FLAGS_RELEASE
"
${
CMAKE_CXX_FLAGS_RELEASE
}
-D_FORTIFY_SOURCE=2"
)
add_subdirectory
(
dataset
)
add_subdirectory
(
dataset
)
set
(
CMAKE_CXX_FLAGS_RELEASE
${
_md_tmp_CMAKE_CXX_FLAGS_RELEASE
}
)
else
()
add_subdirectory
(
dataset
)
endif
()
endif
()
endif
()
mindspore/ccsrc/dataset/CMakeLists.txt
浏览文件 @
d4822137
...
@@ -12,6 +12,9 @@ endif()
...
@@ -12,6 +12,9 @@ endif()
set
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
-Wno-format"
)
set
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
-Wno-format"
)
set
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
-Wno-attributes"
)
set
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
-Wno-attributes"
)
if
(
${
CMAKE_SYSTEM_NAME
}
MATCHES
"Windows"
)
set
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
-Wl,--image-base -Wl,0x10000000"
)
endif
()
############################# Options ################################
############################# Options ################################
if
(
ENABLE_GPUQUE
)
if
(
ENABLE_GPUQUE
)
add_definitions
(
-D ENABLE_GPUQUE
)
add_definitions
(
-D ENABLE_GPUQUE
)
...
@@ -80,7 +83,7 @@ set_target_properties(_c_dataengine PROPERTIES
...
@@ -80,7 +83,7 @@ set_target_properties(_c_dataengine PROPERTIES
######################################################################
######################################################################
################# Link with external libraries ########################
################# Link with external libraries ########################
if
(
WIN32
)
if
(
${
CMAKE_SYSTEM_NAME
}
MATCHES
"Windows"
)
target_link_libraries
(
_c_dataengine PRIVATE mindspore
)
target_link_libraries
(
_c_dataengine PRIVATE mindspore
)
target_link_libraries
(
_c_dataengine PRIVATE mindspore::pybind11_module
${
PYTHON_LIBRARIES
}
mindspore::protobuf
${
SECUREC_LIBRARY
}
)
target_link_libraries
(
_c_dataengine PRIVATE mindspore::pybind11_module
${
PYTHON_LIBRARIES
}
mindspore::protobuf
${
SECUREC_LIBRARY
}
)
else
()
else
()
...
@@ -101,7 +104,7 @@ if (ENABLE_TDTQUE)
...
@@ -101,7 +104,7 @@ if (ENABLE_TDTQUE)
endif
()
endif
()
add_dependencies
(
_c_dataengine _c_mindrecord
)
add_dependencies
(
_c_dataengine _c_mindrecord
)
if
(
WIN32
)
if
(
${
CMAKE_SYSTEM_NAME
}
MATCHES
"Windows"
)
set
(
MINDRECORD_LINK_OBJECT
${
CMAKE_BINARY_DIR
}
/mindspore/ccsrc/mindrecord/CMakeFiles/_c_mindrecord.dir/objects.a
)
set
(
MINDRECORD_LINK_OBJECT
${
CMAKE_BINARY_DIR
}
/mindspore/ccsrc/mindrecord/CMakeFiles/_c_mindrecord.dir/objects.a
)
target_link_libraries
(
_c_dataengine PRIVATE _c_mindrecord
${
MINDRECORD_LINK_OBJECT
}
mindspore::sqlite
)
target_link_libraries
(
_c_dataengine PRIVATE _c_mindrecord
${
MINDRECORD_LINK_OBJECT
}
mindspore::sqlite
)
else
()
else
()
...
...
mindspore/ccsrc/dataset/engine/datasetops/dataset_op.cc
浏览文件 @
d4822137
...
@@ -109,11 +109,15 @@ void DatasetOp::Print(std::ostream &out, bool show_all) const {
...
@@ -109,11 +109,15 @@ void DatasetOp::Print(std::ostream &out, bool show_all) const {
// Gets the next buffer from the given child
// Gets the next buffer from the given child
Status
DatasetOp
::
GetNextBuffer
(
std
::
unique_ptr
<
DataBuffer
>
*
p_buffer
,
int32_t
worker_id
,
bool
retry_if_eoe
)
{
Status
DatasetOp
::
GetNextBuffer
(
std
::
unique_ptr
<
DataBuffer
>
*
p_buffer
,
int32_t
worker_id
,
bool
retry_if_eoe
)
{
#if defined(_WIN32) || defined(_WIN64)
RETURN_IF_NOT_OK
(
out_connector_
->
PopWithRetry
(
static_cast
<
int
>
(
worker_id
),
p_buffer
,
retry_if_eoe
));
#else
std
::
unique_ptr
<
DataBuffer
>
next_buff
;
std
::
unique_ptr
<
DataBuffer
>
next_buff
;
// pop is a blocked call and will throw an interruption if the whole group shuts down.
// pop is a blocked call and will throw an interruption if the whole group shuts down.
RETURN_IF_NOT_OK
(
out_connector_
->
PopWithRetry
(
static_cast
<
int
>
(
worker_id
),
&
next_buff
,
retry_if_eoe
));
RETURN_IF_NOT_OK
(
out_connector_
->
PopWithRetry
(
static_cast
<
int
>
(
worker_id
),
&
next_buff
,
retry_if_eoe
));
*
p_buffer
=
std
::
move
(
next_buff
);
*
p_buffer
=
std
::
move
(
next_buff
);
#endif
return
Status
::
OK
();
return
Status
::
OK
();
}
}
...
...
mindspore/ccsrc/dataset/engine/datasetops/map_op.cc
浏览文件 @
d4822137
...
@@ -65,6 +65,9 @@ MapOp::MapOp(const std::vector<std::string> &in_col_names, const std::vector<std
...
@@ -65,6 +65,9 @@ MapOp::MapOp(const std::vector<std::string> &in_col_names, const std::vector<std
tfuncs_
(
std
::
move
(
tensor_funcs
)),
tfuncs_
(
std
::
move
(
tensor_funcs
)),
in_columns_
(
in_col_names
),
in_columns_
(
in_col_names
),
out_columns_
(
out_col_names
),
out_columns_
(
out_col_names
),
#if defined(_WIN32) || defined(_WIN64)
eof_worker_id_
(
0
),
#endif
perf_mode_
(
perf_mode
)
{
perf_mode_
(
perf_mode
)
{
// If caller didn't specify the out_col_names, assume they are same as the in_columns.
// If caller didn't specify the out_col_names, assume they are same as the in_columns.
if
(
out_columns_
.
empty
()
||
out_columns_
[
0
].
empty
())
{
if
(
out_columns_
.
empty
()
||
out_columns_
[
0
].
empty
())
{
...
@@ -120,6 +123,17 @@ Status MapOp::operator()() {
...
@@ -120,6 +123,17 @@ Status MapOp::operator()() {
RETURN_IF_NOT_OK
(
child_
[
0
]
->
GetNextBuffer
(
&
buff
,
0
));
RETURN_IF_NOT_OK
(
child_
[
0
]
->
GetNextBuffer
(
&
buff
,
0
));
is_eof
=
buff
->
eof
();
is_eof
=
buff
->
eof
();
RETURN_IF_NOT_OK
(
local_queues_
[
que_id
]
->
Add
(
std
::
move
(
buff
)));
RETURN_IF_NOT_OK
(
local_queues_
[
que_id
]
->
Add
(
std
::
move
(
buff
)));
#if defined(_WIN32) || defined(_WIN64)
if
(
is_eof
)
{
eof_worker_id_
=
que_id
;
for
(
int32_t
id
=
0
;
id
<
num_workers_
;
id
++
)
{
if
(
id
!=
eof_worker_id_
)
{
auto
eof_buffer
=
std
::
make_unique
<
DataBuffer
>
(
0
,
DataBuffer
::
kDeBFlagEOF
);
RETURN_IF_NOT_OK
(
local_queues_
[
id
]
->
Add
(
std
::
move
(
eof_buffer
)));
}
}
}
#endif
que_id
=
(
que_id
+
1
)
%
num_workers_
;
que_id
=
(
que_id
+
1
)
%
num_workers_
;
}
}
}
}
...
@@ -159,6 +173,14 @@ Status MapOp::WorkerEntry(int32_t worker_id) {
...
@@ -159,6 +173,14 @@ Status MapOp::WorkerEntry(int32_t worker_id) {
continue
;
continue
;
}
else
if
(
in_buffer
->
eof
())
{
}
else
if
(
in_buffer
->
eof
())
{
// Calling base class EofReceived to forward eof buffer.
// Calling base class EofReceived to forward eof buffer.
#if defined(_WIN32) || defined(_Win64)
if
(
perf_mode_
)
{
if
(
eof_worker_id_
==
worker_id
)
{
RETURN_IF_NOT_OK
(
EofReceived
(
worker_id
));
}
break
;
}
#endif
RETURN_IF_NOT_OK
(
EofReceived
(
worker_id
));
RETURN_IF_NOT_OK
(
EofReceived
(
worker_id
));
break
;
break
;
}
}
...
...
mindspore/ccsrc/dataset/engine/datasetops/map_op.h
浏览文件 @
d4822137
...
@@ -193,6 +193,10 @@ class MapOp : public ParallelOp {
...
@@ -193,6 +193,10 @@ class MapOp : public ParallelOp {
// cause additional blocking because pop calls to Connector from the threads are synchronized to enforce the order.
// cause additional blocking because pop calls to Connector from the threads are synchronized to enforce the order.
bool
perf_mode_
;
bool
perf_mode_
;
#if defined(_WIN32) || defined(_WIN64)
// EOF worker id is only work on Performance mode, to record the worker id of queue which gets EOF
int32_t
eof_worker_id_
;
#endif
// Private function for worker/thread to loop continuously. It comprises the main
// Private function for worker/thread to loop continuously. It comprises the main
// logic of MapOp: getting the data from previous Op, validating user specified column names,
// logic of MapOp: getting the data from previous Op, validating user specified column names,
// applying a list of TensorOps to each of the data, process the results and then
// applying a list of TensorOps to each of the data, process the results and then
...
...
mindspore/ccsrc/mindrecord/CMakeLists.txt
浏览文件 @
d4822137
...
@@ -26,7 +26,7 @@ set_target_properties(_c_mindrecord PROPERTIES
...
@@ -26,7 +26,7 @@ set_target_properties(_c_mindrecord PROPERTIES
)
)
# add link library
# add link library
if
(
WIN32
)
if
(
${
CMAKE_SYSTEM_NAME
}
MATCHES
"Windows"
)
target_link_libraries
(
_c_mindrecord PRIVATE mindspore::sqlite mindspore mindspore::protobuf
)
target_link_libraries
(
_c_mindrecord PRIVATE mindspore::sqlite mindspore mindspore::protobuf
)
else
()
else
()
target_link_libraries
(
_c_mindrecord PRIVATE mindspore::sqlite
${
PYTHON_LIB
}
${
SECUREC_LIBRARY
}
mindspore mindspore_gvar mindspore::protobuf
)
target_link_libraries
(
_c_mindrecord PRIVATE mindspore::sqlite
${
PYTHON_LIB
}
${
SECUREC_LIBRARY
}
mindspore mindspore_gvar mindspore::protobuf
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录