Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Metz
oceanbase
提交
f7ac50cd
O
oceanbase
项目概览
Metz
/
oceanbase
与 Fork 源项目一致
Fork自
oceanbase / oceanbase
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oceanbase
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
f7ac50cd
编写于
10月 13, 2021
作者:
J
jg0
提交者:
wangzelin.wzl
10月 13, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix memory leak of dynamic creation and release of threads
上级
3dfbfef7
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
23 addition
and
30 deletion
+23
-30
deps/oblib/src/lib/coro/co_routine.cpp
deps/oblib/src/lib/coro/co_routine.cpp
+7
-2
deps/oblib/src/lib/coro/co_routine.h
deps/oblib/src/lib/coro/co_routine.h
+1
-2
deps/oblib/src/lib/coro/co_var_center.cpp
deps/oblib/src/lib/coro/co_var_center.cpp
+9
-23
deps/oblib/src/lib/coro/co_var_center.h
deps/oblib/src/lib/coro/co_var_center.h
+3
-3
deps/oblib/src/lib/coro/thread.cpp
deps/oblib/src/lib/coro/thread.cpp
+3
-0
未找到文件。
deps/oblib/src/lib/coro/co_routine.cpp
浏览文件 @
f7ac50cd
...
...
@@ -144,13 +144,13 @@ void CoRoutine::__start(transfer_t from)
int
CoRoutine
::
at_create
()
{
CVC
.
at_routine_create
();
CVC
.
at_routine_create
(
get_crls_buffer
()
);
return
OB_SUCCESS
;
}
void
CoRoutine
::
at_exit
()
{
CVC
.
at_routine_exit
();
CVC
.
at_routine_exit
(
get_crls_buffer
()
);
return
;
}
...
...
@@ -190,6 +190,11 @@ void CoMainRoutine::start()
free_coidx
(
idx_
);
}
void
CoMainRoutine
::
at_exit
()
{
CoRoutine
::
at_exit
();
}
void
CoMainRoutine
::
destroy
()
{
CoCtx
::
destroy
(
&
cc_
);
...
...
deps/oblib/src/lib/coro/co_routine.h
浏览文件 @
f7ac50cd
...
...
@@ -235,8 +235,7 @@ public:
void
start
();
// Destroy resources.
void
destroy
();
void
at_exit
()
override
{}
void
at_exit
()
override
;
void
usleep
(
uint32_t
usec
)
final
;
void
sleep_until
(
int64_t
abs_time
)
final
;
...
...
deps/oblib/src/lib/coro/co_var_center.cpp
浏览文件 @
f7ac50cd
...
...
@@ -72,35 +72,21 @@ int CoVarCenter::register_hook(CoVarHook* hook)
return
static_cast
<
int
>
(
num
);
}
void
CoVarCenter
::
at_routine_create
()
void
CoVarCenter
::
at_routine_create
(
char
*
buffer
)
{
char
*
buffer
=
nullptr
;
if
(
OB_LIKELY
(
CoSched
::
get_active_routine
()
!=
nullptr
))
{
buffer
=
CoSched
::
get_active_routine
()
->
get_crls_buffer
();
assert
(
buffer
!=
nullptr
);
}
else
{
ob_abort
();
}
int64_t
&
num
=
reinterpret_cast
<
int64_t
&>
(
*
(
&
buffer
[
coro
::
CoConfig
::
MAX_CRLS_SIZE
]
-
8
));
int64_t
&
num
=
reinterpret_cast
<
int64_t
&>
(
*
(
&
buffer
[
coro
::
CoConfig
::
MAX_CRLS_SIZE
]
-
8
));
num
=
0
;
}
void
CoVarCenter
::
at_routine_exit
()
void
CoVarCenter
::
at_routine_exit
(
char
*
buffer
)
{
if
(
CoSched
::
get_active_routine
()
!=
CoSched
::
get_instance
())
{
char
*
buffer
=
nullptr
;
if
(
OB_LIKELY
(
CoSched
::
get_active_routine
()
!=
nullptr
))
{
buffer
=
CoSched
::
get_active_routine
()
->
get_crls_buffer
();
}
const
auto
MAX_CRLS_SIZE
=
coro
::
CoConfig
::
MAX_CRLS_SIZE
;
int64_t
&
num
=
reinterpret_cast
<
int64_t
&>
(
*
(
&
buffer
[
MAX_CRLS_SIZE
]
-
8
));
CoVarHook
**
last
=
reinterpret_cast
<
CoVarHook
**>
(
&
buffer
[
MAX_CRLS_SIZE
]
-
16
);
for
(
int64_t
i
=
num
-
1
;
i
>=
0
;
i
--
)
{
int64_t
&
num
=
reinterpret_cast
<
int64_t
&>
(
*
(
&
buffer
[
MAX_CRLS_SIZE
]
-
8
));
CoVarHook
**
last
=
reinterpret_cast
<
CoVarHook
**>
(
&
buffer
[
MAX_CRLS_SIZE
]
-
16
);
for
(
int64_t
i
=
num
-
1
;
i
>=
0
;
i
--
)
{
last
[
-
i
]
->
deinit_
();
}
num
=
0
;
}
}
}
// namespace lib
...
...
deps/oblib/src/lib/coro/co_var_center.h
浏览文件 @
f7ac50cd
...
...
@@ -72,9 +72,9 @@ public:
return
pos
;
}
int
register_hook
(
CoVarHook
*
hook
);
void
at_routine_create
();
void
at_routine_exit
();
int
register_hook
(
CoVarHook
*
hook
);
void
at_routine_create
(
char
*
buffer
);
void
at_routine_exit
(
char
*
buffer
);
static
CoVarCenter
&
instance
()
{
...
...
deps/oblib/src/lib/coro/thread.cpp
浏览文件 @
f7ac50cd
...
...
@@ -229,6 +229,9 @@ void* Thread::__th_start(void* arg)
}
}
}
if
(
mem_context
!=
nullptr
&&
*
mem_context
!=
nullptr
)
{
DESTROY_CONTEXT
(
*
mem_context
);
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录