Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Musl
提交
16fcaf70
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看板
提交
16fcaf70
编写于
1月 30, 2023
作者:
O
openharmony_ci
提交者:
fangting
5月 05, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
!787 增加dlclose debug开关
Merge pull request !787 from Maplestory_zeng/master
上级
b470d3b0
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
30 addition
and
3 deletion
+30
-3
porting/linux/user/ldso/dynlink.c
porting/linux/user/ldso/dynlink.c
+12
-3
porting/linux/user/ldso/ld_log.c
porting/linux/user/ldso/ld_log.c
+16
-0
porting/linux/user/ldso/ld_log.h
porting/linux/user/ldso/ld_log.h
+2
-0
未找到文件。
porting/linux/user/ldso/dynlink.c
浏览文件 @
16fcaf70
...
@@ -1229,12 +1229,21 @@ static void unmap_library(struct dso *dso)
...
@@ -1229,12 +1229,21 @@ static void unmap_library(struct dso *dso)
for
(
i
=
0
;
i
<
dso
->
loadmap
->
nsegs
;
i
++
)
{
for
(
i
=
0
;
i
<
dso
->
loadmap
->
nsegs
;
i
++
)
{
if
(
!
dso
->
loadmap
->
segs
[
i
].
p_memsz
)
if
(
!
dso
->
loadmap
->
segs
[
i
].
p_memsz
)
continue
;
continue
;
if
(
!
is_dlclose_debug_enable
())
{
munmap
((
void
*
)
dso
->
loadmap
->
segs
[
i
].
addr
,
munmap
((
void
*
)
dso
->
loadmap
->
segs
[
i
].
addr
,
dso
->
loadmap
->
segs
[
i
].
p_memsz
);
dso
->
loadmap
->
segs
[
i
].
p_memsz
);
}
else
{
(
void
)
mprotect
((
void
*
)
dso
->
loadmap
->
segs
[
i
].
addr
,
dso
->
loadmap
->
segs
[
i
].
p_memsz
,
PROT_NONE
);
}
}
}
internal_free
(
dso
->
loadmap
);
internal_free
(
dso
->
loadmap
);
}
else
if
(
dso
->
map
&&
dso
->
map_len
)
{
}
else
if
(
dso
->
map
&&
dso
->
map_len
)
{
if
(
!
is_dlclose_debug_enable
())
{
munmap
(
dso
->
map
,
dso
->
map_len
);
munmap
(
dso
->
map
,
dso
->
map_len
);
}
else
{
mprotect
(
dso
->
map
,
dso
->
map_len
,
PROT_NONE
);
}
}
}
}
}
...
...
porting/linux/user/ldso/ld_log.c
浏览文件 @
16fcaf70
...
@@ -16,6 +16,7 @@
...
@@ -16,6 +16,7 @@
#include "ld_log.h"
#include "ld_log.h"
static
bool
ld_log_enable
=
false
;
static
bool
ld_log_enable
=
false
;
static
bool
ld_dlclose_debug
=
false
;
#ifdef OHOS_ENABLE_PARAMETER
#ifdef OHOS_ENABLE_PARAMETER
#include <fcntl.h>
#include <fcntl.h>
...
@@ -73,11 +74,21 @@ static bool get_ld_log_value()
...
@@ -73,11 +74,21 @@ static bool get_ld_log_value()
}
}
return
(
get_bool_sysparam
(
app_param_handle
)
||
get_bool_sysparam
(
all_param_handle
));
return
(
get_bool_sysparam
(
app_param_handle
)
||
get_bool_sysparam
(
all_param_handle
));
}
}
static
bool
get_ld_debug_dlclose_value
()
{
static
CachedHandle
param_handle
=
NULL
;
if
(
param_handle
==
NULL
)
{
param_handle
=
CachedParameterCreate
(
"musl.ld.debug.dlclose"
,
"false"
);
}
return
get_bool_sysparam
(
param_handle
);
}
#endif
#endif
void
ld_log_reset
()
void
ld_log_reset
()
{
{
#if (defined(OHOS_ENABLE_PARAMETER))
#if (defined(OHOS_ENABLE_PARAMETER))
ld_dlclose_debug
=
get_ld_debug_dlclose_value
();
if
(
!
is_musl_log_enable
())
{
if
(
!
is_musl_log_enable
())
{
ld_log_enable
=
false
;
ld_log_enable
=
false
;
return
;
return
;
...
@@ -92,3 +103,8 @@ bool get_ld_log_enable()
...
@@ -92,3 +103,8 @@ bool get_ld_log_enable()
{
{
return
ld_log_enable
;
return
ld_log_enable
;
}
}
bool
is_dlclose_debug_enable
()
{
return
ld_dlclose_debug
;
}
porting/linux/user/ldso/ld_log.h
浏览文件 @
16fcaf70
...
@@ -34,6 +34,8 @@ extern "C" {
...
@@ -34,6 +34,8 @@ extern "C" {
hidden
bool
get_ld_log_enable
();
hidden
bool
get_ld_log_enable
();
hidden
void
ld_log_reset
();
hidden
void
ld_log_reset
();
hidden
bool
is_dlclose_debug_enable
();
#if ((LD_LOG_LEVEL & LD_LOG_ERROR) && (defined(OHOS_ENABLE_PARAMETER) || defined(ENABLE_MUSL_LOG)))
#if ((LD_LOG_LEVEL & LD_LOG_ERROR) && (defined(OHOS_ENABLE_PARAMETER) || defined(ENABLE_MUSL_LOG)))
#define LD_LOGE(...) if (get_ld_log_enable()) { \
#define LD_LOGE(...) if (get_ld_log_enable()) { \
(void)HiLogAdapterPrint(MUSL_LOG_TYPE, LOG_ERROR, MUSL_LOG_DOMAIN, LD_LOG_TAG, __VA_ARGS__); \
(void)HiLogAdapterPrint(MUSL_LOG_TYPE, LOG_ERROR, MUSL_LOG_DOMAIN, LD_LOG_TAG, __VA_ARGS__); \
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录