Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Kernel Liteos A
提交
44279b25
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看板
提交
44279b25
编写于
11月 04, 2021
作者:
O
openharmony_ci
提交者:
Gitee
11月 04, 2021
浏览文件
操作
浏览文件
下载
差异文件
!694 PR676 关于ppoll修改挑单到3.0TLS
Merge pull request !694 from pef/OpenHarmony-3.0-1102
上级
ca8909b8
951d2336
变更
10
隐藏空白更改
内联
并排
Showing
10 changed file
with
339 addition
and
229 deletion
+339
-229
kernel/base/ipc/los_signal.c
kernel/base/ipc/los_signal.c
+5
-17
syscall/fs_syscall.c
syscall/fs_syscall.c
+23
-24
syscall/ipc_syscall.c
syscall/ipc_syscall.c
+10
-2
syscall/syscall_pub.h
syscall/syscall_pub.h
+1
-1
testsuites/unittest/IO/BUILD.gn
testsuites/unittest/IO/BUILD.gn
+1
-0
testsuites/unittest/IO/It_test_IO.h
testsuites/unittest/IO/It_test_IO.h
+1
-2
testsuites/unittest/IO/full/IO_test_ppoll_001.cpp
testsuites/unittest/IO/full/IO_test_ppoll_001.cpp
+69
-121
testsuites/unittest/IO/full/IO_test_ppoll_002.cpp
testsuites/unittest/IO/full/IO_test_ppoll_002.cpp
+66
-62
testsuites/unittest/IO/full/IO_test_ppoll_003.cpp
testsuites/unittest/IO/full/IO_test_ppoll_003.cpp
+152
-0
testsuites/unittest/IO/io_test.cpp
testsuites/unittest/IO/io_test.cpp
+11
-0
未找到文件。
kernel/base/ipc/los_signal.c
浏览文件 @
44279b25
...
...
@@ -218,28 +218,22 @@ void OsSigMaskSwitch(LosTaskCB * const rtcb, sigset_t set)
}
}
int
OsSigprocMask
(
int
how
,
const
sigset_t_l
*
setl
,
sigset_t_l
*
oldset
)
int
OsSigprocMask
(
int
how
,
const
sigset_t_l
*
setl
,
sigset_t_l
*
oldset
l
)
{
LosTaskCB
*
spcb
=
NULL
;
sigset_t
oldSigprocmask
;
int
ret
=
LOS_OK
;
unsigned
int
intSave
;
sigset_t
set
;
int
retVal
;
if
(
setl
!=
NULL
)
{
retVal
=
LOS_ArchCopyFromUser
(
&
set
,
&
(
setl
->
sig
[
0
]),
sizeof
(
sigset_t
));
if
(
retVal
!=
0
)
{
return
-
EFAULT
;
}
}
SCHEDULER_LOCK
(
intSave
);
spcb
=
OsCurrTaskGet
();
/* If requested, copy the old mask to user. */
oldSigprocmask
=
spcb
->
sig
.
sigprocmask
;
if
(
oldsetl
!=
NULL
)
{
*
(
sigset_t
*
)
oldsetl
=
spcb
->
sig
.
sigprocmask
;
}
/* If requested, modify the current signal mask. */
if
(
setl
!=
NULL
)
{
set
=
*
(
sigset_t
*
)
setl
;
/* Okay, determine what we are supposed to do */
switch
(
how
)
{
/* Set the union of the current set and the signal
...
...
@@ -267,12 +261,6 @@ int OsSigprocMask(int how, const sigset_t_l *setl, sigset_t_l *oldset)
}
SCHEDULER_UNLOCK
(
intSave
);
if
(
oldset
!=
NULL
)
{
retVal
=
LOS_ArchCopyToUser
(
&
(
oldset
->
sig
[
0
]),
&
oldSigprocmask
,
sizeof
(
sigset_t
));
if
(
retVal
!=
0
)
{
return
-
EFAULT
;
}
}
return
ret
;
}
...
...
syscall/fs_syscall.c
浏览文件 @
44279b25
...
...
@@ -2462,36 +2462,35 @@ int SysFstatfs64(int fd, size_t sz, struct statfs *buf)
int
SysPpoll
(
struct
pollfd
*
fds
,
nfds_t
nfds
,
const
struct
timespec
*
tmo_p
,
const
sigset_t
*
sigMask
,
int
nsig
)
{
int
timeout
;
int
ret
;
sigset_t_l
origMask
;
sigset_t_l
setl
;
if
(
sigMask
==
NULL
)
{
ret
=
-
EINVAL
;
return
ret
;
}
int
timeout
,
retVal
;
sigset_t_l
origMask
=
{
0
};
sigset_t_l
set
=
{
0
};
CHECK_ASPACE
(
tmo_p
,
sizeof
(
struct
timespec
));
CHECK_ASPACE
(
sigMask
,
sizeof
(
sigset_t
));
CPY_FROM_USER
(
tmo_p
);
CPY_FROM_USER
(
sigMask
);
timeout
=
(
tmo_p
==
NULL
)
?
-
1
:
(
tmo_p
->
tv_sec
*
OS_SYS_US_PER_MS
+
tmo_p
->
tv_nsec
/
OS_SYS_NS_PER_MS
);
if
(
timeout
&
0x80000000
)
{
ret
=
-
EINVAL
;
return
ret
;
if
(
tmo_p
!=
NULL
)
{
timeout
=
tmo_p
->
tv_sec
*
OS_SYS_US_PER_MS
+
tmo_p
->
tv_nsec
/
OS_SYS_NS_PER_MS
;
if
(
timeout
<
0
)
{
return
-
EINVAL
;
}
}
else
{
timeout
=
-
1
;
}
setl
.
sig
[
0
]
=
*
sigMask
;
OsSigprocMask
(
SIG_SETMASK
,
&
setl
,
&
origMask
);
ret
=
SysPoll
(
fds
,
nfds
,
timeout
);
if
(
ret
<
0
)
{
ret
=
-
get_errno
();
if
(
sigMask
!=
NULL
)
{
retVal
=
LOS_ArchCopyFromUser
(
&
set
,
sigMask
,
sizeof
(
sigset_t
));
if
(
retVal
!=
0
)
{
return
-
EFAULT
;
}
(
VOID
)
OsSigprocMask
(
SIG_SETMASK
,
&
set
,
&
origMask
);
}
else
{
(
VOID
)
OsSigprocMask
(
SIG_SETMASK
,
NULL
,
&
origMask
);
}
OsSigprocMask
(
SIG_SETMASK
,
&
origMask
,
NULL
);
PointerFree
(
tmo_pbak
);
PointerFree
(
sigMaskbak
);
return
(
ret
==
-
1
)
?
-
get_errno
()
:
ret
;
retVal
=
SysPoll
(
fds
,
nfds
,
timeout
);
(
VOID
)
OsSigprocMask
(
SIG_SETMASK
,
&
origMask
,
NULL
);
return
retVal
;
}
#endif
syscall/ipc_syscall.c
浏览文件 @
44279b25
...
...
@@ -29,6 +29,7 @@
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "syscall_pub.h"
#include "mqueue.h"
#include <errno.h>
#include <sys/types.h>
...
...
@@ -36,6 +37,7 @@
#include "time_posix.h"
#include "user_copy.h"
#include "los_signal.h"
#include "los_process_pri.h"
#include "los_strncpy_from_user.h"
#include "fs/file.h"
...
...
@@ -229,8 +231,14 @@ int SysSigAction(int sig, const sigaction_t *restrict sa, sigaction_t *restrict
int
SysSigprocMask
(
int
how
,
const
sigset_t_l
*
restrict
setl
,
sigset_t_l
*
restrict
oldl
,
size_t
sigsetsize
)
{
/* Let nxsig_procmask do all of the work */
return
OsSigprocMask
(
how
,
setl
,
oldl
);
CHECK_ASPACE
(
setl
,
sizeof
(
sigset_t_l
));
CHECK_ASPACE
(
oldl
,
sizeof
(
sigset_t_l
));
CPY_FROM_USER
(
setl
);
CPY_FROM_USER
(
oldl
);
/* Let OsSigprocMask do all of the work */
int
ret
=
OsSigprocMask
(
how
,
setl
,
oldl
);
CPY_TO_USER
(
oldl
);
return
ret
;
}
int
SysKill
(
pid_t
pid
,
int
sig
)
...
...
syscall/syscall_pub.h
浏览文件 @
44279b25
...
...
@@ -110,7 +110,7 @@ Please deal with the "char *" by function:UserPathCopy.
#define CPY_FROM_USER(ptr) \
__typeof
(
*
ptr
)
ptr
##
cpy
=
{
0
},
*
ptr
##
bak
=
ptr
;
\
if
(
ptr
!=
NULL
)
{
\
if
(
LOS_ArchCopyFromUser
((
void
*
)
&
ptr
##
cpy
,
ptr
,
sizeof
(
*
ptr
))
!=
0
)
{
\
if
(
LOS_ArchCopyFromUser
((
void
*
)
&
ptr
##
cpy
,
ptr
##
bak
,
sizeof
(
*
ptr
##
bak
))
!=
0
)
{
\
set_errno
(
EFAULT
);
\
return
-
get_errno
();
\
}
\
...
...
testsuites/unittest/IO/BUILD.gn
浏览文件 @
44279b25
...
...
@@ -85,6 +85,7 @@ sources_full = [
"full/IO_test_strncasecmp_l_002.cpp",
"full/IO_test_ppoll_001.cpp",
"full/IO_test_ppoll_002.cpp",
"full/IO_test_ppoll_003.cpp",
]
if (LOSCFG_USER_TEST_LEVEL >= TEST_LEVEL_LOW) {
...
...
testsuites/unittest/IO/It_test_IO.h
浏览文件 @
44279b25
...
...
@@ -127,12 +127,11 @@ extern VOID IO_TEST_DCNGETTEXT_002(VOID);
extern
VOID
IO_TEST_DCGETTEXT_001
(
VOID
);
extern
VOID
IO_TEST_DCGETTEXT_002
(
VOID
);
extern
VOID
IO_TEST_GETTEXT_001
(
VOID
);
extern
VOID
IO_TEST_PPOLL_001
(
void
);
extern
VOID
IO_TEST_PPOLL_002
(
void
);
extern
VOID
IO_TEST_PSELECT_001
(
void
);
extern
VOID
IO_TEST_STRFMON_L_001
(
VOID
);
extern
VOID
IO_TEST_STRFMON_L_002
(
VOID
);
extern
VOID
IO_TEST_PPOLL_001
(
VOID
);
extern
VOID
IO_TEST_PPOLL_002
(
VOID
);
extern
VOID
IO_TEST_PPOLL_003
(
VOID
);
#endif
testsuites/unittest/IO/full/IO_test_ppoll_001.cpp
浏览文件 @
44279b25
...
...
@@ -30,143 +30,91 @@
*/
#include "It_test_IO.h"
#include <poll.h>
#include "signal.h"
#include "pthread.h"
#define LISTEN_FD_NUM 10
#define POLL_EVENTS 1
const
int
BUF_SIZE
=
128
;
const
int
DELAY_TIME
=
200
;
int
pipeFdPpoll
[
LISTEN_FD_NUM
][
2
];
static
pthread_t
g_tid
=
-
1
;
extern
int
ppoll
(
struct
pollfd
*
fds
,
nfds_t
nfds
,
const
struct
timespec
*
tmo_p
,
const
sigset_t
*
sigmask
);
static
INT32
pipeFdPpoll
[
2
];
static
INT32
g_step
=
1
;
static
CHAR
strBuf
[]
=
"hello world."
;
static
struct
pollfd
pfd
;
static
void
*
pthread_01
(
void
)
static
void
*
pthread_01
(
void
*
arg
)
{
static
int
count
=
0
;
int
total_num
=
0
;
int
times
=
3
;
int
i
,
ret
;
struct
pollfd
fds
[
LISTEN_FD_NUM
]
=
{
0
};
char
buffer
[
20
];
struct
timespec
t
=
{
3
,
0
};
sigset_t
sigset
;
/* TEST_PRINT("[INFO]%s:%d,%s,Create thread %d\n", __FILE__, __LINE__, __func__, count); */
count
++
;
sigemptyset
(
&
sigset
);
sigaddset
(
&
sigset
,
SIGALRM
);
/* 把SIGALRM 信号添加到sigset 信号集中 */
sigaddset
(
&
sigset
,
SIGUSR1
);
for
(
i
=
0
;
i
<
LISTEN_FD_NUM
;
i
++
)
{
fds
[
i
].
fd
=
pipeFdPpoll
[
i
][
0
];
fds
[
i
].
events
=
POLL_EVENTS
;
INT32
retVal
;
CHAR
buf
[
BUF_SIZE
];
/* 执行ppoll监视文件描述符 */
while
(
g_step
<
3
)
{
/* 3, 3rd step */
usleep
(
DELAY_TIME
);
}
while
(
times
--
)
{
ret
=
ppoll
(
fds
,
LISTEN_FD_NUM
,
&
t
,
&
sigset
);
total_num
+=
((
ret
>
0
)
?
ret
:
0
);
if
(
ret
<=
0
)
{
continue
;
}
for
(
i
=
0
;
i
<
LISTEN_FD_NUM
;
i
++
)
{
if
(
fds
[
i
].
revents
&
POLL_EVENTS
)
{
ret
=
read
(
fds
[
i
].
fd
,
buffer
,
12
);
ICUNIT_GOTO_EQUAL
(
ret
,
12
,
ret
,
EXIT
);
ret
=
strcmp
(
buffer
,
"hello world"
);
TEST_PRINT
(
"[EVENT]%s:%d,%s,buffer=%s
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
buffer
);
}
}
if
(
total_num
==
LISTEN_FD_NUM
)
{
break
;
}
g_step
++
;
retVal
=
ppoll
(
&
pfd
,
1
,
NULL
,
NULL
);
ICUNIT_ASSERT_NOT_EQUAL_NULL
(
retVal
,
-
1
,
retVal
);
while
(
g_step
<
5
)
{
/* 5, 5th step */
usleep
(
DELAY_TIME
);
}
/* ICUNIT_GOTO_EQUAL(total_num, 10, -1, EXIT); */
/* TEST_PRINT("[INFO]%s:%d,%s,total_num=%d\n", __FILE__, __LINE__, __func__, total_num); */
EXIT:
return
nullptr
;
}
static
UINT32
testcase1
(
VOID
)
{
int
i
;
int
ret
;
int
count
=
0
;
for
(
i
=
0
;
i
<
LISTEN_FD_NUM
;
i
++
)
{
ret
=
pipe
(
pipeFdPpoll
[
i
]);
ICUNIT_GOTO_EQUAL
(
ret
,
0
,
ret
,
EXIT
);
TEST_PRINT
(
"[INFO]%s:%d,%s,ret=%d,pipeFdPpoll[%d][0]=%d
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
ret
,
i
,
pipeFdPpoll
[
i
][
0
]);
TEST_PRINT
(
"[INFO]%s:%d,%s,ret=%d,pipeFdPpoll[%d][0]=%d
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
ret
,
i
,
pipeFdPpoll
[
i
][
1
]);
g_step
++
;
/* 判断revents */
if
(
pfd
.
revents
&
POLLIN
)
{
memset_s
(
buf
,
sizeof
(
buf
),
0
,
sizeof
(
buf
));
retVal
=
read
(
pfd
.
fd
,
buf
,
BUF_SIZE
);
ICUNIT_ASSERT_NOT_EQUAL_NULL
(
retVal
,
-
1
,
retVal
);
retVal
=
strcmp
(
strBuf
,
buf
);
ICUNIT_ASSERT_EQUAL_NULL
(
retVal
,
0
,
retVal
);
}
errno
=
0
;
ret
=
pthread_create
(
&
g_tid
,
nullptr
,
(
void
*
(
*
)(
void
*
))
pthread_01
,
nullptr
);
TEST_PRINT
(
"[INFO]%s:%d,%s,ret=%d,errno=%d,errstr=%s
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
ret
,
errno
,
strerror
(
errno
));
ICUNIT_GOTO_EQUAL
(
ret
,
0
,
ret
,
EXIT
);
errno
=
0
;
for
(
i
=
0
;
i
<
LISTEN_FD_NUM
;
i
++
)
{
if
((
pipeFdPpoll
[
i
][
1
]
!=
9
)
&&
(
pipeFdPpoll
[
i
][
1
]
!=
10
)
&&
(
pipeFdPpoll
[
i
][
1
]
!=
11
))
{
ret
=
write
(
pipeFdPpoll
[
i
][
1
],
"hello world!"
,
12
);
/* 12, "hello world" length and '\0' */
}
ICUNIT_GOTO_EQUAL
(
ret
,
12
,
ret
,
EXIT
);
TEST_PRINT
(
"[INFO]%s:%d,%s,ret=%d,errno=%d,errstr=%s
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
ret
,
errno
,
strerror
(
errno
));
while
(
g_step
<
6
)
{
/* 6, 6th step */
usleep
(
DELAY_TIME
);
}
pthread_exit
(
NULL
);
}
#if 1
/* write looply */
while
(
1
)
{
if
(
count
++
>
3
)
{
break
;
}
sleep
(
1
);
for
(
i
=
0
;
i
<
LISTEN_FD_NUM
;
i
++
)
{
errno
=
0
;
ret
=
pthread_create
(
&
g_tid
,
nullptr
,
(
void
*
(
*
)(
void
*
))
pthread_01
,
nullptr
);
TEST_PRINT
(
"[INFO]%s:%d,%s,ret=%d,errno=%d,errstr=%s
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
ret
,
errno
,
strerror
(
errno
));
ICUNIT_GOTO_EQUAL
(
ret
,
0
,
ret
,
EXIT
);
if
((
pipeFdPpoll
[
i
][
1
]
==
13
)
||
(
pipeFdPpoll
[
i
][
1
]
==
14
)
||
(
pipeFdPpoll
[
i
][
1
]
==
15
))
{
errno
=
0
;
ret
=
write
(
pipeFdPpoll
[
i
][
1
],
"World HELLO!"
,
12
);
/* 12, "hello world" length and '\0' */
TEST_PRINT
(
"[INFO]%s:%d,%s,ret=%d,errno=%d,errstr=%s
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
ret
,
errno
,
strerror
(
errno
));
TEST_PRINT
(
"[INFO]%s:%d,%s,ret=%d,pipeFdPpoll[%d][1]=%d,count=%d
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
ret
,
i
,
pipeFdPpoll
[
i
][
1
],
count
);
}
/* ICUNIT_GOTO_EQUAL(ret, 12, ret, EXIT); */
}
STATIC
UINT32
testcase
(
VOID
)
{
INT32
retVal
;
pthread_t
tid
;
/* 建立管道 */
while
(
g_step
<
1
)
{
/* 1, 1st step */
usleep
(
DELAY_TIME
);
}
#endif
pthread_join
(
g_tid
,
nullptr
);
for
(
i
=
0
;
i
<
LISTEN_FD_NUM
;
i
++
)
{
close
(
pipeFdPpoll
[
i
][
0
]);
close
(
pipeFdPpoll
[
i
][
1
]);
retVal
=
pipe
(
pipeFdPpoll
);
ICUNIT_ASSERT_NOT_EQUAL
(
retVal
,
-
1
,
retVal
);
g_step
++
;
/* 设置pfd */
pfd
.
fd
=
pipeFdPpoll
[
0
];
pfd
.
events
=
POLLIN
;
/* 开辟线程执行 ppoll */
while
(
g_step
<
2
)
{
/* 2, 2nd step */
usleep
(
DELAY_TIME
);
}
return
LOS_OK
;
EXIT:
for
(
i
=
0
;
i
<
LISTEN_FD_NUM
;
i
++
)
{
close
(
pipeFdPpoll
[
i
][
0
]);
close
(
pipeFdPpoll
[
i
][
1
]
);
retVal
=
pthread_create
(
&
tid
,
NULL
,
pthread_01
,
NULL
);
ICUNIT_ASSERT_EQUAL
(
retVal
,
0
,
retVal
)
;
g_step
++
;
/* 向管道写入数据 */
while
(
g_step
<
4
)
{
/* 4, 4th step */
usleep
(
DELAY_TIME
);
}
return
LOS_NOK
;
}
static
UINT32
testcase
(
VOID
)
{
testcase1
();
sleep
(
1
);
retVal
=
write
(
pipeFdPpoll
[
1
],
"hello world."
,
sizeof
(
strBuf
));
ICUNIT_ASSERT_NOT_EQUAL
(
retVal
,
-
1
,
retVal
);
g_step
++
;
pthread_join
(
tid
,
NULL
);
return
LOS_OK
;
}
VOID
IO_TEST_PPOLL_001
(
VOID
)
{
TEST_ADD_CASE
(
__FUNCTION__
,
testcase
,
TEST_LIB
,
TEST_LIBC
,
TEST_LEVEL1
,
TEST_FUNCTION
);
}
}
\ No newline at end of file
testsuites/unittest/IO/full/IO_test_ppoll_002.cpp
浏览文件 @
44279b25
...
...
@@ -30,83 +30,87 @@
*/
#include "It_test_IO.h"
#include "time.h"
#include "signal.h"
#include <poll.h>
#include <fcntl.h>
#include <unistd.h>
#include <strings.h>
#include "pthread.h"
#define BUF_LEN 20
#define MAX_SCAN_FDSET 10
/* define poll's listened FD set's size */
#define POLL_WAIT_TIMEOUT 10*1000
/* ms */
const
int
BUF_SIZE
=
128
;
const
int
DELAY_TIME
=
200
;
extern
int
ppoll
(
struct
pollfd
*
fds
,
nfds_t
nfds
,
const
struct
timespec
*
timeout
,
const
sigset_t
*
sigmask
);
void
work_ppoll
(
int
fd
)
{
int
ret
=
0
;
int
i
=
0
;
char
recv_buf
[
BUF_LEN
];
sigset_t
sigset
;
struct
timespec
t
;
struct
pollfd
scan_fdset
[
MAX_SCAN_FDSET
];
int
scan_fdset_num
=
10
;
int
count
=
5
;
bzero
(
recv_buf
,
BUF_LEN
);
sigemptyset
(
&
sigset
);
sigaddset
(
&
sigset
,
SIGALRM
);
/* add SIGALRM to sigset */
sigaddset
(
&
sigset
,
SIGUSR1
);
/* add SIGUSR1 to sigset */
bzero
(
&
t
,
sizeof
(
struct
timespec
));
t
.
tv_sec
=
10
;
t
.
tv_nsec
=
0
;
bzero
(
scan_fdset
,
sizeof
(
struct
pollfd
)
*
MAX_SCAN_FDSET
);
scan_fdset
[
0
].
fd
=
fd
;
/* attention:in the book《UNIX网络编程第一卷》P162 metions:POLLERR,POLLHUP,POLLNVAL\
those error signals can not be set in events. */
/* they will return in revents,while the proper condition happens. */
scan_fdset
[
0
].
events
=
POLLOUT
;
/* set the signal needed to be listened:POLLOUT/POLLIN */
static
int
pipeFdPpoll
[
2
];
static
int
g_step
=
1
;
static
char
strBuf
[]
=
"hello world."
;
static
struct
pollfd
pfd
;
/* set other elements in the array as invalid. */
for
(
i
=
1
;
i
<
MAX_SCAN_FDSET
;
i
++
)
{
/* scan_fdset[i].fd = -1; */
scan_fdset
[
i
].
fd
=
fd
;
scan_fdset
[
i
].
events
=
POLLOUT
;
/* set the signal needed to be listened. */
static
void
*
pthread_01
(
void
*
arg
)
{
int
retVal
;
char
buf
[
BUF_SIZE
];
const
struct
timespec
timeout
=
{
10000
,
0
};
/* 执行ppoll监视文件描述符 */
while
(
g_step
<
4
)
{
/* 4, 4th step */
usleep
(
DELAY_TIME
);
}
/* scan_fdset_num = 1; */
/* 表示当前的scan_fdset[] 数组中只使用前面1 个元素存放需要监听的扫描符 */
while
(
count
--
)
{
ret
=
ppoll
(
scan_fdset
,
scan_fdset_num
,
&
t
,
&
sigset
);
for
(
i
=
0
;
i
<
MAX_SCAN_FDSET
;
i
++
)
{
if
(
scan_fdset
[
i
].
revents
&
POLLOUT
)
{
TEST_PRINT
(
"[INFO]%s:%d,%s,fd have signal!
\n
"
,
__FILE__
,
__LINE__
,
__func__
);
ret
=
read
(
fd
,
recv_buf
,
BUF_LEN
);
if
(
-
1
==
ret
)
{
TEST_PRINT
(
"[INFO]%s:%d,%s,read error!
\n
"
,
__FILE__
,
__LINE__
,
__func__
);
continue
;
}
TEST_PRINT
(
"[INFO]%s:%d,%s,recv_buf=%s
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
recv_buf
);
}
TEST_PRINT
(
"[INFO]%s:%d,%s,scan_fdset[i].revents=%d
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
scan_fdset
[
i
].
revents
);
}
g_step
++
;
retVal
=
ppoll
(
&
pfd
,
1
,
&
timeout
,
NULL
);
ICUNIT_ASSERT_NOT_EQUAL_NULL
(
retVal
,
-
1
,
retVal
);
/* 判断revents */
if
(
pfd
.
revents
&
POLLIN
)
{
memset_s
(
buf
,
sizeof
(
buf
),
0
,
sizeof
(
buf
));
retVal
=
read
(
pfd
.
fd
,
buf
,
BUF_SIZE
);
ICUNIT_ASSERT_NOT_EQUAL_NULL
(
retVal
,
-
1
,
retVal
);
retVal
=
strcmp
(
strBuf
,
buf
);
ICUNIT_ASSERT_EQUAL_NULL
(
retVal
,
0
,
retVal
);
}
while
(
g_step
<
5
)
{
/* 5, 5th step */
usleep
(
DELAY_TIME
);
}
pthread_exit
(
NULL
);
}
static
UINT32
testcase
(
VOID
)
{
int
fd
;
char
*
filename
=
FILEPATH_775
;
int
retVal
;
pthread_t
tid
;
/* 建立管道 */
while
(
g_step
<
1
)
{
usleep
(
DELAY_TIME
);
}
retVal
=
pipe
(
pipeFdPpoll
);
ICUNIT_ASSERT_NOT_EQUAL
(
retVal
,
-
1
,
retVal
);
g_step
++
;
/* 设置pfd */
pfd
.
fd
=
pipeFdPpoll
[
0
];
pfd
.
events
=
POLLIN
;
/* 向管道写入数据 */
while
(
g_step
<
2
)
{
/* 2, 2nd step */
usleep
(
DELAY_TIME
);
}
sleep
(
1
);
retVal
=
write
(
pipeFdPpoll
[
1
],
"hello world."
,
sizeof
(
strBuf
));
ICUNIT_ASSERT_NOT_EQUAL
(
retVal
,
-
1
,
retVal
);
g_step
++
;
fd
=
open
(
filename
,
O_RDWR
);
TEST_PRINT
(
"[INFO]%s:%d,%s,fd=%d
\n
"
,
__FILE__
,
__LINE__
,
__func__
,
fd
);
work_ppoll
(
fd
);
/* 开辟线程执行 ppoll */
while
(
g_step
<
3
)
{
/* 3, 3rd step */
usleep
(
DELAY_TIME
);
}
retVal
=
pthread_create
(
&
tid
,
NULL
,
pthread_01
,
NULL
);
ICUNIT_ASSERT_EQUAL
(
retVal
,
0
,
retVal
);
g_step
++
;
pthread_join
(
tid
,
NULL
);
return
LOS_OK
;
}
VOID
IO_TEST_PPOLL_002
(
VOID
)
{
TEST_ADD_CASE
(
__FUNCTION__
,
testcase
,
TEST_LIB
,
TEST_LIBC
,
TEST_LEVEL1
,
TEST_FUNCTION
);
}
}
\ No newline at end of file
testsuites/unittest/IO/full/IO_test_ppoll_003.cpp
0 → 100755
浏览文件 @
44279b25
/*
* Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
* 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.
*/
#include "It_test_IO.h"
#include "pthread.h"
#include "signal.h"
const
int
BUF_SIZE
=
128
;
const
int
DELAY_TIME
=
200
;
static
INT32
pipeFdPpoll
[
2
];
static
INT32
g_step
=
1
;
static
CHAR
strBuf
[]
=
"hello world."
;
static
struct
pollfd
pfd
;
static
sigset_t
sigMask
;
static
UINT32
count
=
0
;
static
void
signalHandle
(
INT32
sigNum
)
{
g_step
++
;
return
;
}
static
void
*
pthread_01
(
void
*
arg
)
{
INT32
retVal
;
CHAR
buf
[
BUF_SIZE
];
(
void
)
signal
(
SIGUSR1
,
signalHandle
);
while
(
1
)
{
/* 执行ppoll监视文件描述符 */
while
(
g_step
<
2
)
{
/* 2, 2nd step */
usleep
(
DELAY_TIME
);
}
g_step
++
;
retVal
=
ppoll
(
&
pfd
,
1
,
NULL
,
&
sigMask
);
ICUNIT_ASSERT_NOT_EQUAL_NULL
(
retVal
,
-
1
,
retVal
);
/* 判断revents */
if
(
pfd
.
revents
&
POLLIN
)
{
memset_s
(
buf
,
sizeof
(
buf
),
0
,
sizeof
(
buf
));
retVal
=
read
(
pfd
.
fd
,
buf
,
BUF_SIZE
);
ICUNIT_ASSERT_NOT_EQUAL_NULL
(
retVal
,
-
1
,
retVal
);
retVal
=
strcmp
(
strBuf
,
buf
);
ICUNIT_ASSERT_EQUAL_NULL
(
retVal
,
0
,
retVal
);
count
++
;
}
else
{
ICUNIT_ASSERT_NOT_EQUAL_NULL
(
pfd
.
revents
&
POLLIN
,
0
,
pfd
.
revents
&
POLLIN
);
}
g_step
++
;
if
(
g_step
>=
7
)
{
/* 7, 7th step */
ICUNIT_ASSERT_EQUAL_NULL
(
count
,
2
,
count
);
/* 2, 2nd step */
pthread_exit
(
NULL
);
}
}
return
LOS_OK
;
}
static
UINT32
testcase
(
VOID
)
{
INT32
retVal
;
pthread_t
tid
;
/* 建立管道 */
while
(
g_step
<
1
)
{
usleep
(
DELAY_TIME
);
}
retVal
=
pipe
(
pipeFdPpoll
);
ICUNIT_ASSERT_NOT_EQUAL
(
retVal
,
-
1
,
retVal
);
/* 设置pfd sigmask */
pfd
.
fd
=
pipeFdPpoll
[
0
];
pfd
.
events
=
POLLIN
;
pfd
.
revents
=
0x0
;
sigemptyset
(
&
sigMask
);
sigaddset
(
&
sigMask
,
SIGUSR1
);
/* 开辟线程执行 ppoll */
retVal
=
pthread_create
(
&
tid
,
NULL
,
pthread_01
,
NULL
);
ICUNIT_ASSERT_EQUAL
(
retVal
,
0
,
retVal
);
g_step
++
;
/* 向管道写入数据 */
while
(
g_step
<
3
)
{
/* 3, 3ed step */
usleep
(
DELAY_TIME
);
}
sleep
(
1
);
/* 保证先挂起再写入数据 */
retVal
=
write
(
pipeFdPpoll
[
1
],
"hello world."
,
sizeof
(
strBuf
));
ICUNIT_ASSERT_NOT_EQUAL
(
retVal
,
-
1
,
retVal
);
/* 向线程发送信号 */
while
(
g_step
<
5
)
{
/* 5, 5th step */
usleep
(
DELAY_TIME
);
}
sleep
(
1
);
/* 保证先挂起再发送信号 */
retVal
=
pthread_kill
(
tid
,
SIGUSR1
);
ICUNIT_ASSERT_EQUAL
(
retVal
,
0
,
retVal
);
/* 继续向管道写入数据 */
ICUNIT_ASSERT_EQUAL
(
g_step
,
5
,
g_step
);
/* 5, sth。判断挂起解除之前信号没有被处理 */
retVal
=
write
(
pipeFdPpoll
[
1
],
"hello world."
,
sizeof
(
strBuf
));
ICUNIT_ASSERT_NOT_EQUAL
(
retVal
,
-
1
,
retVal
);
while
(
g_step
<
7
)
{
/* 7, 7th step */
usleep
(
DELAY_TIME
);
}
ICUNIT_ASSERT_EQUAL
(
count
,
2
,
count
);
/* 2, 2nd step */
/* 等待退出 */
pthread_join
(
tid
,
NULL
);
return
LOS_OK
;
}
VOID
IO_TEST_PPOLL_003
(
VOID
)
{
TEST_ADD_CASE
(
__FUNCTION__
,
testcase
,
TEST_LIB
,
TEST_LIBC
,
TEST_LEVEL1
,
TEST_FUNCTION
);
}
\ No newline at end of file
testsuites/unittest/IO/io_test.cpp
浏览文件 @
44279b25
...
...
@@ -115,6 +115,17 @@ HWTEST_F(IoTest, IO_TEST_PPOLL_002, TestSize.Level0)
IO_TEST_PPOLL_002
();
}
/* *
* @tc.name: IO_TEST_PPOLL_003
* @tc.desc: function for IoTest
* @tc.type: FUNC
* @tc.require: AR000EEMQ9
*/
HWTEST_F
(
IoTest
,
IO_TEST_PPOLL_003
,
TestSize
.
Level0
)
{
IO_TEST_PPOLL_003
();
}
/* *
* @tc.name: IT_STDLIB_POLL_002
* @tc.desc: function for IoTest
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录