Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Tue, 15 Oct 2002 15:17:13 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Tue, 15 Oct 2002 15:17:13 -0400 Received: from x35.xmailserver.org ([208.129.208.51]:13971 "EHLO x35.xmailserver.org") by vger.kernel.org with ESMTP id ; Tue, 15 Oct 2002 15:17:11 -0400 X-AuthUser: davidel@xmailserver.org Date: Tue, 15 Oct 2002 12:31:12 -0700 (PDT) From: Davide Libenzi X-X-Sender: davide@blue1.dev.mcafeelabs.com To: Benjamin LaHaise cc: Shailabh Nagar , linux-kernel , linux-aio , Andrew Morton , David Miller , Linus Torvalds , Stephen Tweedie Subject: Re: [PATCH] async poll for 2.5 In-Reply-To: <20021015151238.L14596@redhat.com> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1522 Lines: 36 On Tue, 15 Oct 2002, Benjamin LaHaise wrote: > On Tue, Oct 15, 2002 at 12:16:39PM -0700, Davide Libenzi wrote: > > Ben, one of the reasons of the /dev/epoll speed is how it returns events > > and how it collapses them. A memory mapped array is divided by two and > > while the user consumes events in one set, the kernel fill the other one. > > The next wait() will switch the pointers. There is no copy from kernel to > > user space. Doing : > > > > int sys_epoll_wait(int epd, struct pollfd **pevts, int timeout); > > > > the only data the kernel has to copy to userspace is the 4(8) bytes for > > the "pevts" pointer. > > Erm, the aio interface has support for the event ringbuffer being accessed > by userspace (it lives in user memory and the kernel acts as a writer, with > userspace as a reader), that's one of its advantages -- completion events > are directly accessible from userspace after being written to by an > interrupt. Ideally this is to be wrapped in a vsyscall, but we don't have > support for that yet on x86, although much of the code written for x86-64 > should be reusable. In general I would like to have a "common" interface to retrieve IO events, but IMHO the two solutions should be benchmarked before adopting the one or the other. - Davide - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/