summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2019-05-14 20:46:12 -0600
committerJens Axboe <axboe@kernel.dk>2019-05-14 20:46:12 -0600
commit7e8902e14c1e684c03d44a7357928246b96b55bb (patch)
tree967d984203a79b7e1b1bfe8f846f1748436666d9
parentbb2c80ff0f7834691c892b6ea38114603b20abbe (diff)
examples/link-cp: fix a few issues
Still need to handle broken chains, must resubmit those. Signed-off-by: Jens Axboe <axboe@kernel.dk>
-rw-r--r--examples/link-cp.c20
1 files changed, 12 insertions, 8 deletions
diff --git a/examples/link-cp.c b/examples/link-cp.c
index 993d3a6..9ac4658 100644
--- a/examples/link-cp.c
+++ b/examples/link-cp.c
@@ -78,7 +78,7 @@ static int queue_rw_pair(struct io_uring *ring, off_t size, off_t offset)
return 0;
}
-static void handle_cqe(struct io_uring_cqe *cqe)
+static void handle_cqe(struct io_uring *ring, struct io_uring_cqe *cqe)
{
struct io_data *data;
@@ -86,10 +86,9 @@ static void handle_cqe(struct io_uring_cqe *cqe)
printf("cqe error: %s\n", strerror(cqe->res));
data = io_uring_cqe_get_data(cqe);
- if (!data)
- return;
-
- free(data);
+ if (data)
+ free(data);
+ io_uring_cqe_seen(ring, cqe);
}
static int copy_file(struct io_uring *ring, off_t insize)
@@ -103,8 +102,9 @@ static int copy_file(struct io_uring *ring, off_t insize)
inflight = 0;
while (insize) {
int has_inflight = inflight;
+ int depth;
- while (inflight < QD) {
+ while (insize && inflight < QD) {
this_size = BS;
if (this_size > insize)
this_size = insize;
@@ -117,12 +117,16 @@ static int copy_file(struct io_uring *ring, off_t insize)
if (has_inflight != inflight)
io_uring_submit(ring);
- while (inflight >= QD) {
+ if (insize)
+ depth = QD;
+ else
+ depth = 1;
+ while (inflight >= depth) {
int ret;
ret = io_uring_wait_cqe(ring, &cqe);
assert(ret >= 0);
- handle_cqe(cqe);
+ handle_cqe(ring, cqe);
inflight--;
}
}