From: Matthew Wilcox Subject: Re: [PATCH v2] fs: Convert return type int to vm_fault_t Date: Mon, 3 Sep 2018 19:13:55 -0700 Message-ID: <20180904021355.GA17153@bombadil.infradead.org> References: <20180830172547.GA4408@jordon-HP-15-Notebook-PC> <20180830163352.5a96cc721ce069bed95fdbe8@linux-foundation.org> <20180903172843.9bf312c738ce8a434dd9c242@linux-foundation.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: Souptick Joarder , Ryusuke Konishi , Al Viro , Theodore Ts'o , adilger.kernel@dilger.ca, Jens Axboe , "Darrick J. Wong" , Eric Biggers , Philippe Ombredanne , Andreas Gruenbacher , Greg KH , kemi.wang@intel.com, linux-fsdevel , linux-kernel@vger.kernel.org, linux-ext4@vger.kernel.org, linux-nilfs To: Andrew Morton Return-path: Content-Disposition: inline In-Reply-To: <20180903172843.9bf312c738ce8a434dd9c242@linux-foundation.org> Sender: linux-kernel-owner@vger.kernel.org List-Id: linux-ext4.vger.kernel.org On Mon, Sep 03, 2018 at 05:28:43PM -0700, Andrew Morton wrote: > > > I'm beginning to feel vm_fault_t exhaustion. Please remind me what > > > benefit we're going to get out of all this churn? Hi Andrew, The primary benefit is to help driver writers. At the moment, there is nothing to stop them returning -ENOMEM instead of VM_FAULT_NOMEM. There were one or two examples of this in the tree, but I think they're all gone now. Secondarily, there are a number of places which translate between error codes and vm_fault codes. Those places are reduced as a result of these patches, if not entirely eliminated yet. There was some pretty extreme cargo-culting of errno to vm_fault switch statements, particularly in the DRM drivers. There were also several places which were just ignoring the return value of vm_insert_foo(), and as a result of this audit, those have been fixed. Those errors are going to be rare, but can cause inappropriate decisions to be made by the OOM killer. Now that I think about it, vmf_insert_foo() should probably get marked with __must_check to prevent those kinds of errors from being introduced again.