Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Tue, 15 Oct 2002 15:06:47 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Tue, 15 Oct 2002 15:06:46 -0400 Received: from to-velocet.redhat.com ([216.138.202.10]:9199 "EHLO touchme.toronto.redhat.com") by vger.kernel.org with ESMTP id ; Tue, 15 Oct 2002 15:06:44 -0400 Date: Tue, 15 Oct 2002 15:12:38 -0400 From: Benjamin LaHaise To: Davide Libenzi Cc: Shailabh Nagar , linux-kernel , linux-aio , Andrew Morton , David Miller , Linus Torvalds , Stephen Tweedie Subject: Re: [PATCH] async poll for 2.5 Message-ID: <20021015151238.L14596@redhat.com> References: <20021015150201.K14596@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.2.5.1i In-Reply-To: ; from davidel@xmailserver.org on Tue, Oct 15, 2002 at 12:16:39PM -0700 Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1277 Lines: 26 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. -ben - 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/