* [LTP] [PATCH] aio_suspend/3-1: cancel the aio_write operations
@ 2012-07-26 2:22 Kang Kai
2012-08-03 1:43 ` Kang Kai
2012-08-03 2:35 ` Wanlong Gao
0 siblings, 2 replies; 3+ messages in thread
From: Kang Kai @ 2012-07-26 2:22 UTC (permalink / raw)
To: ltp-list; +Cc: Zhenfeng.Zhao
After aio_suspend, call aio_cancel to cancel other aio_write operations
then wait them to canceld or complete.
If don't do that, it fails with "Segmentation fault" on routerstation(mips)
board randomly about in 1000 continuous test. The reason may be some
aio_writes don't complete before close the file, that cause some resouse
don't be released and finally cause segment fault.
Signed-off-by: Kang Kai <kai.kang@windriver.com>
---
.../conformance/interfaces/aio_suspend/3-1.c | 15 +++++++++++++++
1 files changed, 15 insertions(+), 0 deletions(-)
diff --git a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c b/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
index 15120e1..49d204a 100644
--- a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
+++ b/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
@@ -87,6 +87,21 @@ int main()
exit(PTS_FAIL);
}
+ if (aio_cancel(fd, NULL) == -1) {
+ printf(TNAME " Error at aio_cancel(): %s\n", strerror(errno));
+ exit(PTS_FAIL);
+ }
+
+
+ while (1) {
+ for (i = 0; i < NAIOCB; ++i) {
+ if (aio_error(&aiocb[i]) == EINPROGRESS)
+ break;
+ }
+ if (i == NAIOCB)
+ break;
+ }
+
close(fd);
printf("Test PASSED\n");
return PTS_PASS;
--
1.7.5.4
------------------------------------------------------------------------------
Live Security Virtual Conference
Exclusive live event will cover all the ways today's security and
threat landscape has changed and how IT managers can respond. Discussions
will include endpoint security, mobile security and the latest in malware
threats. http://www.accelacomm.com/jaw/sfrnl04242012/114/50122263/
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
^ permalink raw reply related [flat|nested] 3+ messages in thread* Re: [LTP] [PATCH] aio_suspend/3-1: cancel the aio_write operations
2012-07-26 2:22 [LTP] [PATCH] aio_suspend/3-1: cancel the aio_write operations Kang Kai
@ 2012-08-03 1:43 ` Kang Kai
2012-08-03 2:35 ` Wanlong Gao
1 sibling, 0 replies; 3+ messages in thread
From: Kang Kai @ 2012-08-03 1:43 UTC (permalink / raw)
To: Kang Kai; +Cc: ltp-list, Zhenfeng.Zhao
On 2012年07月26日 10:22, Kang Kai wrote:
> After aio_suspend, call aio_cancel to cancel other aio_write operations
> then wait them to canceld or complete.
>
> If don't do that, it fails with "Segmentation fault" on routerstation(mips)
> board randomly about in 1000 continuous test. The reason may be some
> aio_writes don't complete before close the file, that cause some resouse
> don't be released and finally cause segment fault.
Hi,
Would anybody like to review this patch for me?
Thanks,
Kai
> Signed-off-by: Kang Kai<kai.kang@windriver.com>
> ---
> .../conformance/interfaces/aio_suspend/3-1.c | 15 +++++++++++++++
> 1 files changed, 15 insertions(+), 0 deletions(-)
>
> diff --git a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c b/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
> index 15120e1..49d204a 100644
> --- a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
> +++ b/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
> @@ -87,6 +87,21 @@ int main()
> exit(PTS_FAIL);
> }
>
> + if (aio_cancel(fd, NULL) == -1) {
> + printf(TNAME " Error at aio_cancel(): %s\n", strerror(errno));
> + exit(PTS_FAIL);
> + }
> +
> +
> + while (1) {
> + for (i = 0; i< NAIOCB; ++i) {
> + if (aio_error(&aiocb[i]) == EINPROGRESS)
> + break;
> + }
> + if (i == NAIOCB)
> + break;
> + }
> +
> close(fd);
> printf("Test PASSED\n");
> return PTS_PASS;
------------------------------------------------------------------------------
Live Security Virtual Conference
Exclusive live event will cover all the ways today's security and
threat landscape has changed and how IT managers can respond. Discussions
will include endpoint security, mobile security and the latest in malware
threats. http://www.accelacomm.com/jaw/sfrnl04242012/114/50122263/
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
^ permalink raw reply [flat|nested] 3+ messages in thread* Re: [LTP] [PATCH] aio_suspend/3-1: cancel the aio_write operations
2012-07-26 2:22 [LTP] [PATCH] aio_suspend/3-1: cancel the aio_write operations Kang Kai
2012-08-03 1:43 ` Kang Kai
@ 2012-08-03 2:35 ` Wanlong Gao
1 sibling, 0 replies; 3+ messages in thread
From: Wanlong Gao @ 2012-08-03 2:35 UTC (permalink / raw)
To: Kang Kai; +Cc: ltp-list, Zhenfeng.Zhao
On 07/26/2012 10:22 AM, Kang Kai wrote:
> After aio_suspend, call aio_cancel to cancel other aio_write operations
> then wait them to canceld or complete.
>
> If don't do that, it fails with "Segmentation fault" on routerstation(mips)
> board randomly about in 1000 continuous test. The reason may be some
> aio_writes don't complete before close the file, that cause some resouse
> don't be released and finally cause segment fault.
>
> Signed-off-by: Kang Kai <kai.kang@windriver.com>
> ---
> .../conformance/interfaces/aio_suspend/3-1.c | 15 +++++++++++++++
> 1 files changed, 15 insertions(+), 0 deletions(-)
>
> diff --git a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c b/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
> index 15120e1..49d204a 100644
> --- a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
> +++ b/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/3-1.c
> @@ -87,6 +87,21 @@ int main()
> exit(PTS_FAIL);
> }
>
> + if (aio_cancel(fd, NULL) == -1) {
> + printf(TNAME " Error at aio_cancel(): %s\n", strerror(errno));
> + exit(PTS_FAIL);
> + }
Try to cancel the pending aio seems useless, how about waiting aios until completed?
Can you test like below?
for (i = 0; i < NAIOCB; i++) {
do {
usleep(10000);
ret = aio_error(&aiocb[i]);
} while (ret == EINPROGRESS);
if (ret < 0) {
printf(TNAME " Error at aio_error() : %s\n", strerror(ret));
exit(PTS_FAIL);
}
}
Thanks,
Wanlong Gao
> +
> +
> + while (1) {
> + for (i = 0; i < NAIOCB; ++i) {
> + if (aio_error(&aiocb[i]) == EINPROGRESS)
> + break;
> + }
> + if (i == NAIOCB)
> + break;
> + }
> +
> close(fd);
> printf("Test PASSED\n");
> return PTS_PASS;
>
------------------------------------------------------------------------------
Live Security Virtual Conference
Exclusive live event will cover all the ways today's security and
threat landscape has changed and how IT managers can respond. Discussions
will include endpoint security, mobile security and the latest in malware
threats. http://www.accelacomm.com/jaw/sfrnl04242012/114/50122263/
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2012-08-03 2:37 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-07-26 2:22 [LTP] [PATCH] aio_suspend/3-1: cancel the aio_write operations Kang Kai
2012-08-03 1:43 ` Kang Kai
2012-08-03 2:35 ` Wanlong Gao
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox