Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp610898pxb; Tue, 19 Oct 2021 09:19:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyfcuNleFqF7FedIsETVurOTb8nDdoUDKe059s34dkuO2OkI2KqiomySuktUI+4P0yx6Y4x X-Received: by 2002:a17:906:1146:: with SMTP id i6mr39049819eja.12.1634660387489; Tue, 19 Oct 2021 09:19:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634660387; cv=none; d=google.com; s=arc-20160816; b=Sfk8V/AHLI+8t92WgBsWzOAH0stvE3MSp/r96U7l4xqT7haNPu9sRxtLRxuI/jPGYy AljOPIWa6X0vLFzwgZOGhq3YYx+GkYXyseSutR64eejyHbtXuLpcjI/BmqXgKcDFmKDM 1JNHou0bQWw6PNPd+CDXDscgdH9sqR9Tk4O1naCWOZYyerbGS8Cc/Mtgwq8sxfwNvmxT e0F3xR3Mrx2V9tJoykue6T8I9a4LA82aCAiI1Bn0Z1fMsbnGBlqpmsMs0vqh/tYnFCin yO93ttd5uy3zBT22G9ZBW0re3FY0jfxxtahidgbQatItvnGHty3rQJcOcm7hFbQ5xBYR 5Fng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature:dkim-filter; bh=iEhVIWcUk5jbjVURZb10GpPGdkF+/+N9SWuRL7VGkPA=; b=ro9yEFG7+kYWTCEhbQ983wtIrsVdJzQjz8PYR8B4lG28ta89UKeANgXBqiPLnp9Cp9 P5BFucey2UA7tvoRx+VxAyOyOR088TiKZ9iQkp+Th7LX/lbWD8tF+rkVhjsxaWT7gMX2 KXB4Ih9khk7c/4h0pRiucOLWpwyS56ATISvBrYJ+rifizFTOlrjKMQCz6lDuJ2qVLT38 1FNimEpUfGr3F0Q0mdjrX1J325Lst6RJKD4JRHmxRz2tAN8hAXLmfav+G5aHqihVC+NK 9VB089lK94p+k+ccaYGW/Db24Qtl3M/baqLlG/HpTodNZWHJTxu62E8g6ufxkOFLyKHZ BGGg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fieldses.org header.s=default header.b=OHcrbppT; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j9si20122478edw.49.2021.10.19.09.19.22; Tue, 19 Oct 2021 09:19:47 -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=@fieldses.org header.s=default header.b=OHcrbppT; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231526AbhJSQTF (ORCPT + 99 others); Tue, 19 Oct 2021 12:19:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33712 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229774AbhJSQTF (ORCPT ); Tue, 19 Oct 2021 12:19:05 -0400 Received: from fieldses.org (fieldses.org [IPv6:2600:3c00:e000:2f7::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 59ABCC06161C; Tue, 19 Oct 2021 09:16:52 -0700 (PDT) Received: by fieldses.org (Postfix, from userid 2815) id A273550D7; Tue, 19 Oct 2021 12:16:51 -0400 (EDT) DKIM-Filter: OpenDKIM Filter v2.11.0 fieldses.org A273550D7 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fieldses.org; s=default; t=1634660211; bh=iEhVIWcUk5jbjVURZb10GpPGdkF+/+N9SWuRL7VGkPA=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=OHcrbppTT8sBFsga2bIiVWh+IKVkntFHTZb9KMZ3aWHmm059ItobPz1X18om/f7PU YRu+xMPOaOqjKCAIwFuXzr0avswcgoWdLPJy7aVh51I2zv5KiMZS47RmAQ+8f/kxog oraLP0m0abZ3C6eY1gQZUKVjF2S8lIR++Q/ntHIQ= Date: Tue, 19 Oct 2021 12:16:51 -0400 From: "J. Bruce Fields" To: Jeff Layton Cc: Mauro Carvalho Chehab , Linux Doc Mailing List , Jonathan Corbet , Alexander Viro , linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3 18/23] fs: remove a comment pointing to the removed mandatory-locking file Message-ID: <20211019161651.GD15063@fieldses.org> References: <887de3a1ecadda3dbfe0adf9df9070f0afa9406c.1634630486.git.mchehab+huawei@kernel.org> <20211019141427.GA15063@fieldses.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Oct 19, 2021 at 11:46:51AM -0400, Jeff Layton wrote: > IDK...Do we want to "erase history" selectively like that? Seems like pretty spotty history anyway, so I don't think it's a problem, but... > Maybe we should just get rid of the whole pile of "changelog" comments > in fs/locks.c? They aren't terribly useful these days anyhow. ... that'd be fine with me. I didn't mainly because I thought it'd be good to read through it and see if there's anything that should be salvaged. Reading through it now: The last few paragraphs (under "Locking conflicts and dependencies" were added more recently by Neil and are still useful. I'd be OK losing the rest. It might still be good to have some basic introduction; maybe something like this?: --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)