Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp708530pxb; Tue, 19 Oct 2021 11:15:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxC8ZZqjazRregTJ/CdrneR36nlnvrPlYTotm8319GFMr+4xzMUu71qEyPyYg0KnxmEkmDp X-Received: by 2002:a17:90a:4b8e:: with SMTP id i14mr1442043pjh.235.1634667324605; Tue, 19 Oct 2021 11:15:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634667324; cv=none; d=google.com; s=arc-20160816; b=W38yh37/2ioEybzt2DuM67xUebHog5IbyqlBaH+3jzz7TO2m8tQp9flPgy7Y9YXzN0 magRogRGr+1CUGd1iro3GwDUtfUuV3oHZkt+pk82e9Q2BnuG6N2sjPjG8cFsMuCzj1lE JbBWCqk1Eepyy1l5F3wot5KIJhXzOuL+NTewsSjyMrsj9pAeyvd9+juRZBN3oCPTXgvT Eyrorlvh6TUYsh0Rhi42c8shme8Cs5ENTE5TkEAI9ad9EF2uO6Y1yLyK8riHf2v10ra5 lzgIcFoTvzAmetPejp0kQHcJUDQtaMyl+Isko3WfVx0hftf54JhKePu9Bnl38YC3qy4a qgMA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=cZ7RAlBcJCkNvd1DpEAnj362jzDFvXcWj5faNQjT3lU=; b=EMoBZ2y7SHKo8tL0RWhcn2oFwAcKI3yE/hWqYkIAu+A+IUbv3I26LKrsnY40LktIUi S8JMebXUrNETkt8YPw6M23b+JE6E66SbdII0+TLUvRqUUwmt33ky8ZV1AUVwrhnQxp0V GfAHQwOAaUyltpSL6yN0nIVETYVVnFc/euDOJ4a6f0l/j1e/zP7uDQ45bG+E4iKVXQm2 XhRt4nv/I4gQeHh3rxyH7HhOM5YCX4bncXRy9fOFJjeWKRH76HaieEPQbdyKy5EJsvZd imxQvwAnzhii0scdc4i9KPOQVwwbMoUWE7CFvJ89z0uBqYB1cFszu/OBkQ3rBZ+cGu21 HBAA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=qfQc5LAX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id lw6si2556449pjb.95.2021.10.19.11.15.09; Tue, 19 Oct 2021 11:15:24 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=qfQc5LAX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234401AbhJSSQY (ORCPT + 99 others); Tue, 19 Oct 2021 14:16:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:44496 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231586AbhJSSQX (ORCPT ); Tue, 19 Oct 2021 14:16:23 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 94E7860EB8; Tue, 19 Oct 2021 18:14:09 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1634667250; bh=J4ZMuwKRrsM3GBytg7AEN8iyVcpQjlnruCCQfoCvW9E=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=qfQc5LAXqVyhH+RjZfQebBgWV4Rbi2eG3uFJ4ogsx53Z4cLrkb5Ndf43HRnR8xUyZ IlYjQdFT6owENmiviF/HF6MXrMelCjaqLGKCiPcDdnusWe11fPMFo8pkYpLWw81h+o Nr2bCKa3rIe9Q3l8u6n/gSpS64uKBA91CzS/e3QEkbCTCMp9rjJ5/9UsE39N9QOgw7 GQhv38hrJE/cF2uKNxfaDJklVeVLRf69i0NmFVXuhObsjY1OP20uk0R3C5csvDh40s 5MGMA9mgrXZtz3mPTZ3lXckE/LBd7wR6FmvqxnPbGcv1mKv15lsVmzzcOyEuJBhHK7 4WyWMEXKBYn4Q== Message-ID: <6f4a14d0a455c5a93eccfdf2dc8555b82b79694b.camel@kernel.org> Subject: Re: [PATCH] locks: remove changelog comments From: Jeff Layton To: "J. Bruce Fields" Cc: Mauro Carvalho Chehab , Linux Doc Mailing List , Jonathan Corbet , Alexander Viro , linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org Date: Tue, 19 Oct 2021 14:14:08 -0400 In-Reply-To: <20211019173835.GE15063@fieldses.org> References: <887de3a1ecadda3dbfe0adf9df9070f0afa9406c.1634630486.git.mchehab+huawei@kernel.org> <20211019141427.GA15063@fieldses.org> <20211019161651.GD15063@fieldses.org> <20211019173835.GE15063@fieldses.org> Content-Type: text/plain; charset="ISO-8859-15" User-Agent: Evolution 3.40.4 (3.40.4-2.fc34) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2021-10-19 at 13:38 -0400, J. Bruce Fields wrote: > From: "J. Bruce Fields" > > This is only of historical interest, and anyone interested in the > history can dig out an old version of locks.c from from git. > > Triggered by the observation that it references the now-removed > Documentation/filesystems/mandatory-locking.rst. > > Reported-by: Mauro Carvalho Chehab > Signed-off-by: J. Bruce Fields > --- > fs/locks.c | 114 ++--------------------------------------------------- > 1 file changed, 4 insertions(+), 110 deletions(-) > > On Tue, Oct 19, 2021 at 12:27:55PM -0400, Jeff Layton wrote: > > Yeah, I think that looks great. Send it with a changelog and I'll pull > > it into the branch I have feeding into -next. > > OK!--b. > > diff --git a/fs/locks.c b/fs/locks.c > index 3d6fb4ae847b..b54813eae44f 100644 > --- a/fs/locks.c > +++ b/fs/locks.c > @@ -2,117 +2,11 @@ > /* > * linux/fs/locks.c > * > - * Provide support for fcntl()'s F_GETLK, F_SETLK, and F_SETLKW calls. > - * Doug Evans (dje@spiff.uucp), August 07, 1992 > + * We implement four types of file locks: BSD locks, posix locks, open > + * file description locks, and leases. For details about BSD locks, > + * see the flock(2) man page; for details about the other three, see > + * fcntl(2). > * > - * Deadlock detection added. > - * FIXME: one thing isn't handled yet: > - * - mandatory locks (requires lots of changes elsewhere) > - * Kelly Carmichael (kelly@[142.24.8.65]), September 17, 1994. > - * > - * Miscellaneous edits, and a total rewrite of posix_lock_file() code. > - * Kai Petzke (wpp@marie.physik.tu-berlin.de), 1994 > - * > - * Converted file_lock_table to a linked list from an array, which eliminates > - * the limits on how many active file locks are open. > - * Chad Page (pageone@netcom.com), November 27, 1994 > - * > - * Removed dependency on file descriptors. dup()'ed file descriptors now > - * get the same locks as the original file descriptors, and a close() on > - * any file descriptor removes ALL the locks on the file for the current > - * process. Since locks still depend on the process id, locks are inherited > - * after an exec() but not after a fork(). This agrees with POSIX, and both > - * BSD and SVR4 practice. > - * Andy Walker (andy@lysaker.kvaerner.no), February 14, 1995 > - * > - * Scrapped free list which is redundant now that we allocate locks > - * dynamically with kmalloc()/kfree(). > - * Andy Walker (andy@lysaker.kvaerner.no), February 21, 1995 > - * > - * Implemented two lock personalities - FL_FLOCK and FL_POSIX. > - * > - * FL_POSIX locks are created with calls to fcntl() and lockf() through the > - * fcntl() system call. They have the semantics described above. > - * > - * FL_FLOCK locks are created with calls to flock(), through the flock() > - * system call, which is new. Old C libraries implement flock() via fcntl() > - * and will continue to use the old, broken implementation. > - * > - * FL_FLOCK locks follow the 4.4 BSD flock() semantics. They are associated > - * with a file pointer (filp). As a result they can be shared by a parent > - * process and its children after a fork(). They are removed when the last > - * file descriptor referring to the file pointer is closed (unless explicitly > - * unlocked). > - * > - * FL_FLOCK locks never deadlock, an existing lock is always removed before > - * upgrading from shared to exclusive (or vice versa). When this happens > - * any processes blocked by the current lock are woken up and allowed to > - * run before the new lock is applied. > - * Andy Walker (andy@lysaker.kvaerner.no), June 09, 1995 > - * > - * Removed some race conditions in flock_lock_file(), marked other possible > - * races. Just grep for FIXME to see them. > - * Dmitry Gorodchanin (pgmdsg@ibi.com), February 09, 1996. > - * > - * Addressed Dmitry's concerns. Deadlock checking no longer recursive. > - * Lock allocation changed to GFP_ATOMIC as we can't afford to sleep > - * once we've checked for blocking and deadlocking. > - * Andy Walker (andy@lysaker.kvaerner.no), April 03, 1996. > - * > - * Initial implementation of mandatory locks. SunOS turned out to be > - * a rotten model, so I implemented the "obvious" semantics. > - * See 'Documentation/filesystems/mandatory-locking.rst' for details. > - * Andy Walker (andy@lysaker.kvaerner.no), April 06, 1996. > - * > - * Don't allow mandatory locks on mmap()'ed files. Added simple functions to > - * check if a file has mandatory locks, used by mmap(), open() and creat() to > - * see if system call should be rejected. Ref. HP-UX/SunOS/Solaris Reference > - * Manual, Section 2. > - * Andy Walker (andy@lysaker.kvaerner.no), April 09, 1996. > - * > - * Tidied up block list handling. Added '/proc/locks' interface. > - * Andy Walker (andy@lysaker.kvaerner.no), April 24, 1996. > - * > - * Fixed deadlock condition for pathological code that mixes calls to > - * flock() and fcntl(). > - * Andy Walker (andy@lysaker.kvaerner.no), April 29, 1996. > - * > - * Allow only one type of locking scheme (FL_POSIX or FL_FLOCK) to be in use > - * for a given file at a time. Changed the CONFIG_LOCK_MANDATORY scheme to > - * guarantee sensible behaviour in the case where file system modules might > - * be compiled with different options than the kernel itself. > - * Andy Walker (andy@lysaker.kvaerner.no), May 15, 1996. > - * > - * Added a couple of missing wake_up() calls. Thanks to Thomas Meckel > - * (Thomas.Meckel@mni.fh-giessen.de) for spotting this. > - * Andy Walker (andy@lysaker.kvaerner.no), May 15, 1996. > - * > - * Changed FL_POSIX locks to use the block list in the same way as FL_FLOCK > - * locks. Changed process synchronisation to avoid dereferencing locks that > - * have already been freed. > - * Andy Walker (andy@lysaker.kvaerner.no), Sep 21, 1996. > - * > - * Made the block list a circular list to minimise searching in the list. > - * Andy Walker (andy@lysaker.kvaerner.no), Sep 25, 1996. > - * > - * Made mandatory locking a mount option. Default is not to allow mandatory > - * locking. > - * Andy Walker (andy@lysaker.kvaerner.no), Oct 04, 1996. > - * > - * Some adaptations for NFS support. > - * Olaf Kirch (okir@monad.swb.de), Dec 1996, > - * > - * Fixed /proc/locks interface so that we can't overrun the buffer we are handed. > - * Andy Walker (andy@lysaker.kvaerner.no), May 12, 1997. > - * > - * Use slab allocator instead of kmalloc/kfree. > - * Use generic list implementation from . > - * Sped up posix_locks_deadlock by only considering blocked locks. > - * Matthew Wilcox , March, 2000. > - * > - * Leases and LOCK_MAND > - * Matthew Wilcox , June, 2000. > - * Stephen Rothwell , June, 2000. > * > * Locking conflicts and dependencies: > * If multiple threads attempt to lock the same byte (or flock the same file) Thanks, Bruce (and Mauro). Applied to the locks-next branch (and I dropped Mauro's patch that touched the same area). It should make v5.16. Cheers, -- Jeff Layton