diff options
Diffstat (limited to 'fs/udf/inode.c')
| -rw-r--r-- | fs/udf/inode.c | 9 | 
1 files changed, 4 insertions, 5 deletions
diff --git a/fs/udf/inode.c b/fs/udf/inode.c index 1d6b7a50736b..ea8f6cd01f50 100644 --- a/fs/udf/inode.c +++ b/fs/udf/inode.c @@ -258,10 +258,6 @@ int udf_expand_file_adinicb(struct inode *inode)  	char *kaddr;  	struct udf_inode_info *iinfo = UDF_I(inode);  	int err; -	struct writeback_control udf_wbc = { -		.sync_mode = WB_SYNC_NONE, -		.nr_to_write = 1, -	};  	WARN_ON_ONCE(!inode_is_locked(inode));  	if (!iinfo->i_lenAlloc) { @@ -305,8 +301,10 @@ int udf_expand_file_adinicb(struct inode *inode)  		iinfo->i_alloc_type = ICBTAG_FLAG_AD_LONG;  	/* from now on we have normal address_space methods */  	inode->i_data.a_ops = &udf_aops; +	set_page_dirty(page); +	unlock_page(page);  	up_write(&iinfo->i_data_sem); -	err = inode->i_data.a_ops->writepage(page, &udf_wbc); +	err = filemap_fdatawrite(inode->i_mapping);  	if (err) {  		/* Restore everything back so that we don't lose data... */  		lock_page(page); @@ -317,6 +315,7 @@ int udf_expand_file_adinicb(struct inode *inode)  		unlock_page(page);  		iinfo->i_alloc_type = ICBTAG_FLAG_AD_IN_ICB;  		inode->i_data.a_ops = &udf_adinicb_aops; +		iinfo->i_lenAlloc = inode->i_size;  		up_write(&iinfo->i_data_sem);  	}  	put_page(page);  | 
