diff options
author | Christoph Hellwig <hch@lst.de> | 2010-06-04 05:29:58 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2010-08-09 16:47:33 -0400 |
commit | 155130a4f7848b1aac439cab6bda1a175507c71c (patch) | |
tree | 5019b14b0a9221b08959196e01e3f9326957d678 /fs/nilfs2/inode.c | |
parent | 6e1db88d536adcbbfe562b2d4b7d6425784fff12 (diff) |
get rid of block_write_begin_newtrunc
Move the call to vmtruncate to get rid of accessive blocks to the callers
in preparation of the new truncate sequence and rename the non-truncating
version to block_write_begin.
While we're at it also remove several unused arguments to block_write_begin.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/nilfs2/inode.c')
-rw-r--r-- | fs/nilfs2/inode.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c index 1dd9e6a7d787..5c694ece172e 100644 --- a/fs/nilfs2/inode.c +++ b/fs/nilfs2/inode.c | |||
@@ -197,11 +197,15 @@ static int nilfs_write_begin(struct file *file, struct address_space *mapping, | |||
197 | if (unlikely(err)) | 197 | if (unlikely(err)) |
198 | return err; | 198 | return err; |
199 | 199 | ||
200 | *pagep = NULL; | 200 | err = block_write_begin(mapping, pos, len, flags, pagep, |
201 | err = block_write_begin(file, mapping, pos, len, flags, pagep, | 201 | nilfs_get_block); |
202 | fsdata, nilfs_get_block); | 202 | if (unlikely(err)) { |
203 | if (unlikely(err)) | 203 | loff_t isize = mapping->host->i_size; |
204 | if (pos + len > isize) | ||
205 | vmtruncate(mapping->host, isize); | ||
206 | |||
204 | nilfs_transaction_abort(inode->i_sb); | 207 | nilfs_transaction_abort(inode->i_sb); |
208 | } | ||
205 | return err; | 209 | return err; |
206 | } | 210 | } |
207 | 211 | ||