Add test case for -EAGAIN issue
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
@@ -2,13 +2,14 @@ CFLAGS ?= -g -O2 -Wall -D_GNU_SOURCE -L../src/
|
||||
|
||||
all_targets += poll poll-cancel ring-leak fsync io_uring_setup io_uring_register \
|
||||
io_uring_enter nop sq-full cq-full 35fa71a030ca-test \
|
||||
917257daa0fe-test b19062a56726-test
|
||||
917257daa0fe-test b19062a56726-test eeed8b54e0df-test
|
||||
|
||||
all: $(all_targets)
|
||||
|
||||
test_srcs := poll.c poll-cancel.c ring-leak.c fsync.c io_uring_setup.c \
|
||||
io_uring_register.c io_uring_enter.c nop.c sq-full.c cq-full.c \
|
||||
35fa71a030ca-test.c 917257daa0fe-test.c b19062a56726-test.c
|
||||
35fa71a030ca-test.c 917257daa0fe-test.c b19062a56726-test.c \
|
||||
eeed8b54e0df-test
|
||||
|
||||
test_objs := $(patsubst %.c,%.ol,$(test_srcs))
|
||||
|
||||
@@ -38,6 +39,8 @@ cq-full: cq-full.c
|
||||
$(CC) $(CFLAGS) -o $@ 917257daa0fe-test.c
|
||||
b19062a56726-test: b19062a56726-test.c
|
||||
$(CC) $(CFLAGS) -o $@ b19062a56726-test.c
|
||||
eeed8b54e0df-test: eeed8b54e0df-test.c
|
||||
$(CC) $(CFLAGS) -o $@ eeed8b54e0df-test.c -luring
|
||||
|
||||
clean:
|
||||
rm -f $(all_targets) $(test_objs)
|
||||
|
||||
87
test/eeed8b54e0df-test.c
Normal file
87
test/eeed8b54e0df-test.c
Normal file
@@ -0,0 +1,87 @@
|
||||
/*
|
||||
* Description: -EAGAIN handling
|
||||
*
|
||||
*/
|
||||
#include <errno.h>
|
||||
#include <stdio.h>
|
||||
#include <unistd.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <fcntl.h>
|
||||
|
||||
#include "../src/liburing.h"
|
||||
|
||||
static int get_file_fd(void)
|
||||
{
|
||||
char *buf;
|
||||
int fd;
|
||||
|
||||
fd = open("testfile", O_RDWR | O_CREAT, 0644);
|
||||
if (fd < 0) {
|
||||
perror("open file");
|
||||
return -1;
|
||||
}
|
||||
|
||||
buf = malloc(4096);
|
||||
write(fd, buf, 4096);
|
||||
fsync(fd);
|
||||
|
||||
if (posix_fadvise(fd, 0, 4096, POSIX_FADV_DONTNEED)) {
|
||||
perror("fadvise");
|
||||
close(fd);
|
||||
free(buf);
|
||||
return -1;
|
||||
}
|
||||
|
||||
free(buf);
|
||||
return fd;
|
||||
}
|
||||
|
||||
static void put_file_fd(int fd)
|
||||
{
|
||||
close(fd);
|
||||
unlink("testfile");
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
struct io_uring ring;
|
||||
struct io_uring_sqe *sqe;
|
||||
struct iovec iov;
|
||||
int ret, fd;
|
||||
|
||||
iov.iov_base = malloc(4096);
|
||||
iov.iov_len = 4096;
|
||||
|
||||
ret = io_uring_queue_init(2, &ring, 0);
|
||||
if (ret) {
|
||||
printf("ring setup failed\n");
|
||||
return 1;
|
||||
|
||||
}
|
||||
|
||||
sqe = io_uring_get_sqe(&ring);
|
||||
if (!sqe) {
|
||||
printf("get sqe failed\n");
|
||||
return 1;
|
||||
}
|
||||
|
||||
fd = get_file_fd();
|
||||
if (fd < 0)
|
||||
return 1;
|
||||
|
||||
io_uring_prep_readv(sqe, fd, &iov, 1, 0);
|
||||
sqe->rw_flags = RWF_NOWAIT;
|
||||
|
||||
ret = io_uring_submit(&ring);
|
||||
if (ret != -EAGAIN) {
|
||||
printf("Got submit %d, expected EAGAIN\n", ret);
|
||||
goto err;
|
||||
}
|
||||
|
||||
put_file_fd(fd);
|
||||
return 0;
|
||||
err:
|
||||
put_file_fd(fd);
|
||||
return 1;
|
||||
}
|
||||
Reference in New Issue
Block a user