Christoph Hellwig 2fe17c1075 fallocate should be a file operation
Currently all filesystems except XFS implement fallocate asynchronously,
while XFS forced a commit.  Both of these are suboptimal - in case of O_SYNC
I/O we really want our allocation on disk, especially for the !KEEP_SIZE
case where we actually grow the file with user-visible zeroes.  On the
other hand always commiting the transaction is a bad idea for fast-path
uses of fallocate like for example in recent Samba versions.   Given
that block allocation is a data plane operation anyway change it from
an inode operation to a file operation so that we have the file structure
available that lets us check for O_SYNC.

This also includes moving the code around for a few of the filesystems,
and remove the already unnedded S_ISDIR checks given that we only wire
up fallocate for regular files.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
2011-01-17 02:25:31 -05:00
..
2010-10-25 21:18:20 -04:00
2010-09-20 11:18:16 +01:00
2010-09-20 11:21:09 +01:00
2010-09-20 11:21:09 +01:00
2011-01-12 20:02:46 -05:00
2011-01-17 02:25:31 -05:00
2008-06-27 09:39:44 +01:00
2011-01-10 08:51:44 -08:00
2010-09-20 11:18:46 +01:00
2010-05-21 16:11:36 +01:00
2010-05-05 09:39:18 +01:00
2008-03-31 10:39:54 +01:00
2009-08-26 18:51:04 +01:00
2010-09-29 14:20:52 +01:00
2011-01-07 17:50:26 +11:00
2010-05-21 18:31:20 -04:00
2009-01-05 07:39:13 +00:00
2010-05-05 09:39:18 +01:00
2010-03-01 14:07:37 +00:00
2010-11-30 10:30:19 +00:00
2009-12-16 12:16:49 -05:00