diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2016-05-17 18:05:23 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-05-17 18:05:23 -0400 |
commit | c2e7b207058d4ff6a9010430763fb561f307eb67 (patch) | |
tree | 8983947c4d62365de3d98113662ff9e643a42a0f /fs/hfs/inode.c | |
parent | c52b76185b7a1b300e5f15ff871c8f45ced3dee9 (diff) | |
parent | 24368aad47dc65b45040d6a31bfd6df1d6f3ec97 (diff) |
Merge branch 'work.preadv2' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull vfs cleanups from Al Viro:
"More cleanups from Christoph"
* 'work.preadv2' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
nfsd: use RWF_SYNC
fs: add RWF_DSYNC aand RWF_SYNC
ceph: use generic_write_sync
fs: simplify the generic_write_sync prototype
fs: add IOCB_SYNC and IOCB_DSYNC
direct-io: remove the offset argument to dio_complete
direct-io: eliminate the offset argument to ->direct_IO
xfs: eliminate the pos variable in xfs_file_dio_aio_write
filemap: remove the pos argument to generic_file_direct_write
filemap: remove pos variables in generic_file_read_iter
Diffstat (limited to 'fs/hfs/inode.c')
-rw-r--r-- | fs/hfs/inode.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/fs/hfs/inode.c b/fs/hfs/inode.c index ba533c79a806..8eed66af5b82 100644 --- a/fs/hfs/inode.c +++ b/fs/hfs/inode.c | |||
@@ -124,8 +124,7 @@ static int hfs_releasepage(struct page *page, gfp_t mask) | |||
124 | return res ? try_to_free_buffers(page) : 0; | 124 | return res ? try_to_free_buffers(page) : 0; |
125 | } | 125 | } |
126 | 126 | ||
127 | static ssize_t hfs_direct_IO(struct kiocb *iocb, struct iov_iter *iter, | 127 | static ssize_t hfs_direct_IO(struct kiocb *iocb, struct iov_iter *iter) |
128 | loff_t offset) | ||
129 | { | 128 | { |
130 | struct file *file = iocb->ki_filp; | 129 | struct file *file = iocb->ki_filp; |
131 | struct address_space *mapping = file->f_mapping; | 130 | struct address_space *mapping = file->f_mapping; |
@@ -133,7 +132,7 @@ static ssize_t hfs_direct_IO(struct kiocb *iocb, struct iov_iter *iter, | |||
133 | size_t count = iov_iter_count(iter); | 132 | size_t count = iov_iter_count(iter); |
134 | ssize_t ret; | 133 | ssize_t ret; |
135 | 134 | ||
136 | ret = blockdev_direct_IO(iocb, inode, iter, offset, hfs_get_block); | 135 | ret = blockdev_direct_IO(iocb, inode, iter, hfs_get_block); |
137 | 136 | ||
138 | /* | 137 | /* |
139 | * In case of error extending write may have instantiated a few | 138 | * In case of error extending write may have instantiated a few |
@@ -141,7 +140,7 @@ static ssize_t hfs_direct_IO(struct kiocb *iocb, struct iov_iter *iter, | |||
141 | */ | 140 | */ |
142 | if (unlikely(iov_iter_rw(iter) == WRITE && ret < 0)) { | 141 | if (unlikely(iov_iter_rw(iter) == WRITE && ret < 0)) { |
143 | loff_t isize = i_size_read(inode); | 142 | loff_t isize = i_size_read(inode); |
144 | loff_t end = offset + count; | 143 | loff_t end = iocb->ki_pos + count; |
145 | 144 | ||
146 | if (end > isize) | 145 | if (end > isize) |
147 | hfs_write_failed(mapping, end); | 146 | hfs_write_failed(mapping, end); |