Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Musl
提交
3d981461
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看板
提交
3d981461
编写于
5月 07, 2016
作者:
B
Bobby Bingham
提交者:
Rich Felker
6月 30, 2016
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
pthread: implement try/timed join variants
上级
6d38c9cf
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
19 addition
and
3 deletion
+19
-3
include/pthread.h
include/pthread.h
+2
-0
src/thread/pthread_join.c
src/thread/pthread_join.c
+17
-3
未找到文件。
include/pthread.h
浏览文件 @
3d981461
...
@@ -214,6 +214,8 @@ struct cpu_set_t;
...
@@ -214,6 +214,8 @@ struct cpu_set_t;
int
pthread_getaffinity_np
(
pthread_t
,
size_t
,
struct
cpu_set_t
*
);
int
pthread_getaffinity_np
(
pthread_t
,
size_t
,
struct
cpu_set_t
*
);
int
pthread_setaffinity_np
(
pthread_t
,
size_t
,
const
struct
cpu_set_t
*
);
int
pthread_setaffinity_np
(
pthread_t
,
size_t
,
const
struct
cpu_set_t
*
);
int
pthread_getattr_np
(
pthread_t
,
pthread_attr_t
*
);
int
pthread_getattr_np
(
pthread_t
,
pthread_attr_t
*
);
int
pthread_tryjoin_np
(
pthread_t
,
void
**
);
int
pthread_timedjoin_np
(
pthread_t
,
void
**
,
const
struct
timespec
*
);
#endif
#endif
#ifdef __cplusplus
#ifdef __cplusplus
...
...
src/thread/pthread_join.c
浏览文件 @
3d981461
...
@@ -5,18 +5,32 @@ int __munmap(void *, size_t);
...
@@ -5,18 +5,32 @@ int __munmap(void *, size_t);
void
__pthread_testcancel
(
void
);
void
__pthread_testcancel
(
void
);
int
__pthread_setcancelstate
(
int
,
int
*
);
int
__pthread_setcancelstate
(
int
,
int
*
);
int
__pthread_
join
(
pthread_t
t
,
void
**
res
)
int
__pthread_
timedjoin_np
(
pthread_t
t
,
void
**
res
,
const
struct
timespec
*
at
)
{
{
int
tmp
,
cs
;
int
tmp
,
cs
,
r
=
0
;
__pthread_testcancel
();
__pthread_testcancel
();
__pthread_setcancelstate
(
PTHREAD_CANCEL_DISABLE
,
&
cs
);
__pthread_setcancelstate
(
PTHREAD_CANCEL_DISABLE
,
&
cs
);
if
(
cs
==
PTHREAD_CANCEL_ENABLE
)
__pthread_setcancelstate
(
cs
,
0
);
if
(
cs
==
PTHREAD_CANCEL_ENABLE
)
__pthread_setcancelstate
(
cs
,
0
);
while
((
tmp
=
t
->
tid
))
__timedwait_cp
(
&
t
->
tid
,
tmp
,
0
,
0
,
0
);
while
((
tmp
=
t
->
tid
)
&&
r
!=
ETIMEDOUT
&&
r
!=
EINVAL
)
r
=
__timedwait_cp
(
&
t
->
tid
,
tmp
,
CLOCK_REALTIME
,
at
,
0
);
__pthread_setcancelstate
(
cs
,
0
);
__pthread_setcancelstate
(
cs
,
0
);
if
(
r
==
ETIMEDOUT
||
r
==
EINVAL
)
return
r
;
a_barrier
();
a_barrier
();
if
(
res
)
*
res
=
t
->
result
;
if
(
res
)
*
res
=
t
->
result
;
if
(
t
->
map_base
)
__munmap
(
t
->
map_base
,
t
->
map_size
);
if
(
t
->
map_base
)
__munmap
(
t
->
map_base
,
t
->
map_size
);
return
0
;
return
0
;
}
}
int
__pthread_join
(
pthread_t
t
,
void
**
res
)
{
return
__pthread_timedjoin_np
(
t
,
res
,
0
);
}
int
__pthread_tryjoin_np
(
pthread_t
t
,
void
**
res
)
{
return
t
->
tid
?
EBUSY
:
__pthread_join
(
t
,
res
);
}
weak_alias
(
__pthread_tryjoin_np
,
pthread_tryjoin_np
);
weak_alias
(
__pthread_timedjoin_np
,
pthread_timedjoin_np
);
weak_alias
(
__pthread_join
,
pthread_join
);
weak_alias
(
__pthread_join
,
pthread_join
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录