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>
Showing
- Documentation/filesystems/Locking 1 addition, 2 deletionsDocumentation/filesystems/Locking
- fs/btrfs/file.c 113 additions, 0 deletionsfs/btrfs/file.c
- fs/btrfs/inode.c 0 additions, 111 deletionsfs/btrfs/inode.c
- fs/ext4/ext4.h 1 addition, 1 deletionfs/ext4/ext4.h
- fs/ext4/extents.c 3 additions, 6 deletionsfs/ext4/extents.c
- fs/ext4/file.c 1 addition, 1 deletionfs/ext4/file.c
- fs/gfs2/file.c 258 additions, 0 deletionsfs/gfs2/file.c
- fs/gfs2/ops_inode.c 0 additions, 258 deletionsfs/gfs2/ops_inode.c
- fs/ocfs2/file.c 3 additions, 5 deletionsfs/ocfs2/file.c
- fs/open.c 2 additions, 2 deletionsfs/open.c
- fs/xfs/linux-2.6/xfs_file.c 56 additions, 0 deletionsfs/xfs/linux-2.6/xfs_file.c
- fs/xfs/linux-2.6/xfs_iops.c 0 additions, 60 deletionsfs/xfs/linux-2.6/xfs_iops.c
- include/linux/fs.h 2 additions, 2 deletionsinclude/linux/fs.h
Loading
Please register or sign in to comment