Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Musl
提交
fd80cfa0
T
Third Party Musl
项目概览
OpenHarmony
/
Third Party Musl
1 年多 前同步成功
通知
37
Star
125
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Musl
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
fd80cfa0
编写于
4月 03, 2011
作者:
R
Rich Felker
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
omit pthread tsd dtor code if tsd is not used
上级
8de03e1a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
24 addition
and
14 deletion
+24
-14
src/thread/pthread_create.c
src/thread/pthread_create.c
+6
-13
src/thread/pthread_key_create.c
src/thread/pthread_key_create.c
+18
-1
未找到文件。
src/thread/pthread_create.c
浏览文件 @
fd80cfa0
#include "pthread_impl.h"
static
void
dummy_1
(
pthread_t
self
)
{
}
weak_alias
(
dummy_1
,
__pthread_tsd_run_dtors
);
#ifdef __pthread_unwind_next
#undef __pthread_unwind_next
#define __pthread_unwind_next __pthread_unwind_next_3
...
...
@@ -7,7 +12,6 @@
void
__pthread_unwind_next
(
struct
__ptcb
*
cb
)
{
int
i
,
j
,
not_finished
;
pthread_t
self
;
if
(
cb
->
__next
)
longjmp
((
void
*
)
cb
->
__next
->
__jb
,
1
);
...
...
@@ -16,18 +20,7 @@ void __pthread_unwind_next(struct __ptcb *cb)
LOCK
(
&
self
->
exitlock
);
not_finished
=
self
->
tsd_used
;
for
(
j
=
0
;
not_finished
&&
j
<
PTHREAD_DESTRUCTOR_ITERATIONS
;
j
++
)
{
not_finished
=
0
;
for
(
i
=
0
;
i
<
PTHREAD_KEYS_MAX
;
i
++
)
{
if
(
self
->
tsd
[
i
]
&&
libc
.
tsd_keys
[
i
])
{
void
*
tmp
=
self
->
tsd
[
i
];
self
->
tsd
[
i
]
=
0
;
libc
.
tsd_keys
[
i
](
tmp
);
not_finished
=
1
;
}
}
}
__pthread_tsd_run_dtors
(
self
);
/* Mark this thread dead before decrementing count */
self
->
dead
=
1
;
...
...
src/thread/pthread_key_create.c
浏览文件 @
fd80cfa0
...
...
@@ -3,13 +3,14 @@
const
size_t
__pthread_tsd_size
=
sizeof
(
void
*
)
*
PTHREAD_KEYS_MAX
;
void
*
__pthread_tsd_main
[
PTHREAD_KEYS_MAX
]
=
{
0
};
static
void
(
*
keys
[
PTHREAD_KEYS_MAX
])(
void
*
);
static
void
nodtor
(
void
*
dummy
)
{
}
int
pthread_key_create
(
pthread_key_t
*
k
,
void
(
*
dtor
)(
void
*
))
{
static
void
(
*
keys
[
PTHREAD_KEYS_MAX
])(
void
*
);
unsigned
i
=
(
uintptr_t
)
&
k
/
16
%
PTHREAD_KEYS_MAX
;
unsigned
j
=
i
;
...
...
@@ -24,3 +25,19 @@ int pthread_key_create(pthread_key_t *k, void (*dtor)(void *))
}
while
((
j
=
(
j
+
1
)
%
PTHREAD_KEYS_MAX
)
!=
i
);
return
EAGAIN
;
}
void
__pthread_tsd_run_dtors
(
pthread_t
self
)
{
int
i
,
j
,
not_finished
=
self
->
tsd_used
;
for
(
j
=
0
;
not_finished
&&
j
<
PTHREAD_DESTRUCTOR_ITERATIONS
;
j
++
)
{
not_finished
=
0
;
for
(
i
=
0
;
i
<
PTHREAD_KEYS_MAX
;
i
++
)
{
if
(
self
->
tsd
[
i
]
&&
keys
[
i
])
{
void
*
tmp
=
self
->
tsd
[
i
];
self
->
tsd
[
i
]
=
0
;
keys
[
i
](
tmp
);
not_finished
=
1
;
}
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录