Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Kernel Liteos A
提交
cdcf6005
K
Kernel Liteos A
项目概览
OpenHarmony
/
Kernel Liteos A
1 年多 前同步成功
通知
464
Star
414
Fork
55
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
4
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel Liteos A
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
4
Issue
4
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
cdcf6005
编写于
3月 10, 2022
作者:
O
openharmony_ci
提交者:
Gitee
3月 10, 2022
浏览文件
操作
浏览文件
下载
差异文件
!819 fix: codex及合规修复
Merge pull request !819 from Zhaotianyu/cherry-pick-1646726776
上级
31403e0e
1bb40f98
变更
10
显示空白变更内容
内联
并排
Showing
10 changed file
with
52 addition
and
264 deletion
+52
-264
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_026.c
...uites/kernel/sample/posix/mutex/full/It_posix_mutex_026.c
+2
-29
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_038.c
...uites/kernel/sample/posix/mutex/full/It_posix_mutex_038.c
+0
-53
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_042.c
...uites/kernel/sample/posix/mutex/full/It_posix_mutex_042.c
+0
-23
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_043.c
...uites/kernel/sample/posix/mutex/full/It_posix_mutex_043.c
+0
-25
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_045.c
...uites/kernel/sample/posix/mutex/full/It_posix_mutex_045.c
+0
-27
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_046.c
...uites/kernel/sample/posix/mutex/full/It_posix_mutex_046.c
+0
-30
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_049.c
...uites/kernel/sample/posix/mutex/full/It_posix_mutex_049.c
+0
-25
testsuites/kernel/sample/posix/mutex/smoke/It_posix_mutex_019.c
...ites/kernel/sample/posix/mutex/smoke/It_posix_mutex_019.c
+0
-32
tools/scripts/parse_exc/parse_excinfo.py
tools/scripts/parse_exc/parse_excinfo.py
+24
-10
tools/scripts/parse_memory/parse_mem_info.sh
tools/scripts/parse_memory/parse_mem_info.sh
+26
-10
未找到文件。
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_026.c
浏览文件 @
cdcf6005
...
@@ -54,28 +54,6 @@ struct _scenar_028 {
...
@@ -54,28 +54,6 @@ struct _scenar_028 {
#define NSCENAR (sizeof(g_scenarii028) / sizeof(g_scenarii028[0]))
#define NSCENAR (sizeof(g_scenarii028) / sizeof(g_scenarii028[0]))
/* pthread_mutex_destroy 2-2.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
* This sample test aims to check the following assertion:
*
* pthread_mutex_init() can be used to re-initialize a destroyed mutex.
* The steps are:
* -> Initialize a mutex with a given attribute.
* -> Destroy the mutex
* -> Initialize again the mutex with another attribute.
*/
static
UINT32
Testcase
(
VOID
)
static
UINT32
Testcase
(
VOID
)
{
{
int
ret
;
int
ret
;
...
@@ -85,25 +63,20 @@ static UINT32 Testcase(VOID)
...
@@ -85,25 +63,20 @@ static UINT32 Testcase(VOID)
pthread_mutexattr_t
*
pma
[
NSCENAR
+
2
];
pthread_mutexattr_t
*
pma
[
NSCENAR
+
2
];
long
pshared
;
long
pshared
;
/* System abilities */
pshared
=
sysconf
(
_SC_THREAD_PROCESS_SHARED
);
pshared
=
sysconf
(
_SC_THREAD_PROCESS_SHARED
);
/* Initialize the mutex attributes objects */
for
(
i
=
0
;
i
<
NSCENAR
;
i
++
)
{
for
(
i
=
0
;
i
<
NSCENAR
;
i
++
)
{
ret
=
pthread_mutexattr_init
(
&
ma
[
i
]);
ret
=
pthread_mutexattr_init
(
&
ma
[
i
]);
ICUNIT_ASSERT_EQUAL
(
ret
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
ret
,
0
,
ret
);
}
}
/* Default mutexattr object */
ret
=
pthread_mutexattr_init
(
&
ma
[
i
]);
ret
=
pthread_mutexattr_init
(
&
ma
[
i
]);
ICUNIT_ASSERT_EQUAL
(
ret
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
ret
,
0
,
ret
);
/* Initialize the pointer array */
for
(
i
=
0
;
i
<
NSCENAR
+
2
;
i
++
)
// 2, The loop frequency.
/* 2, The loop frequency. */
for
(
i
=
0
;
i
<
NSCENAR
+
2
;
i
++
)
/* NULL pointer */
/* NULL pointer */
pma
[
i
]
=
NULL
;
pma
[
i
]
=
NULL
;
/* Ok, we can now proceed to the test */
for
(
i
=
0
;
i
<
NSCENAR
+
2
;
i
++
)
{
// 2, The loop frequency.
for
(
i
=
0
;
i
<
NSCENAR
+
2
;
i
++
)
{
// 2, The loop frequency.
for
(
j
=
0
;
j
<
NSCENAR
+
2
;
j
++
)
{
// 2, The loop frequency.
for
(
j
=
0
;
j
<
NSCENAR
+
2
;
j
++
)
{
// 2, The loop frequency.
ret
=
pthread_mutex_init
(
&
mtx
,
pma
[
i
]);
ret
=
pthread_mutex_init
(
&
mtx
,
pma
[
i
]);
...
...
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_038.c
浏览文件 @
cdcf6005
...
@@ -40,51 +40,15 @@ extern "C" {
...
@@ -40,51 +40,15 @@ extern "C" {
static
pthread_mutex_t
g_mutex038
;
static
pthread_mutex_t
g_mutex038
;
static
sem_t
g_sem038
;
static
sem_t
g_sem038
;
/* pthread_mutex_lock 4-1.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
* This sample test aims to check the following assertion:
*
* If the mutex type is PTHREAD_MUTEX_RECURSIVE,
* then the mutex maintains the concept of a lock count.
* When a thread successfully acquires a mutex for the first time,
* the lock count is set to one. Every time a thread relocks this mutex,
* the lock count is incremented by one.
* Each time the thread unlocks the mutex,
* the lock count is decremented by one.
* When the lock count reaches zero,
* the mutex becomes available and others threads can acquire it.
* The steps are:
* ->Create a mutex with recursive attribute
* ->Create a threads
* ->Parent locks the mutex twice, unlocks once.
* ->Child attempts to lock the mutex.
* ->Parent unlocks the mutex.
* ->Parent unlocks the mutex (shall fail)
* ->Child unlocks the mutex.
*/
static
void
*
TaskF01
(
void
*
arg
)
static
void
*
TaskF01
(
void
*
arg
)
{
{
int
ret
;
int
ret
;
/* Try to lock the mutex once. The call must fail here. */
ret
=
pthread_mutex_trylock
(
&
g_mutex038
);
ret
=
pthread_mutex_trylock
(
&
g_mutex038
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
}
}
/* Free the parent thread and lock the mutex (must success) */
if
((
ret
=
sem_post
(
&
g_sem038
)))
{
if
((
ret
=
sem_post
(
&
g_sem038
)))
{
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
}
}
...
@@ -93,12 +57,10 @@ static void *TaskF01(void *arg)
...
@@ -93,12 +57,10 @@ static void *TaskF01(void *arg)
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
}
}
/* Wait for the parent to let us go on */
if
((
ret
=
sem_post
(
&
g_sem038
)))
{
if
((
ret
=
sem_post
(
&
g_sem038
)))
{
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
}
}
/* Unlock and exit */
if
((
ret
=
pthread_mutex_unlock
(
&
g_mutex038
)))
{
if
((
ret
=
pthread_mutex_unlock
(
&
g_mutex038
)))
{
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
ICUNIT_GOTO_EQUAL
(
1
,
0
,
ret
,
EXIT
);
}
}
...
@@ -113,12 +75,10 @@ static UINT32 Testcase(VOID)
...
@@ -113,12 +75,10 @@ static UINT32 Testcase(VOID)
pthread_mutexattr_t
ma
;
pthread_mutexattr_t
ma
;
pthread_t
child
;
pthread_t
child
;
/* Initialize the semaphore */
if
((
ret
=
sem_init
(
&
g_sem038
,
0
,
0
)))
{
if
((
ret
=
sem_init
(
&
g_sem038
,
0
,
0
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* We initialize the recursive mutex */
if
((
ret
=
pthread_mutexattr_init
(
&
ma
)))
{
if
((
ret
=
pthread_mutexattr_init
(
&
ma
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
...
@@ -135,9 +95,6 @@ static UINT32 Testcase(VOID)
...
@@ -135,9 +95,6 @@ static UINT32 Testcase(VOID)
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* -- The mutex is now ready for testing -- */
/* First, we lock it twice and unlock once */
if
((
ret
=
pthread_mutex_lock
(
&
g_mutex038
)))
{
if
((
ret
=
pthread_mutex_lock
(
&
g_mutex038
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
...
@@ -150,40 +107,31 @@ static UINT32 Testcase(VOID)
...
@@ -150,40 +107,31 @@ static UINT32 Testcase(VOID)
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* Here this thread owns the mutex and the internal count is "1" */
/* We create the child thread */
if
((
ret
=
pthread_create
(
&
child
,
NULL
,
TaskF01
,
NULL
)))
{
if
((
ret
=
pthread_create
(
&
child
,
NULL
,
TaskF01
,
NULL
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* then wait for child to be ready */
if
((
ret
=
sem_wait
(
&
g_sem038
)))
{
if
((
ret
=
sem_wait
(
&
g_sem038
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* We can now unlock the mutex */
if
((
ret
=
pthread_mutex_unlock
(
&
g_mutex038
)))
{
if
((
ret
=
pthread_mutex_unlock
(
&
g_mutex038
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* We wait for the child to lock the mutex */
if
((
ret
=
sem_wait
(
&
g_sem038
)))
{
if
((
ret
=
sem_wait
(
&
g_sem038
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* Then, try to unlock the mutex (owned by the child or unlocked) */
ret
=
pthread_mutex_unlock
(
&
g_mutex038
);
ret
=
pthread_mutex_unlock
(
&
g_mutex038
);
if
(
ret
==
ENOERR
)
{
if
(
ret
==
ENOERR
)
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* Everything seems OK here */
if
((
ret
=
pthread_join
(
child
,
NULL
)))
{
if
((
ret
=
pthread_join
(
child
,
NULL
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* Simple loop to double-check */
for
(
i
=
0
;
i
<
50
;
i
++
)
{
// 50, The loop frequency.
for
(
i
=
0
;
i
<
50
;
i
++
)
{
// 50, The loop frequency.
if
((
ret
=
pthread_mutex_lock
(
&
g_mutex038
)))
{
if
((
ret
=
pthread_mutex_lock
(
&
g_mutex038
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
...
@@ -199,7 +147,6 @@ static UINT32 Testcase(VOID)
...
@@ -199,7 +147,6 @@ static UINT32 Testcase(VOID)
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
/* The test passed, we destroy the mutex */
if
((
ret
=
pthread_mutex_destroy
(
&
g_mutex038
)))
{
if
((
ret
=
pthread_mutex_destroy
(
&
g_mutex038
)))
{
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
ICUNIT_ASSERT_EQUAL
(
1
,
0
,
ret
);
}
}
...
...
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_042.c
浏览文件 @
cdcf6005
...
@@ -39,29 +39,6 @@ extern "C" {
...
@@ -39,29 +39,6 @@ extern "C" {
static
pthread_mutex_t
g_mutex042
;
static
pthread_mutex_t
g_mutex042
;
/* pthread_mutex_unlock 5-1.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This sample test aims to check the following assertion:
* If the mutex type is PTHREAD_MUTEX_RECURSIVE,
* and a thread attempts to unlock a mutex that it does not own,
* an uwErr is returned.
* The steps are:
* -> Initialize and lock a recursive mutex
* -> create a child thread which tries to unlock this mutex. *
*/
static
void
*
TaskF01
(
void
*
arg
)
static
void
*
TaskF01
(
void
*
arg
)
{
{
int
ret
;
int
ret
;
...
...
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_043.c
浏览文件 @
cdcf6005
...
@@ -36,31 +36,6 @@ extern "C" {
...
@@ -36,31 +36,6 @@ extern "C" {
#endif
/* __cpluscplus */
#endif
/* __cpluscplus */
#endif
/* __cpluscplus */
#endif
/* __cpluscplus */
/* pthread_mutex_unlock 5-2.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This sample test aims to check the following assertion:
* If the mutex type is PTHREAD_MUTEX_RECURSIVE,
* and a thread attempts to unlock an unlocked mutex,
* an uwErr is returned.
* The steps are:
* -> Initialize a recursive mutex
* -> Attempt to unlock the mutex when it is unlocked
* and when it has been locked then unlocked.
*/
static
UINT32
Testcase
(
VOID
)
static
UINT32
Testcase
(
VOID
)
{
{
int
ret
;
int
ret
;
...
...
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_045.c
浏览文件 @
cdcf6005
...
@@ -39,33 +39,6 @@ extern "C" {
...
@@ -39,33 +39,6 @@ extern "C" {
static
pthread_mutex_t
g_mutex045
;
static
pthread_mutex_t
g_mutex045
;
/* pthread_mutex_trylock 1-2.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
* This sample test aims to check the following assertion:
*
* The pthread_mutex_trylock() function locks the mutex object
* when it is unlocked.
* The steps are:
*
* -> For each kind of mutex,
* -> trylock the mutex. It shall suceed.
* -> trylock the mutex again. It shall fail (except in case of recursive mutex).
* -> create a new child (either thread or process)
* -> the new child trylock the mutex. It shall fail.
* -> undo everything.
*/
static
VOID
*
TaskF01
(
void
*
argument
)
static
VOID
*
TaskF01
(
void
*
argument
)
{
{
int
ret
;
int
ret
;
...
...
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_046.c
浏览文件 @
cdcf6005
...
@@ -39,36 +39,6 @@ extern "C" {
...
@@ -39,36 +39,6 @@ extern "C" {
static
pthread_mutex_t
g_mutex046
;
static
pthread_mutex_t
g_mutex046
;
static
UINT32
g_nID
;
static
UINT32
g_nID
;
/* pthread_mutex_trylock 2-1.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
* This sample test aims to check the following assertion:
*
* If the mutex is of type PTHREAD_MUTEX_RECURSIVE,
* and the calling thread already owns the mutex,
* the call is successful (the lock count is incremented).
* The steps are:
*
* -> trylock the mutex. It shall suceed.
* -> trylock the mutex again. It shall suceed again
* -> unlock once
* -> create a new child (either thread or process)
* -> the new child trylock the mutex. It shall fail.
* -> Unlock. It shall succeed.
* -> Unlock again. It shall fail.
* -> undo everything.
*/
static
void
*
TaskF01
(
void
*
arg
)
static
void
*
TaskF01
(
void
*
arg
)
{
{
int
ret
;
int
ret
;
...
...
testsuites/kernel/sample/posix/mutex/full/It_posix_mutex_049.c
浏览文件 @
cdcf6005
...
@@ -39,31 +39,6 @@ extern "C" {
...
@@ -39,31 +39,6 @@ extern "C" {
static
pthread_mutex_t
g_mutex049
;
static
pthread_mutex_t
g_mutex049
;
/* pthread_mutex_trylock 4-2.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
* This sample test aims to check the following assertion:
*
* If the mutex was already locked, the call returns EBUSY immediatly.
* The steps are:
* -> Set a timeout.
* -> For each kind of mutex,
* -> Lock the mutex.
* -> create a new child (either thread or process)
* -> the new child trylock the mutex. It shall fail.
* -> undo everything.
*/
static
VOID
*
TaskF01
(
void
*
argument
)
static
VOID
*
TaskF01
(
void
*
argument
)
{
{
int
ret
;
int
ret
;
...
...
testsuites/kernel/sample/posix/mutex/smoke/It_posix_mutex_019.c
浏览文件 @
cdcf6005
...
@@ -41,38 +41,6 @@ static pthread_mutex_t *g_mtx;
...
@@ -41,38 +41,6 @@ static pthread_mutex_t *g_mtx;
static
sem_t
g_semA
,
g_semB
;
static
sem_t
g_semA
,
g_semB
;
static
pthread_mutex_t
g_mtxNull
,
g_mtxDef
;
static
pthread_mutex_t
g_mtxNull
,
g_mtxDef
;
/* pthread_mutex_init 1-2.c
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
* This sample test aims to check the following assertion:
*
* If the mutex attribute pointer passed to pthread_mutex_init is NULL,
* the effects on the mutex are the same as if a default mutex attribute object had been passed.
*
* The steps are:
* * create two mutexes. One is initialized with NULL attribute, the other with a default attribute object.
* * Compare the following features between the two mutexes:
* -> Can it cause / detect a deadlock? (attempt to lock a mutex the thread already owns).
* If detected, do both mutexes cause the same uwErr code?
* -> Is an uwErr returned when unlocking the mutex in unlocked state?
* When unlocking the mutex owned by another thread?
*
* The test will pass if the results of each feature are the same for the two mutexes
* (making no assumption on what is the default behavior).
* The test will be unresolved if any initialization fails.
* The test will fail if a feature differs between the two mutex objects.
*/
static
void
*
TaskF01
(
void
*
arg
)
static
void
*
TaskF01
(
void
*
arg
)
{
{
int
ret
;
int
ret
;
...
...
tools/scripts/parse_exc/parse_excinfo.py
浏览文件 @
cdcf6005
#!/usr/bin/env python2
#!/usr/bin/env python2
# -*- coding: utf-8 -*-
# -*- coding: utf-8 -*-
# Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
# Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
#
#
# Copyright (c) 2021 Huawei Device Co., Ltd.
# Redistribution and use in source and binary forms, with or without modification,
# Licensed under the Apache License, Version 2.0 (the "License");
# are permitted provided that the following conditions are met:
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#
# http://www.apache.org/licenses/LICENSE-2.0
# 1. Redistributions of source code must retain the above copyright notice, this list of
# conditions and the following disclaimer.
#
#
# Unless required by applicable law or agreed to in writing, software
# 2. Redistributions in binary form must reproduce the above copyright notice, this list
# distributed under the License is distributed on an "AS IS" BASIS,
# of conditions and the following disclaimer in the documentation and/or other materials
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# provided with the distribution.
# See the License for the specific language governing permissions and
# limitations under the License.
#
#
# 3. Neither the name of the copyright holder nor the names of its contributors may be used
# to endorse or promote products derived from this software without specific prior written
# permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
# THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
import
sys
import
sys
import
os
import
os
...
...
tools/scripts/parse_memory/parse_mem_info.sh
浏览文件 @
cdcf6005
#!/bin/bash
#!/bin/bash
#Copyright (c) 2020-2021 Huawei Device Co., Ltd.
# Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
#Licensed under the Apache License, Version 2.0 (the "License");
# Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
#you may not use this file except in compliance with the License.
#You may obtain a copy of the License at
#
#
# http://www.apache.org/licenses/LICENSE-2.0
# Redistribution and use in source and binary forms, with or without modification,
# are permitted provided that the following conditions are met:
#
#
#Unless required by applicable law or agreed to in writing, software
# 1. Redistributions of source code must retain the above copyright notice, this list of
#distributed under the License is distributed on an "AS IS" BASIS,
# conditions and the following disclaimer.
#WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#
#See the License for the specific language governing permissions and
# 2. Redistributions in binary form must reproduce the above copyright notice, this list
#limitations under the License.
# of conditions and the following disclaimer in the documentation and/or other materials
# provided with the distribution.
#
# 3. Neither the name of the copyright holder nor the names of its contributors may be used
# to endorse or promote products derived from this software without specific prior written
# permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
# THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
LOAD_BASE
=
"0x2000000"
LOAD_BASE
=
"0x2000000"
LLVM_ADDR2LINE
=
llvm-addr2line
LLVM_ADDR2LINE
=
llvm-addr2line
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录