Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Musl
提交
8968bf22
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看板
未验证
提交
8968bf22
编写于
8月 24, 2022
作者:
O
openharmony_ci
提交者:
Gitee
8月 24, 2022
浏览文件
操作
浏览文件
下载
差异文件
!470 在fortify功能中增加strncat和strlen函数的运行时检测
Merge pull request !470 from dhy308/branch_rm008_fix_backup
上级
4c45af25
770cef0b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
112 addition
and
3 deletion
+112
-3
libc-test/src/functionalext/fortify/string.c
libc-test/src/functionalext/fortify/string.c
+84
-0
porting/linux/user/include/fortify/string.h
porting/linux/user/include/fortify/string.h
+19
-0
porting/linux/user/src/fortify/fortify.c
porting/linux/user/src/fortify/fortify.c
+9
-3
未找到文件。
libc-test/src/functionalext/fortify/string.c
浏览文件 @
8968bf22
...
...
@@ -91,6 +91,58 @@ static void test_strcat_0020()
return
;
}
/**
* @tc.name : test_strcat_0010
* @tc.desc : After adding fortify, test the normal strcat of the function.
* @tc.level : Level 0
*/
static
void
test_strncat_0010
()
{
char
src
[
SIZE_15
];
strcpy
(
src
,
STRLEN_10
);
char
dst
[
SIZE_20
];
memset
(
dst
,
0
,
SIZE_20
);
strncat
(
dst
,
src
,
strlen
(
src
));
TEST
(
dst
[
0
]
==
EQ_0
);
}
/**
* @tc.name : test_strcat_0020
* @tc.desc : Ability to test the strcat Fortify runtime
* @tc.level : Level 2
*/
static
void
test_strncat_0020
()
{
struct
sigaction
sigabrt
=
{
.
sa_handler
=
SignalHandler
,
};
sigaction
(
SIGABRT
,
&
sigabrt
,
NULL
);
char
src
[
SIZE_15
];
strcpy
(
src
,
STRLEN_10
);
char
dst
[
SIZE_5
];
memset
(
dst
,
0
,
SIZE_5
);
int
status
;
int
pid
=
fork
();
switch
(
pid
)
{
case
-
1
:
t_error
(
"fork failed: %s
\n
"
,
strerror
(
errno
));
break
;
case
0
:
strncat
(
dst
,
src
,
strlen
(
src
));
exit
(
0
);
default:
waitpid
(
pid
,
&
status
,
WUNTRACED
);
TEST
(
WIFEXITED
(
status
)
==
0
);
TEST
(
WIFSTOPPED
(
status
)
==
1
);
TEST
(
WSTOPSIG
(
status
)
==
SIGSTOP
);
kill
(
pid
,
SIGCONT
);
break
;
}
return
;
}
/**
* @tc.name : test_stpcpy_0010
* @tc.desc : After adding fortify, test the normal stpcpy of the function.
...
...
@@ -798,9 +850,40 @@ static void test_memset_0020()
return
;
}
static
void
test_strlen_0010
()
{
struct
sigaction
sigabrt
=
{
.
sa_handler
=
SignalHandler
,
};
sigaction
(
SIGABRT
,
&
sigabrt
,
NULL
);
char
buf
[
SIZE_10
];
memcpy
(
buf
,
STRLEN_10
,
sizeof
(
buf
));
int
status
;
int
pid
=
fork
();
switch
(
pid
)
{
case
-
1
:
t_error
(
"fork failed: %s
\n
"
,
strerror
(
errno
));
break
;
case
0
:
strlen
(
buf
);
exit
(
0
);
default:
waitpid
(
pid
,
&
status
,
WUNTRACED
);
TEST
(
WIFEXITED
(
status
)
==
0
);
TEST
(
WIFSTOPPED
(
status
)
==
1
);
TEST
(
WSTOPSIG
(
status
)
==
SIGSTOP
);
kill
(
pid
,
SIGCONT
);
break
;
}
return
;
}
int
main
(
int
argc
,
char
*
argv
[])
{
test_strcat_0010
();
test_strcat_0020
();
test_strncat_0010
();
test_strncat_0020
();
test_strchr_0010
();
test_strchr_0020
();
test_strncpy_0010
();
...
...
@@ -821,6 +904,7 @@ int main(int argc, char *argv[]) {
test_memset_0020
();
test_memcpy_0010
();
test_memcpy_0020
();
test_strlen_0010
();
#ifdef _GNU_SOURCE
test_mempcpy_0010
();
...
...
porting/linux/user/include/fortify/string.h
浏览文件 @
8968bf22
...
...
@@ -29,6 +29,7 @@ size_t __strlcpy_diagnose(char*, const char*, size_t, size_t);
size_t
__strlcat_diagnose
(
char
*
,
const
char
*
,
size_t
,
size_t
);
char
*
__strchr_diagnose
(
const
char
*
p
,
int
ch
,
size_t
s_len
);
char
*
__strrchr_diagnose
(
const
char
*
p
,
int
ch
,
size_t
s_len
);
size_t
__strlen_chk
(
const
char
*
s
,
size_t
s_len
);
#ifdef __FORTIFY_COMPILATION
__DIAGNOSE_FORTIFY_INLINE
...
...
@@ -94,6 +95,15 @@ __DIAGNOSE_ERROR_IF(__DIAGNOSE_UNEVALUATED_LE(__DIAGNOSE_BOS(dst), __builtin_str
#endif
}
#ifdef __FORTIFY_RUNTIME
__DIAGNOSE_FORTIFY_INLINE
char
*
strncat
(
char
*
const
dst
__DIAGNOSE_PASS_OBJECT_SIZE
,
const
char
*
src
,
size_t
n
)
__DIAGNOSE_OVERLOAD
{
return
__builtin___strncat_chk
(
dst
,
src
,
n
,
__DIAGNOSE_BOS
(
dst
));
}
#endif
#ifdef __FORTIFY_RUNTIME
__DIAGNOSE_FORTIFY_INLINE
char
*
stpncpy
(
char
*
const
dst
__DIAGNOSE_PASS_OBJECT_SIZE
,
...
...
@@ -221,6 +231,15 @@ __DIAGNOSE_OVERLOAD
return
__builtin_strrchr
(
s
,
c
);
}
#ifdef __FORTIFY_RUNTIME
__DIAGNOSE_FORTIFY_INLINE
size_t
strlen
(
const
char
*
const
s
__DIAGNOSE_PASS_OBJECT_SIZE0
)
__DIAGNOSE_OVERLOAD
{
return
__strlen_chk
(
s
,
__DIAGNOSE_BOS0
(
s
));
}
#endif
#endif // __FORTIFY_COMPILATION
#ifdef __cplusplus
}
...
...
porting/linux/user/src/fortify/fortify.c
浏览文件 @
8968bf22
...
...
@@ -167,18 +167,24 @@ static inline void __diagnose_count(const char *fn, const char *identifier, size
size_t
__strlen_chk
(
const
char
*
s
,
size_t
s_len
)
{
size_t
ret
=
strlen
(
s
);
size_t
ret
=
__DIAGNOSE_CALL_BYPASSING_FORTIFY
(
strlen
)
(
s
);
if
(
__DIAGNOSE_PREDICT_FALSE
(
ret
>=
s_len
))
{
__fortify_error
(
"strlen: detected read past end of buffer
\n
"
);
return
0
;
}
return
ret
;
}
char
*
__strncat_chk
(
char
*
dst
,
const
char
*
src
,
size_t
len
,
size_t
dst_buf_size
)
{
size_t
src_len
=
strlen
(
src
)
+
strlen
(
dst
);
__diagnose_buffer_access
(
"strncat"
,
"write into"
,
src_len
,
dst_buf_size
);
return
__DIAGNOSE_CALL_BYPASSING_FORTIFY
(
strncat
)(
dst
,
src
,
len
);
}
char
*
__strcat_chk
(
char
*
dst
,
const
char
*
src
,
size_t
dst_buf_size
)
{
size_t
src_len
=
strlen
(
src
)
+
strlen
(
dst
);
__diagnose_buffer_access
(
"strc
py
"
,
"write into"
,
src_len
,
dst_buf_size
);
__diagnose_buffer_access
(
"strc
at
"
,
"write into"
,
src_len
,
dst_buf_size
);
return
__DIAGNOSE_CALL_BYPASSING_FORTIFY
(
strcat
)(
dst
,
src
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录