Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Musl
提交
05eff01e
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
05eff01e
编写于
8月 05, 2012
作者:
R
Rich Felker
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
dynamic linker internals cleanup
上级
5a3a3786
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
7 addition
and
5 deletion
+7
-5
src/ldso/dynlink.c
src/ldso/dynlink.c
+7
-5
未找到文件。
src/ldso/dynlink.c
浏览文件 @
05eff01e
...
...
@@ -105,9 +105,12 @@ static uint32_t hash(const char *s0)
return
h
&
0xfffffff
;
}
static
Sym
*
lookup
(
const
char
*
s
,
uint32_t
h
,
Sym
*
syms
,
uint32_t
*
hashtab
,
char
*
strings
)
static
Sym
*
lookup
(
const
char
*
s
,
uint32_t
h
,
struct
dso
*
dso
)
{
size_t
i
;
Sym
*
syms
=
dso
->
syms
;
uint32_t
*
hashtab
=
dso
->
hashtab
;
char
*
strings
=
dso
->
strings
;
for
(
i
=
hashtab
[
2
+
h
%
hashtab
[
0
]];
i
;
i
=
hashtab
[
2
+
hashtab
[
0
]
+
i
])
{
if
(
!
strcmp
(
s
,
strings
+
syms
[
i
].
st_name
))
return
syms
+
i
;
...
...
@@ -128,7 +131,7 @@ static void *find_sym(struct dso *dso, const char *s, int need_def)
for
(;
dso
;
dso
=
dso
->
next
)
{
Sym
*
sym
;
if
(
!
dso
->
global
)
continue
;
sym
=
lookup
(
s
,
h
,
dso
->
syms
,
dso
->
hashtab
,
dso
->
strings
);
sym
=
lookup
(
s
,
h
,
dso
);
if
(
sym
&&
(
!
need_def
||
sym
->
st_shndx
)
&&
sym
->
st_value
&&
(
1
<<
(
sym
->
st_info
&
0xf
)
&
OK_TYPES
)
&&
(
1
<<
(
sym
->
st_info
>>
4
)
&
OK_BINDS
))
{
...
...
@@ -788,12 +791,11 @@ static void *do_dlsym(struct dso *p, const char *s, void *ra)
return
res
;
}
h
=
hash
(
s
);
sym
=
lookup
(
s
,
h
,
p
->
syms
,
p
->
hashtab
,
p
->
strings
);
sym
=
lookup
(
s
,
h
,
p
);
if
(
sym
&&
sym
->
st_value
&&
(
1
<<
(
sym
->
st_info
&
0xf
)
&
OK_TYPES
))
return
p
->
base
+
sym
->
st_value
;
if
(
p
->
deps
)
for
(
i
=
0
;
p
->
deps
[
i
];
i
++
)
{
sym
=
lookup
(
s
,
h
,
p
->
deps
[
i
]
->
syms
,
p
->
deps
[
i
]
->
hashtab
,
p
->
deps
[
i
]
->
strings
);
sym
=
lookup
(
s
,
h
,
p
);
if
(
sym
&&
sym
->
st_value
&&
(
1
<<
(
sym
->
st_info
&
0xf
)
&
OK_TYPES
))
return
p
->
deps
[
i
]
->
base
+
sym
->
st_value
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录