On Oct 29, 2013, at 9:08 AM, Hellwig Christoph <hch@xxxxxxxxxxxxx> wrote: > On Tue, Oct 29, 2013 at 01:05:44PM +0000, Myklebust, Trond wrote: >> Imagine someone wanting to punch a 50TB hole in NTFS, for instance. It doesn't have real holes, so you'd end up needing to zero out the existing extents in that region of the file. That will take time, even with an O(nr_extents) algorithm. > > That behaviour is not a hole punch, and should not be multiplexed onto > a whole punch on the wire command! If such a use case is important > enough there should be an equivanet of the SCSI WRITE SAME command which > might make some sense to be implemented async. > > We'd surely not support it in the Linux nfsd, though. The current draft spec even allows the client to specify a "pattern" to be written to the "hole". It is mainly there for applications like Oracle, that initialise empty blocks with a non-trivial pattern so that they can do the on-disk equivalent of memory poisoning. By doing it in this way, it allows the more powerful storage arrays to just implement that patterned region as a set of deduplicated blocks instead of actually allocating all the blocks. You can indeed argue that filesystems that don't have holes and/or deduplication should not implement this operation at all, however the functionality is there in case they do... -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html