summaryrefslogtreecommitdiff
path: root/libaio-0.3.109/harness/cases/13.t
blob: 5f18005b6af2de2a463fbc394465ef6fdc1cba48 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/* 13.t - uses testdir/rwfile
- Submit multiple writes larger than aio-max-size (deadlocks on older
  aio code)
*/
#include "aio_setup.h"

#include <sys/time.h>
#include <sys/resource.h>
#include <unistd.h>

int test_main(void)
{
#define SIZE	(1024 * 1024)
#define IOS	8
	struct iocb	iocbs[IOS];
	struct iocb	*iocb_list[IOS];
	char *bufs[IOS];
	int rwfd;
	int status = 0, res;
	int i;

	rwfd = open("testdir/rwfile", O_RDWR|O_CREAT|O_TRUNC, 0600);
							assert(rwfd != -1);
	res = ftruncate(rwfd, 0);			assert(res == 0);

	for (i=0; i<IOS; i++) {
		bufs[i] = malloc(SIZE);
		assert(bufs[i] != NULL);
		memset(bufs[i], 0, SIZE);

		io_prep_pwrite(&iocbs[i], rwfd, bufs[i], SIZE, i * SIZE);
		iocb_list[i] = &iocbs[i];
	}

	status |= attempt_io_submit(io_ctx, IOS, iocb_list, IOS);

	for (i=0; i<IOS; i++) {
		struct timespec ts = { tv_sec: 30, tv_nsec: 0 };
		struct io_event event;
		struct iocb *iocb;

		res = io_getevents(io_ctx, 0, 1, &event, &ts);
		if (res != 1) {
			status |= 1;
			printf("io_getevents failed [%d] with res=%d [%s]\n",
				i, res, (res < 0) ? strerror(-res) : "okay");
			break;
		}

		if (event.res != SIZE)
			status |= 1;

		iocb = (void *)event.obj;
		printf("event[%d]: write[%d] %s, returned: %ld [%s]\n",
			i, (int)(iocb - &iocbs[0]),
			(event.res != SIZE) ? "failed" : "okay",
			(long)event.res,
			(event.res < 0) ? strerror(-event.res) : "okay"
			);
	}

	res = ftruncate(rwfd, 0);			assert(res == 0);
	res = close(rwfd);				assert(res == 0);
	return status;
}