Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2992802AbXEBGlT (ORCPT ); Wed, 2 May 2007 02:41:19 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S2992800AbXEBGlT (ORCPT ); Wed, 2 May 2007 02:41:19 -0400 Received: from gw1.cosmosbay.com ([86.65.150.130]:46954 "EHLO gw1.cosmosbay.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2992826AbXEBGlR (ORCPT ); Wed, 2 May 2007 02:41:17 -0400 Message-ID: <46383218.4020406@cosmosbay.com> Date: Wed, 02 May 2007 08:39:20 +0200 From: Eric Dumazet User-Agent: Thunderbird 1.5.0.10 (Windows/20070221) MIME-Version: 1.0 To: Davi Arnaut CC: Andrew Morton , Davide Libenzi , Linus Torvalds , Linux Kernel Mailing List Subject: Re: [patch 14/22] pollfs: pollable futex References: <20070502052235.914764000@haxent.com.br> <20070502053427.123392000@haxent.com.br> <4638279A.9010105@cosmosbay.com> <46382CA2.1020504@haxent.com.br> In-Reply-To: <46382CA2.1020504@haxent.com.br> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 8bit X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-1.6 (gw1.cosmosbay.com [86.65.150.130]); Wed, 02 May 2007 08:39:27 +0200 (CEST) Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3374 Lines: 117 Davi Arnaut a ?crit : > Eric Dumazet wrote: >> Davi Arnaut a ?crit : >>> Asynchronously wait for FUTEX_WAKE operation on a futex if it still contains >>> a given value. There can be only one futex wait per file descriptor. However, >>> it can be rearmed (possibly at a different address) anytime. >>> >>> The pollable futex approach is far superior (send and receive events from >>> userspace or kernel) to eventfd and fixes (supercedes) FUTEX_FD at the same time. >>> >>> Building block for pollable semaphores and user-defined events. >>> >>> Signed-off-by: Davi E. M. Arnaut >>> >>> --- >>> fs/pollfs/Makefile | 1 >>> fs/pollfs/futex.c | 154 +++++++++++++++++++++++++++++++++++++++++++++++++++++ >>> init/Kconfig | 7 ++ >>> 3 files changed, 162 insertions(+) >>> >>> Index: linux-2.6/fs/pollfs/Makefile >>> =================================================================== >>> --- linux-2.6.orig/fs/pollfs/Makefile >>> +++ linux-2.6/fs/pollfs/Makefile >>> @@ -3,3 +3,4 @@ pollfs-y := file.o >>> >>> pollfs-$(CONFIG_POLLFS_SIGNAL) += signal.o >>> pollfs-$(CONFIG_POLLFS_TIMER) += timer.o >>> +pollfs-$(CONFIG_POLLFS_FUTEX) += futex.o >>> Index: linux-2.6/fs/pollfs/futex.c >>> =================================================================== >>> --- /dev/null >>> +++ linux-2.6/fs/pollfs/futex.c >>> @@ -0,0 +1,154 @@ >>> +/* >>> + * pollable futex >>> + * >>> + * Copyright (C) 2007 Davi E. M. Arnaut >>> + * >>> + * Licensed under the GNU GPL. See the file COPYING for details. >>> + */ >>> + >>> +#include >>> +#include >>> +#include >>> +#include >>> +#include >>> +#include >>> +#include >>> +#include >>> +#include >>> + >>> +struct futex_event { >>> + union { >>> + void __user *addr; >>> + u64 padding; >>> + }; >>> + int val; >>> +}; >> Hum... Here we might have a problem with 64 bit futexes, or private futexes >> >> So I believe this interface is not well defined and not expandable: in case of >> future additions to futexes, an old application compiled with an old pollable >> futex_event type might fail. >> > > Hmm, how about: > > struct futex_event { > union { > void __user *addr; > u64 padding; > }; > union { > int val; > s64 val64; > }; > /* whatever room is necessary for future improvements */ > }; > > I haven't been keeping up with 64 bit or private futexes. What else > could probably go wrong? Well, that's the point : This interface is like an ioctl() one : pretty bad if not properly designed :) You probably need to stick one field containing one command or version number, something like that. struct futex_event { int type; union { void __user *addr; u64 padding; }; union { int val; s64 val64; }; }; #define FUTEX_EVENT_SHARED32 1 #define FUTEX_EVENT_SHARED64 2 #define FUTEX_EVENT_PRIVATE32 (128|1) #define FUTEX_EVENT_PRIVATE64 (128|2) ... Also, you should take care of alignements constraints (a 32bit user program might run on a 64bit kernel) - 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/