From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753058Ab0ESSYr (ORCPT ); Wed, 19 May 2010 14:24:47 -0400 Received: from mail-ww0-f46.google.com ([74.125.82.46]:54006 "EHLO mail-ww0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751673Ab0ESSYq (ORCPT ); Wed, 19 May 2010 14:24:46 -0400 DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=date:from:to:cc:subject:message-id:references:mime-version :content-type:content-disposition:in-reply-to:user-agent; b=eoR2B1A+F7KKcXdqPjohtc7NoARBJnw7yazMR2gIjlFbtSb+Y25Bko4I20+nff6lpn V8z6TKdJu/ynGxTRFbg9by7ACs7WhIO+HGQfH/vrxr1H6chdxwGXfGM2xS0ufoE5ZCI6 QfnPZdKFJWZNZAZZn/5eyTgRPipRT+N6t3K1o= Date: Wed, 19 May 2010 20:22:36 +0200 From: Frederic Weisbecker To: "H. Peter Anvin" Cc: Ingo Molnar , LKML , Autofs , Thomas Gleixner , John Kacur , Arnd Bergmann Subject: Re: [PATCH 2/8] autofs: Pushdown the bkl from ioctl Message-ID: <20100519182234.GB9752@nowhere> References: <1274289855-10001-1-git-send-regression-fweisbec@gmail.com> <1274289855-10001-3-git-send-regression-fweisbec@gmail.com> <4BF4279C.2000805@zytor.com> <20100519180832.GA9752@nowhere> <4BF42A5E.6060503@zytor.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <4BF42A5E.6060503@zytor.com> User-Agent: Mutt/1.5.18 (2008-05-17) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, May 19, 2010 at 11:13:50AM -0700, H. Peter Anvin wrote: > On 05/19/2010 11:08 AM, Frederic Weisbecker wrote: > > On Wed, May 19, 2010 at 11:02:04AM -0700, H. Peter Anvin wrote: > >> On 05/19/2010 10:24 AM, Frederic Weisbecker wrote: > >>> * generate kernel reactions > >>> */ > >>> -static int autofs_root_ioctl(struct inode *inode, struct file *filp, > >>> +static int autofs_root_ioctl_unlocked(struct inode *inode, struct file *filp, > >>> unsigned int cmd, unsigned long arg) > >>> { > >>> struct autofs_sb_info *sbi = autofs_sbi(inode->i_sb); > >>> @@ -579,3 +579,16 @@ static int autofs_root_ioctl(struct inode *inode, struct file *filp, > >>> return -ENOSYS; > >>> } > >>> } > >>> + > >>> +static long autofs_root_ioctl(struct file *filp, > >>> + unsigned int cmd, unsigned long arg) > >>> +{ > >> > >> The choice of naming here seems reverse in my opinion. > > > > > > Oh, why? > > > > The function that holds the bkl calls its unlocked version. > > > > But it's not ... it is locked at that point. It's not lock*ing*, but it > is not *unlocked*, either. Furthermore, it is directly contradicting > the naming scheme of the ops structure. It depends on the point of view. The function itself doesn't lock, it is the "naked point", so if you take it, you need to lock before, that's what the name wants to tell. But may be that's the opposite point of view than the common one, for which I wouldn't be suprised as my brain tends to be upside down...