diff options
author | Christoph Hellwig <hch@infradead.org> | 2012-02-29 04:53:49 -0500 |
---|---|---|
committer | Ben Myers <bpm@sgi.com> | 2012-03-05 12:19:26 -0500 |
commit | 6923e686f19cb7017fc9777a10e06c2e2b2a2936 (patch) | |
tree | 14398306804485fd7c0f04538d76f042f5cec6d9 /fs/xfs | |
parent | aa6bf01d391935a8929333bc2e243084ea0c58db (diff) |
xfs: do not require an ioend for new EOF calculation
Replace xfs_ioend_new_eof with a new inline xfs_new_eof helper that
doesn't require and ioend, and is available also outside of xfs_aops.c.
Also make the code a bit more clear by using a normal if statement
instead of a slightly misleading MIN().
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Mark Tinguely <tinguely@sgi.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Ben Myers <bpm@sgi.com>
Diffstat (limited to 'fs/xfs')
-rw-r--r-- | fs/xfs/xfs_aops.c | 24 | ||||
-rw-r--r-- | fs/xfs/xfs_inode.h | 14 |
2 files changed, 18 insertions, 20 deletions
diff --git a/fs/xfs/xfs_aops.c b/fs/xfs/xfs_aops.c index 540a01742c6d..745492b6c666 100644 --- a/fs/xfs/xfs_aops.c +++ b/fs/xfs/xfs_aops.c | |||
@@ -99,23 +99,6 @@ xfs_destroy_ioend( | |||
99 | } | 99 | } |
100 | 100 | ||
101 | /* | 101 | /* |
102 | * If the end of the current ioend is beyond the current EOF, | ||
103 | * return the new EOF value, otherwise zero. | ||
104 | */ | ||
105 | STATIC xfs_fsize_t | ||
106 | xfs_ioend_new_eof( | ||
107 | xfs_ioend_t *ioend) | ||
108 | { | ||
109 | xfs_inode_t *ip = XFS_I(ioend->io_inode); | ||
110 | xfs_fsize_t isize; | ||
111 | xfs_fsize_t bsize; | ||
112 | |||
113 | bsize = ioend->io_offset + ioend->io_size; | ||
114 | isize = MIN(i_size_read(VFS_I(ip)), bsize); | ||
115 | return isize > ip->i_d.di_size ? isize : 0; | ||
116 | } | ||
117 | |||
118 | /* | ||
119 | * Fast and loose check if this write could update the on-disk inode size. | 102 | * Fast and loose check if this write could update the on-disk inode size. |
120 | */ | 103 | */ |
121 | static inline bool xfs_ioend_is_append(struct xfs_ioend *ioend) | 104 | static inline bool xfs_ioend_is_append(struct xfs_ioend *ioend) |
@@ -135,7 +118,7 @@ xfs_setfilesize( | |||
135 | xfs_fsize_t isize; | 118 | xfs_fsize_t isize; |
136 | 119 | ||
137 | xfs_ilock(ip, XFS_ILOCK_EXCL); | 120 | xfs_ilock(ip, XFS_ILOCK_EXCL); |
138 | isize = xfs_ioend_new_eof(ioend); | 121 | isize = xfs_new_eof(ip, ioend->io_offset + ioend->io_size); |
139 | if (isize) { | 122 | if (isize) { |
140 | trace_xfs_setfilesize(ip, ioend->io_offset, ioend->io_size); | 123 | trace_xfs_setfilesize(ip, ioend->io_offset, ioend->io_size); |
141 | ip->i_d.di_size = isize; | 124 | ip->i_d.di_size = isize; |
@@ -357,6 +340,7 @@ xfs_submit_ioend_bio( | |||
357 | xfs_ioend_t *ioend, | 340 | xfs_ioend_t *ioend, |
358 | struct bio *bio) | 341 | struct bio *bio) |
359 | { | 342 | { |
343 | struct xfs_inode *ip = XFS_I(ioend->io_inode); | ||
360 | atomic_inc(&ioend->io_remaining); | 344 | atomic_inc(&ioend->io_remaining); |
361 | bio->bi_private = ioend; | 345 | bio->bi_private = ioend; |
362 | bio->bi_end_io = xfs_end_bio; | 346 | bio->bi_end_io = xfs_end_bio; |
@@ -365,8 +349,8 @@ xfs_submit_ioend_bio( | |||
365 | * If the I/O is beyond EOF we mark the inode dirty immediately | 349 | * If the I/O is beyond EOF we mark the inode dirty immediately |
366 | * but don't update the inode size until I/O completion. | 350 | * but don't update the inode size until I/O completion. |
367 | */ | 351 | */ |
368 | if (xfs_ioend_new_eof(ioend)) | 352 | if (xfs_new_eof(ip, ioend->io_offset + ioend->io_size)) |
369 | xfs_mark_inode_dirty(XFS_I(ioend->io_inode)); | 353 | xfs_mark_inode_dirty(ip); |
370 | 354 | ||
371 | submit_bio(wbc->sync_mode == WB_SYNC_ALL ? WRITE_SYNC : WRITE, bio); | 355 | submit_bio(wbc->sync_mode == WB_SYNC_ALL ? WRITE_SYNC : WRITE, bio); |
372 | } | 356 | } |
diff --git a/fs/xfs/xfs_inode.h b/fs/xfs/xfs_inode.h index eda493780395..7f90469141d7 100644 --- a/fs/xfs/xfs_inode.h +++ b/fs/xfs/xfs_inode.h | |||
@@ -275,6 +275,20 @@ static inline xfs_fsize_t XFS_ISIZE(struct xfs_inode *ip) | |||
275 | } | 275 | } |
276 | 276 | ||
277 | /* | 277 | /* |
278 | * If this I/O goes past the on-disk inode size update it unless it would | ||
279 | * be past the current in-core inode size. | ||
280 | */ | ||
281 | static inline xfs_fsize_t | ||
282 | xfs_new_eof(struct xfs_inode *ip, xfs_fsize_t new_size) | ||
283 | { | ||
284 | xfs_fsize_t i_size = i_size_read(VFS_I(ip)); | ||
285 | |||
286 | if (new_size > i_size) | ||
287 | new_size = i_size; | ||
288 | return new_size > ip->i_d.di_size ? new_size : 0; | ||
289 | } | ||
290 | |||
291 | /* | ||
278 | * i_flags helper functions | 292 | * i_flags helper functions |
279 | */ | 293 | */ |
280 | static inline void | 294 | static inline void |