From: Bian Naimeng <biannm@cn.fujitsu.com>
To: Garrett Cooper <yanegomi@gmail.com>
Cc: ltp-list@lists.sourceforge.net
Subject: [LTP] [POSIX][PATCH 1/4]Get rid of aio_suspend/6-1
Date: Thu, 11 Nov 2010 12:06:12 +0800 [thread overview]
Message-ID: <4CDB6BB4.3010004@cn.fujitsu.com> (raw)
In-Reply-To: <4CDB6AEC.9090604@cn.fujitsu.com>
aio_suspend/6-1 is same as 1-1,so remove it.
Signed-off-by: Bian Naimeng <biannm@cn.fujitsu.com>
---
.../conformance/interfaces/aio_suspend/6-1.c | 217 --------------------
1 files changed, 0 insertions(+), 217 deletions(-)
delete mode 100644 testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/6-1.c
diff --git a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/6-1.c b/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/6-1.c
deleted file mode 100644
index bc464c8..0000000
--- a/testcases/open_posix_testsuite/conformance/interfaces/aio_suspend/6-1.c
+++ /dev/null
@@ -1,217 +0,0 @@
-/*
- * Copyright (c) 2004, Bull SA. All rights reserved.
- * Created by: Laurent.Vivier@bull.net
- * This file is licensed under the GPL license. For the full content
- * of this license, see the COPYING file at the top level of this
- * source tree.
- */
-
-/*
- * assertion:
- *
- * aio_supend() shall return zero after one or more AIO operations have
- * completed.
- *
- * method:
- *
- * - write to a file
- * - submit a list of read requests
- * - suspend on a selected request
- * - check return code
- *
- */
-
-#define _XOPEN_SOURCE 600
-#include <sys/stat.h>
-#include <aio.h>
-#include <errno.h>
-#include <fcntl.h>
-#include <signal.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <unistd.h>
-
-#include "posixtest.h"
-
-#define TNAME "aio_suspend/6-1.c"
-
-#define NUM_AIOCBS 10
-#define BUF_SIZE 1024*1024
-#define WAIT_FOR_AIOCB 6
-
-int received_selected = 0;
-int received_all = 0;
-
-void
-sigrt1_handler(int signum, siginfo_t *info, void *context)
-{
- if (info->si_value.sival_int == WAIT_FOR_AIOCB)
- received_selected = 1;
-}
-
-void
-sigrt2_handler(int signum, siginfo_t *info, void *context)
-{
- received_all = 1;
-}
-
-int
-main ()
-{
- char tmpfname[256];
- int fd;
-
- struct aiocb **aiocbs;
- struct aiocb *plist[2];
- char *bufs;
- struct sigaction action;
- struct sigevent event;
- int errors = 0;
- int ret;
- int err;
- int i;
-
- if (sysconf(_SC_ASYNCHRONOUS_IO) != 200112L)
- return PTS_UNSUPPORTED;
-
- snprintf(tmpfname, sizeof(tmpfname), "/tmp/pts_aio_suspend_6_1_%d",
- getpid());
- unlink(tmpfname);
-
- fd = open(tmpfname, O_CREAT | O_RDWR | O_EXCL, S_IRUSR | S_IWUSR);
-
- if (fd == -1) {
- printf(TNAME " Error at open(): %s\n",
- strerror(errno));
- exit(PTS_UNRESOLVED);
- }
-
- unlink(tmpfname);
-
- bufs = (char *) malloc (NUM_AIOCBS*BUF_SIZE);
-
- if (bufs == NULL) {
- printf (TNAME " Error at malloc(): %s\n", strerror (errno));
- close (fd);
- exit(PTS_UNRESOLVED);
- }
-
- if (write (fd, bufs, NUM_AIOCBS*BUF_SIZE) != (NUM_AIOCBS*BUF_SIZE)) {
- printf(TNAME " Error at write(): %s\n", strerror(errno));
- free (bufs);
- close (fd);
- exit(PTS_UNRESOLVED);
- }
-
-
-
- aiocbs = (struct aiocb**)malloc(sizeof(struct aiocb *) * NUM_AIOCBS);
-
- /* Queue up a bunch of aio reads */
- for (i = 0; i < NUM_AIOCBS; i++) {
-
- aiocbs[i] = (struct aiocb*)malloc(sizeof(struct aiocb));
- memset(aiocbs[i], 0, sizeof(struct aiocb));
-
- aiocbs[i]->aio_fildes = fd;
- aiocbs[i]->aio_offset = i * BUF_SIZE;
- aiocbs[i]->aio_buf = &bufs[i*BUF_SIZE];
- aiocbs[i]->aio_nbytes = BUF_SIZE;
- aiocbs[i]->aio_lio_opcode = LIO_READ;
-
- /* Use SIRTMIN+1 for individual completions */
- aiocbs[i]->aio_sigevent.sigev_notify = SIGEV_SIGNAL;
- aiocbs[i]->aio_sigevent.sigev_signo = SIGRTMIN+1;
- aiocbs[i]->aio_sigevent.sigev_value.sival_int = i;
- }
-
- /* Use SIGRTMIN+2 for list completion */
- event.sigev_notify = SIGEV_SIGNAL;
- event.sigev_signo = SIGRTMIN+2;
- event.sigev_value.sival_ptr = NULL;
-
- /* Setup handler for individual operation completion */
- action.sa_sigaction = sigrt1_handler;
- sigemptyset(&action.sa_mask);
- action.sa_flags = SA_SIGINFO|SA_RESTART;
- sigaction(SIGRTMIN+1, &action, NULL);
-
- /* Setup handler for list completion */
- action.sa_sigaction = sigrt2_handler;
- sigemptyset(&action.sa_mask);
- action.sa_flags = SA_SIGINFO|SA_RESTART;
- sigaction(SIGRTMIN+2, &action, NULL);
-
- /* Setup suspend list */
- plist[0] = NULL;
- plist[1] = aiocbs[WAIT_FOR_AIOCB];
-
- /* Submit request list */
- ret = lio_listio(LIO_NOWAIT, aiocbs, NUM_AIOCBS, &event);
-
- if (ret) {
- printf(TNAME " Error at lio_listio() %d: %s\n", errno, strerror(errno));
- for (i=0; i<NUM_AIOCBS; i++)
- free (aiocbs[i]);
- free (bufs);
- free (aiocbs);
- close (fd);
- exit (PTS_UNRESOLVED);
- }
-
- /* Suspend on selected request */
- ret = aio_suspend((const struct aiocb **)plist, 2, NULL);
-
- /* Check selected request has completed */
- if (!received_selected) {
- printf (TNAME " Error : AIOCB %d should have completed after suspend\n",
- WAIT_FOR_AIOCB);
- for (i=0; i<NUM_AIOCBS; i++)
- free (aiocbs[i]);
- free (bufs);
- free (aiocbs);
- close (fd);
- exit (PTS_FAIL);
- }
-
-
- if (ret) {
- printf (TNAME " Error at aio_suspend() %d: %s\n", errno, strerror (errno));
- for (i=0; i<NUM_AIOCBS; i++)
- free (aiocbs[i]);
- free (bufs);
- free (aiocbs);
- close (fd);
- exit (PTS_FAIL);
- }
-
- /* Wait for list processing completion */
- while (!received_all)
- sleep (1);
-
- /* Check return code and free things */
- for (i = 0; i < NUM_AIOCBS; i++) {
- err = aio_error(aiocbs[i]);
- ret = aio_return(aiocbs[i]);
-
- if ((err != 0) && (ret != BUF_SIZE)) {
- printf(TNAME " req %d: error = %d - return = %d\n", i, err, ret);
- errors++;
- }
-
- free (aiocbs[i]);
- }
-
- free (bufs);
- free (aiocbs);
-
- close(fd);
-
- if (errors != 0)
- exit (PTS_FAIL);
-
- printf (TNAME " PASSED\n");
-
- return PTS_PASS;
-}
--
1.7.0.4
------------------------------------------------------------------------------
Centralized Desktop Delivery: Dell and VMware Reference Architecture
Simplifying enterprise desktop deployment and management using
Dell EqualLogic storage and VMware View: A highly scalable, end-to-end
client virtualization framework. Read more!
http://p.sf.net/sfu/dell-eql-dev2dev
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
next prev parent reply other threads:[~2010-11-11 4:06 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-11-11 4:02 [LTP] [POSIX][PATCH 0/4]Get rid of some test for aio_suspend Bian Naimeng
2010-11-11 4:06 ` Bian Naimeng [this message]
2010-11-11 4:07 ` [LTP] [POSIX][PATCH 2/4]Get rid of aio_suspend/7-1 Bian Naimeng
2010-11-11 4:13 ` [LTP] [POSIX][PATCH 3/4]Get rid of aio_suspend/8-1 Bian Naimeng
2010-11-11 4:14 ` [LTP] [POSIX][PATCH 4/4]Get rid of aio_suspend/9-1 Bian Naimeng
2010-11-11 10:10 ` [LTP] [POSIX][PATCH 0/4]Get rid of some test for aio_suspend Garrett Cooper
2010-11-11 15:09 ` Cyril Hrubis
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4CDB6BB4.3010004@cn.fujitsu.com \
--to=biannm@cn.fujitsu.com \
--cc=ltp-list@lists.sourceforge.net \
--cc=yanegomi@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.