aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext4/ext4.h
diff options
context:
space:
mode:
authorAllison Henderson <achender@linux.vnet.ibm.com>2011-05-25 07:41:50 -0400
committerTheodore Ts'o <tytso@mit.edu>2011-05-25 07:41:50 -0400
commita4bb6b64e39abc0e41ca077725f2a72c868e7622 (patch)
tree0d911caa13d445d64cce5ea37f424bf066731ea6 /fs/ext4/ext4.h
parente861304b8ed83fe43e36d46794d72641c82d4636 (diff)
ext4: enable "punch hole" functionality
This patch adds new routines: "ext4_punch_hole" "ext4_ext_punch_hole" and "ext4_ext_check_cache" fallocate has been modified to call ext4_punch_hole when the punch hole flag is passed. At the moment, we only support punching holes in extents, so this routine is pretty much a wrapper for the ext4_ext_punch_hole routine. The ext4_ext_punch_hole routine first completes all outstanding writes with the associated pages, and then releases them. The unblock aligned data is zeroed, and all blocks in between are punched out. The ext4_ext_check_cache routine is very similar to ext4_ext_in_cache except it accepts a ext4_ext_cache parameter instead of a ext4_extent parameter. This routine is used by ext4_ext_punch_hole to check and see if a block in a hole that has been cached. The ext4_ext_cache parameter is necessary because the members ext4_extent structure are not large enough to hold a 32 bit value. The existing ext4_ext_in_cache routine has become a wrapper to this new function. [ext4 punch hole patch series 5/5 v7] Signed-off-by: Allison Henderson <achender@us.ibm.com> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu> Reviewed-by: Mingming Cao <cmm@us.ibm.com>
Diffstat (limited to 'fs/ext4/ext4.h')
-rw-r--r--fs/ext4/ext4.h3
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/ext4/ext4.h b/fs/ext4/ext4.h
index c48f9db5b96b..7bc7c724805d 100644
--- a/fs/ext4/ext4.h
+++ b/fs/ext4/ext4.h
@@ -1816,6 +1816,7 @@ extern int ext4_change_inode_journal_flag(struct inode *, int);
1816extern int ext4_get_inode_loc(struct inode *, struct ext4_iloc *); 1816extern int ext4_get_inode_loc(struct inode *, struct ext4_iloc *);
1817extern int ext4_can_truncate(struct inode *inode); 1817extern int ext4_can_truncate(struct inode *inode);
1818extern void ext4_truncate(struct inode *); 1818extern void ext4_truncate(struct inode *);
1819extern int ext4_punch_hole(struct file *file, loff_t offset, loff_t length);
1819extern int ext4_truncate_restart_trans(handle_t *, struct inode *, int nblocks); 1820extern int ext4_truncate_restart_trans(handle_t *, struct inode *, int nblocks);
1820extern void ext4_set_inode_flags(struct inode *); 1821extern void ext4_set_inode_flags(struct inode *);
1821extern void ext4_get_inode_flags(struct ext4_inode_info *); 1822extern void ext4_get_inode_flags(struct ext4_inode_info *);
@@ -2157,6 +2158,8 @@ extern int ext4_ext_index_trans_blocks(struct inode *inode, int nrblocks,
2157extern int ext4_ext_map_blocks(handle_t *handle, struct inode *inode, 2158extern int ext4_ext_map_blocks(handle_t *handle, struct inode *inode,
2158 struct ext4_map_blocks *map, int flags); 2159 struct ext4_map_blocks *map, int flags);
2159extern void ext4_ext_truncate(struct inode *); 2160extern void ext4_ext_truncate(struct inode *);
2161extern int ext4_ext_punch_hole(struct file *file, loff_t offset,
2162 loff_t length);
2160extern void ext4_ext_init(struct super_block *); 2163extern void ext4_ext_init(struct super_block *);
2161extern void ext4_ext_release(struct super_block *); 2164extern void ext4_ext_release(struct super_block *);
2162extern long ext4_fallocate(struct file *file, int mode, loff_t offset, 2165extern long ext4_fallocate(struct file *file, int mode, loff_t offset,