Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Musl
提交
b480808a
T
Third Party Musl
项目概览
OpenHarmony
/
Third Party Musl
接近 2 年 前同步成功
通知
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看板
提交
b480808a
编写于
3月 03, 2011
作者:
R
Rich Felker
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
optimize POSIX TSD for fast pthread_getspecific
上级
a53d2f34
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
14 addition
and
9 deletion
+14
-9
src/thread/pthread_getspecific.c
src/thread/pthread_getspecific.c
+1
-2
src/thread/pthread_key_create.c
src/thread/pthread_key_create.c
+1
-0
src/thread/pthread_self.c
src/thread/pthread_self.c
+11
-0
src/thread/pthread_setspecific.c
src/thread/pthread_setspecific.c
+1
-7
未找到文件。
src/thread/pthread_getspecific.c
浏览文件 @
b480808a
...
@@ -2,7 +2,6 @@
...
@@ -2,7 +2,6 @@
void
*
pthread_getspecific
(
pthread_key_t
k
)
void
*
pthread_getspecific
(
pthread_key_t
k
)
{
{
struct
pthread
*
self
=
pthread_self
();
struct
pthread
*
self
=
__pthread_self
();
if
(
!
self
->
tsd
)
return
0
;
return
self
->
tsd
[
k
];
return
self
->
tsd
[
k
];
}
}
src/thread/pthread_key_create.c
浏览文件 @
b480808a
...
@@ -12,6 +12,7 @@ int pthread_key_create(pthread_key_t *k, void (*dtor)(void *))
...
@@ -12,6 +12,7 @@ int pthread_key_create(pthread_key_t *k, void (*dtor)(void *))
int
i
=
(
uintptr_t
)
&
k
/
16
%
PTHREAD_KEYS_MAX
;
int
i
=
(
uintptr_t
)
&
k
/
16
%
PTHREAD_KEYS_MAX
;
int
j
=
i
;
int
j
=
i
;
pthread_self
();
libc
.
tsd_keys
=
keys
;
libc
.
tsd_keys
=
keys
;
if
(
!
dtor
)
dtor
=
nodtor
;
if
(
!
dtor
)
dtor
=
nodtor
;
/* Cheap trick - &k cannot match any destructor pointer */
/* Cheap trick - &k cannot match any destructor pointer */
...
...
src/thread/pthread_self.c
浏览文件 @
b480808a
...
@@ -2,6 +2,10 @@
...
@@ -2,6 +2,10 @@
static
struct
pthread
main_thread
;
static
struct
pthread
main_thread
;
/* pthread_key_create.c overrides this */
static
const
size_t
dummy
=
0
;
weak_alias
(
dummy
,
__pthread_tsd_size
);
#undef errno
#undef errno
static
int
*
errno_location
()
static
int
*
errno_location
()
{
{
...
@@ -10,6 +14,13 @@ static int *errno_location()
...
@@ -10,6 +14,13 @@ static int *errno_location()
static
int
init_main_thread
()
static
int
init_main_thread
()
{
{
void
*
tsd
=
0
;
if
(
__pthread_tsd_size
)
{
tsd
=
mmap
(
0
,
__pthread_tsd_size
,
PROT_READ
|
PROT_WRITE
,
MAP_PRIVATE
|
MAP_ANONYMOUS
,
-
1
,
0
);
if
(
tsd
==
MAP_FAILED
)
return
-
1
;
}
main_thread
.
tsd
=
tsd
;
main_thread
.
self
=
&
main_thread
;
main_thread
.
self
=
&
main_thread
;
if
(
__set_thread_area
(
&
main_thread
)
<
0
)
if
(
__set_thread_area
(
&
main_thread
)
<
0
)
return
-
1
;
return
-
1
;
...
...
src/thread/pthread_setspecific.c
浏览文件 @
b480808a
...
@@ -2,13 +2,7 @@
...
@@ -2,13 +2,7 @@
int
pthread_setspecific
(
pthread_key_t
k
,
const
void
*
x
)
int
pthread_setspecific
(
pthread_key_t
k
,
const
void
*
x
)
{
{
struct
pthread
*
self
=
pthread_self
();
struct
pthread
*
self
=
__pthread_self
();
/* Handle the case of the main thread */
if
(
!
self
->
tsd
)
{
if
(
!
x
)
return
0
;
if
(
!
(
self
->
tsd
=
calloc
(
sizeof
(
void
*
),
PTHREAD_KEYS_MAX
)))
return
ENOMEM
;
}
/* Avoid unnecessary COW */
/* Avoid unnecessary COW */
if
(
self
->
tsd
[
k
]
!=
x
)
{
if
(
self
->
tsd
[
k
]
!=
x
)
{
self
->
tsd
[
k
]
=
(
void
*
)
x
;
self
->
tsd
[
k
]
=
(
void
*
)
x
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录