reiserfs: use generic_cont_expand_simple
This patch makes reiserfs to use AOP_FLAG_CONT_EXPAND in order to get rid of the special generic_cont_expand routine Signed-off-by: Vladimir Saveliev <vs@namesys.com> Signed-off-by: Nick Piggin <npiggin@suse.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
ba9d8cec6c
commit
f7557e8f7f
@ -2562,13 +2562,20 @@ static int reiserfs_write_begin(struct file *file,
|
|||||||
int ret;
|
int ret;
|
||||||
int old_ref = 0;
|
int old_ref = 0;
|
||||||
|
|
||||||
|
inode = mapping->host;
|
||||||
|
*fsdata = 0;
|
||||||
|
if (flags & AOP_FLAG_CONT_EXPAND &&
|
||||||
|
(pos & (inode->i_sb->s_blocksize - 1)) == 0) {
|
||||||
|
pos ++;
|
||||||
|
*fsdata = (void *)(unsigned long)flags;
|
||||||
|
}
|
||||||
|
|
||||||
index = pos >> PAGE_CACHE_SHIFT;
|
index = pos >> PAGE_CACHE_SHIFT;
|
||||||
page = __grab_cache_page(mapping, index);
|
page = __grab_cache_page(mapping, index);
|
||||||
if (!page)
|
if (!page)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
*pagep = page;
|
*pagep = page;
|
||||||
|
|
||||||
inode = mapping->host;
|
|
||||||
reiserfs_wait_on_write_block(inode->i_sb);
|
reiserfs_wait_on_write_block(inode->i_sb);
|
||||||
fix_tail_page_for_writing(page);
|
fix_tail_page_for_writing(page);
|
||||||
if (reiserfs_transaction_running(inode->i_sb)) {
|
if (reiserfs_transaction_running(inode->i_sb)) {
|
||||||
@ -2678,6 +2685,8 @@ static int reiserfs_write_end(struct file *file, struct address_space *mapping,
|
|||||||
struct reiserfs_transaction_handle *th;
|
struct reiserfs_transaction_handle *th;
|
||||||
unsigned start;
|
unsigned start;
|
||||||
|
|
||||||
|
if ((unsigned long)fsdata & AOP_FLAG_CONT_EXPAND)
|
||||||
|
pos ++;
|
||||||
|
|
||||||
reiserfs_wait_on_write_block(inode->i_sb);
|
reiserfs_wait_on_write_block(inode->i_sb);
|
||||||
if (reiserfs_transaction_running(inode->i_sb))
|
if (reiserfs_transaction_running(inode->i_sb))
|
||||||
@ -3065,7 +3074,7 @@ int reiserfs_setattr(struct dentry *dentry, struct iattr *attr)
|
|||||||
}
|
}
|
||||||
/* fill in hole pointers in the expanding truncate case. */
|
/* fill in hole pointers in the expanding truncate case. */
|
||||||
if (attr->ia_size > inode->i_size) {
|
if (attr->ia_size > inode->i_size) {
|
||||||
error = generic_cont_expand(inode, attr->ia_size);
|
error = generic_cont_expand_simple(inode, attr->ia_size);
|
||||||
if (REISERFS_I(inode)->i_prealloc_count > 0) {
|
if (REISERFS_I(inode)->i_prealloc_count > 0) {
|
||||||
int err;
|
int err;
|
||||||
struct reiserfs_transaction_handle th;
|
struct reiserfs_transaction_handle th;
|
||||||
|
Loading…
Reference in New Issue
Block a user