blob: 3f65b94416038a5e19145ccac52e89c88e9d58f0 [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.
*/
#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_fsync/2-1.c"
#define BUF_SIZE 1024
int main(void)
{
char tmpfname[256];
char buf[BUF_SIZE];
int fd, ret;
struct aiocb aiocb_write;
struct aiocb aiocb_fsync;
if (sysconf(_SC_ASYNCHRONOUS_IO) < 200112L)
return PTS_UNSUPPORTED;
snprintf(tmpfname, sizeof(tmpfname), "/tmp/pts_aio_fsync_2_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_write, 0, sizeof(aiocb_write));
aiocb_write.aio_fildes = fd;
aiocb_write.aio_buf = buf;
aiocb_write.aio_nbytes = BUF_SIZE;
if (aio_write(&aiocb_write) == -1) {
printf(TNAME " Error at aio_write(): %s\n", strerror(errno));
exit(PTS_FAIL);
}
memset(&aiocb_fsync, 0, sizeof(aiocb_fsync));
aiocb_fsync.aio_fildes = fd;
if (aio_fsync(O_DSYNC, &aiocb_fsync) != 0) {
printf(TNAME " Error at aio_fsync(): %s\n", strerror(errno));
exit(PTS_FAIL);
}
/* wait for aio_fsync */
do {
usleep(10000);
ret = aio_error(&aiocb_fsync);
} while (ret == EINPROGRESS);
ret = aio_return(&aiocb_fsync);
if (ret) {
printf(TNAME " Error at aio_return(): %d (%s)\n",
ret, strerror(errno));
close(fd);
return PTS_FAIL;
}
/* check that aio_write is completed at this point */
ret = aio_error(&aiocb_write);
if (ret == EINPROGRESS) {
printf(TNAME " aiocb_write still in progress\n");
close(fd);
return PTS_FAIL;
}
close(fd);
printf("Test PASSED\n");
return PTS_PASS;
}