blob: 73029f8fbc0b8593b0bf7ab41fd0196d27d801bc [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()
{
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 */
while (aio_error (&aiocb) == EINPROGRESS);
err = aio_error(&aiocb);
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;
}