linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH libaio] add timeout to io_queue_run and remove io_queue_wait
@ 2003-07-09  0:57 Daniel McNeil
       [not found] ` <3F0C97C0.2060408@netscape.com>
  0 siblings, 1 reply; 3+ messages in thread
From: Daniel McNeil @ 2003-07-09  0:57 UTC (permalink / raw)
  To: Andrew Morton, Suparna Bhattacharya, Benjamin LaHaise
  Cc: linux-aio, Linux Kernel Mailing List

[-- Attachment #1: Type: text/plain, Size: 644 bytes --]

Here is a patch to libaio which adds a timeout parameter to
io_queue_run() and removes io_queue_wait().  This makes my
earlier kernel patch to fs/aio.c unnecessary, since I removed
io_queue_wait() which was calling the io_getevents() syscall
with a zero number of events.  This keeps the callback interface
in the library and allows a user process to wait for i/o's to
complete if it wants to.  I also changed io_queue_run() to
batch up to 8 completions at a time, so it is more efficient.
This requires no kernel changes. I also updated the io_queue_run() 
man page and that is in a separate patch.

Thoughts?

Daniel McNeil <daniel@osdl.org


[-- Attachment #2: patch.libaio.io_queue_run --]
[-- Type: text/x-patch, Size: 3043 bytes --]

diff -rupN -X /home/daniel_nfs/dontdiff libaio-0.3.93/src/io_queue_run.c libaio-0.3.93-io_queue_run_with_timeout/src/io_queue_run.c
--- libaio-0.3.93/src/io_queue_run.c	2002-09-26 09:39:38.000000000 -0700
+++ libaio-0.3.93-io_queue_run_with_timeout/src/io_queue_run.c	2003-07-08 16:38:52.983739711 -0700
@@ -21,19 +21,33 @@
 #include <stdlib.h>
 #include <time.h>
 
-int io_queue_run(io_context_t ctx)
+#define IO_BATCH_EVENTS	8		/* number of events to batch up */
+
+int io_queue_run(io_context_t ctx, struct timespec *timeout)
 {
-	static struct timespec timeout = { 0, 0 };
-	struct io_event event;
-	int ret;
-
-	/* FIXME: batch requests? */
-	while (1 == (ret = io_getevents(ctx, 0, 1, &event, &timeout))) {
-		io_callback_t cb = (io_callback_t)event.data;
-		struct iocb *iocb = event.obj;
+	struct io_event events[IO_BATCH_EVENTS];
+	struct io_event *ep;
+	int ret = 0;		/* total number of events processed */
+	int n;
+
+	/*
+	 * Process io events and call the callbacks.
+	 * Try to batch the events up to IO_BATCH_EVENTS at a time.
+	 * Loop until we have read all the available events and called the callbacks.
+	 */
+	do {
+		int i;
+
+		if ((n = io_getevents(ctx, 1, IO_BATCH_EVENTS, &events, timeout)) <= 0)
+			break;
+		ret += n;
+		for (ep = events, i = n; i-- > 0; ep++) {
+			io_callback_t cb = (io_callback_t)ep->data;
+			struct iocb *iocb = ep->obj;
 
-		cb(ctx, iocb, event.res, event.res2);
-	}
+			cb(ctx, iocb, ep->res, ep->res2);
+		}
+	} while (n == IO_BATCH_EVENTS);
 
-	return ret;
+	return ret ? ret : n;		/* return number of events or error */
 }
diff -rupN -X /home/daniel_nfs/dontdiff libaio-0.3.93/src/libaio.h libaio-0.3.93-io_queue_run_with_timeout/src/libaio.h
--- libaio-0.3.93/src/libaio.h	2002-10-08 16:33:42.000000000 -0700
+++ libaio-0.3.93-io_queue_run_with_timeout/src/libaio.h	2003-07-08 16:41:06.471880979 -0700
@@ -123,7 +123,7 @@ extern int io_queue_init(int maxevents, 
 /*extern int io_queue_grow(io_context_t ctx, int new_maxevents);*/
 extern int io_queue_release(io_context_t ctx);
 /*extern int io_queue_wait(io_context_t ctx, struct timespec *timeout);*/
-extern int io_queue_run(io_context_t ctx);
+extern int io_queue_run(io_context_t ctx, struct timespec *timeout);
 
 /* Actual syscalls */
 extern int io_setup(int maxevents, io_context_t *ctxp);
Binary files libaio-0.3.93/src/libaio.so.1 and libaio-0.3.93-io_queue_run_with_timeout/src/libaio.so.1 differ
diff -rupN -X /home/daniel_nfs/dontdiff libaio-0.3.93/src/Makefile libaio-0.3.93-io_queue_run_with_timeout/src/Makefile
--- libaio-0.3.93/src/Makefile	2002-09-12 20:30:12.000000000 -0700
+++ libaio-0.3.93-io_queue_run_with_timeout/src/Makefile	2003-07-08 16:47:29.426559122 -0700
@@ -14,7 +14,7 @@ all: $(all_targets)
 
 # libaio provided functions
 libaio_srcs := io_queue_init.c io_queue_release.c
-libaio_srcs += io_queue_wait.c io_queue_run.c
+libaio_srcs += io_queue_run.c
 
 # real syscalls
 libaio_srcs += io_getevents.c io_submit.c io_cancel.c

[-- Attachment #3: patch.libaio.man.io_queue_run --]
[-- Type: text/x-patch, Size: 1462 bytes --]

diff -rupN -X /home/daniel_nfs/dontdiff libaio-0.3.93/man/io_queue_run.3 libaio-0.3.93-io_queue_run_with_timeout/man/io_queue_run.3
--- libaio-0.3.93/man/io_queue_run.3	2002-09-26 08:55:18.000000000 -0700
+++ libaio-0.3.93-io_queue_run_with_timeout/man/io_queue_run.3	2003-07-08 17:28:55.441862077 -0700
@@ -9,16 +9,21 @@ io_queue_run \- Handle completed io requ
 .B #include <libaio.h>
 .br
 .sp
-.BI "int io_queue_run(io_context_t  ctx );"
+.BI "int io_queue_run(io_context_t  ctx, struct timespec *timeout);"
 .sp
 .fi
 .SH DESCRIPTION
 .B io_queue_run
-Attempts to read  all the events events from
-the completion queue for the aio_context specified by ctx_id.
+Attempts to read all the events events from
+the completion queue for the aio_context specified by ctx and calls the callbacks
+setup by io_set_callback().
 .SH "RETURN VALUES"
+Returns the number of events handled.
 May return
-0 if no events are available.
+0 if no events are available and the timeout specified
+by timeout has elapsed, where timeout == NULL specifies an infinite
+timeout.  Note that the timeout pointed to by timeout is relative and
+will be updated if not NULL and the operation blocks.
 Will fail with -ENOSYS if not implemented.
 .SH ERRORS
 .TP
@@ -44,7 +49,6 @@ Not implemented
 .BR io_prep_pwrite(3),
 .BR io_queue_init(3),
 .BR io_queue_release(3),
-.BR io_queue_wait(3),
 .BR io_set_callback(3),
 .BR io_submit(3),
 .BR errno(3)

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2003-07-10 22:22 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-07-09  0:57 [PATCH libaio] add timeout to io_queue_run and remove io_queue_wait Daniel McNeil
     [not found] ` <3F0C97C0.2060408@netscape.com>
2003-07-09 23:49   ` Daniel McNeil
2003-07-10 22:37     ` John Myers

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).