diff options
author | Dave Chinner <david@fromorbit.com> | 2014-02-19 23:16:39 -0500 |
---|---|---|
committer | Dave Chinner <david@fromorbit.com> | 2014-02-19 23:16:39 -0500 |
commit | 027f185e66eb24e2ea291ff3b93c1e4bd07b85b4 (patch) | |
tree | 6ec052f37d2a0574c4fdf1dc9044982db4d40a8a /fs/xfs | |
parent | b678573e29749e7fe884c3a8e61c1cf1e1093987 (diff) | |
parent | 9862f62faba8c279ac07415a6f610041116fbdc0 (diff) |
Merge remote-tracking branch 'xfs-async-aio-extend' into for-next
Diffstat (limited to 'fs/xfs')
-rw-r--r-- | fs/xfs/xfs_aops.c | 3 | ||||
-rw-r--r-- | fs/xfs/xfs_iomap.c | 10 |
2 files changed, 5 insertions, 8 deletions
diff --git a/fs/xfs/xfs_aops.c b/fs/xfs/xfs_aops.c index db2cfb067d0b..ef62c6b6130a 100644 --- a/fs/xfs/xfs_aops.c +++ b/fs/xfs/xfs_aops.c | |||
@@ -1441,7 +1441,8 @@ xfs_vm_direct_IO( | |||
1441 | ret = __blockdev_direct_IO(rw, iocb, inode, bdev, iov, | 1441 | ret = __blockdev_direct_IO(rw, iocb, inode, bdev, iov, |
1442 | offset, nr_segs, | 1442 | offset, nr_segs, |
1443 | xfs_get_blocks_direct, | 1443 | xfs_get_blocks_direct, |
1444 | xfs_end_io_direct_write, NULL, 0); | 1444 | xfs_end_io_direct_write, NULL, |
1445 | DIO_ASYNC_EXTEND); | ||
1445 | if (ret != -EIOCBQUEUED && iocb->private) | 1446 | if (ret != -EIOCBQUEUED && iocb->private) |
1446 | goto out_destroy_ioend; | 1447 | goto out_destroy_ioend; |
1447 | } else { | 1448 | } else { |
diff --git a/fs/xfs/xfs_iomap.c b/fs/xfs/xfs_iomap.c index 22d1cbea283d..3b80ebae05f5 100644 --- a/fs/xfs/xfs_iomap.c +++ b/fs/xfs/xfs_iomap.c | |||
@@ -128,7 +128,6 @@ xfs_iomap_write_direct( | |||
128 | xfs_fsblock_t firstfsb; | 128 | xfs_fsblock_t firstfsb; |
129 | xfs_extlen_t extsz, temp; | 129 | xfs_extlen_t extsz, temp; |
130 | int nimaps; | 130 | int nimaps; |
131 | int bmapi_flag; | ||
132 | int quota_flag; | 131 | int quota_flag; |
133 | int rt; | 132 | int rt; |
134 | xfs_trans_t *tp; | 133 | xfs_trans_t *tp; |
@@ -200,18 +199,15 @@ xfs_iomap_write_direct( | |||
200 | 199 | ||
201 | xfs_trans_ijoin(tp, ip, 0); | 200 | xfs_trans_ijoin(tp, ip, 0); |
202 | 201 | ||
203 | bmapi_flag = 0; | ||
204 | if (offset < XFS_ISIZE(ip) || extsz) | ||
205 | bmapi_flag |= XFS_BMAPI_PREALLOC; | ||
206 | |||
207 | /* | 202 | /* |
208 | * From this point onwards we overwrite the imap pointer that the | 203 | * From this point onwards we overwrite the imap pointer that the |
209 | * caller gave to us. | 204 | * caller gave to us. |
210 | */ | 205 | */ |
211 | xfs_bmap_init(&free_list, &firstfsb); | 206 | xfs_bmap_init(&free_list, &firstfsb); |
212 | nimaps = 1; | 207 | nimaps = 1; |
213 | error = xfs_bmapi_write(tp, ip, offset_fsb, count_fsb, bmapi_flag, | 208 | error = xfs_bmapi_write(tp, ip, offset_fsb, count_fsb, |
214 | &firstfsb, 0, imap, &nimaps, &free_list); | 209 | XFS_BMAPI_PREALLOC, &firstfsb, 0, |
210 | imap, &nimaps, &free_list); | ||
215 | if (error) | 211 | if (error) |
216 | goto out_bmap_cancel; | 212 | goto out_bmap_cancel; |
217 | 213 | ||