blob: c5607c57fb24caf9da5a68ca0cd2b7f81a8b72e0 [file] [log] [blame]
/*
* 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:
*
* The aio_write() function shall return the value zero if operation is
* successfuly queued.
*
* method:
*
* - open file
* - write 512 bytes using aio_write
* - check return code
*
*/
#define _XOPEN_SOURCE 600
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
#include <errno.h>
#include <stdlib.h>
#include <aio.h>
#include "posixtest.h"
#define TNAME "aio_write/5-1.c"
int main(void)
{
char tmpfname[256];
#define BUF_SIZE 512
char buf[BUF_SIZE];
int fd;
struct aiocb aiocb;
int err;
int ret;
if (sysconf(_SC_ASYNCHRONOUS_IO) < 200112L)
return PTS_UNSUPPORTED;
snprintf(tmpfname, sizeof(tmpfname), "/tmp/pts_aio_write_5_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);
memset(&aiocb, 0, sizeof(struct aiocb));
aiocb.aio_fildes = fd;
aiocb.aio_buf = buf;
aiocb.aio_nbytes = BUF_SIZE;
if (aio_write(&aiocb) == -1) {
printf(TNAME " Error at aio_write(): %s\n", strerror(errno));
exit(PTS_FAIL);
}
/* Wait until completion */
do {
usleep(10000);
err = aio_error(&aiocb);
} while (err == EINPROGRESS);
ret = aio_return(&aiocb);
if (err != 0) {
printf(TNAME " Error at aio_error() : %s\n", strerror(err));
close(fd);
exit(PTS_FAIL);
}
if (ret != BUF_SIZE) {
printf(TNAME " Error at aio_return()\n");
close(fd);
exit(PTS_FAIL);
}
close(fd);
printf("Test PASSED\n");
return PTS_PASS;
}