Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1765461AbXF1S2O (ORCPT ); Thu, 28 Jun 2007 14:28:14 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1765492AbXF1S1v (ORCPT ); Thu, 28 Jun 2007 14:27:51 -0400 Received: from e33.co.us.ibm.com ([32.97.110.151]:42099 "EHLO e33.co.us.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1765481AbXF1S1s (ORCPT ); Thu, 28 Jun 2007 14:27:48 -0400 Date: Thu, 28 Jun 2007 23:49:13 +0530 From: "Amit K. Arora" To: David Chinner Cc: linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-ext4@vger.kernel.org, suparna@in.ibm.com, cmm@us.ibm.com, xfs@oss.sgi.com Subject: Re: [PATCH 4/7][TAKE5] support new modes in fallocate Message-ID: <20070628181913.GC1674@amitarora.in.ibm.com> References: <20070614091458.GH5181@schatzie.adilger.int> <20070614120413.GD86004887@sgi.com> <20070614193347.GN5181@schatzie.adilger.int> <20070625132810.GA1951@amitarora.in.ibm.com> <20070625134500.GE1951@amitarora.in.ibm.com> <20070625150320.GA8686@amitarora.in.ibm.com> <20070625214626.GJ5181@schatzie.adilger.int> <20070626103247.GA19870@amitarora.in.ibm.com> <20070626153413.GC6652@schatzie.adilger.int> <20070626231803.GQ31489@sgi.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20070626231803.GQ31489@sgi.com> User-Agent: Mutt/1.4.1i Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2208 Lines: 44 On Wed, Jun 27, 2007 at 09:18:04AM +1000, David Chinner wrote: > On Tue, Jun 26, 2007 at 11:34:13AM -0400, Andreas Dilger wrote: > > On Jun 26, 2007 16:02 +0530, Amit K. Arora wrote: > > > On Mon, Jun 25, 2007 at 03:46:26PM -0600, Andreas Dilger wrote: > > > > Can you clarify - what is the current behaviour when ENOSPC (or some other > > > > error) is hit? Does it keep the current fallocate() or does it free it? > > > > > > Currently it is left on the file system implementation. In ext4, we do > > > not undo preallocation if some error (say, ENOSPC) is hit. Hence it may > > > end up with partial (pre)allocation. This is inline with dd and > > > posix_fallocate, which also do not free the partially allocated space. > > > > Since I believe the XFS allocation ioctls do it the opposite way (free > > preallocated space on error) this should be encoded into the flags. > > Having it "filesystem dependent" just means that nobody will be happy. > > No, XFs does not free preallocated space on error. it is up to the > application to clean up. Since XFS also does not free preallocated space on error and this behavior is inline with dd, posix_fallocate() and the current ext4 implementation, do we still need FA_FL_FREE_ENOSPC flag ? > > What I mean is that any data read from the file should have the "appearance" > > of being zeroed (whether zeroes are actually written to disk or not). What > > I _think_ David is proposing is to allow fallocate() to return without > > marking the blocks even "uninitialized" and subsequent reads would return > > the old data from the disk. > > Correct, but for swap files that's not an issue - no user should be able > too read them, and FA_MKSWAP would really need root privileges to execute. Will the FA_MKSWAP mode still be required with your suggested change of teaching do_mpage_readpage() about unwritten extents being in place ? Or, will you still like to have FA_MKSWAP mode ? -- Regards, Amit Arora - 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/