diff options
-rw-r--r-- | fs/aio.c | 4 | ||||
-rw-r--r-- | fs/btrfs/file.c | 3 | ||||
-rw-r--r-- | fs/cifs/file.c | 3 | ||||
-rw-r--r-- | fs/compat.c | 6 | ||||
-rw-r--r-- | fs/fuse/file.c | 2 | ||||
-rw-r--r-- | fs/ntfs/file.c | 2 | ||||
-rw-r--r-- | fs/ocfs2/file.c | 3 | ||||
-rw-r--r-- | fs/read_write.c | 8 | ||||
-rw-r--r-- | fs/xfs/xfs_file.c | 3 | ||||
-rw-r--r-- | include/linux/fs.h | 14 | ||||
-rw-r--r-- | mm/filemap.c | 2 |
11 files changed, 28 insertions, 22 deletions
@@ -1324,6 +1324,8 @@ static ssize_t aio_rw_vect_retry(struct kiocb *iocb) | |||
1324 | if (iocb->ki_pos < 0) | 1324 | if (iocb->ki_pos < 0) |
1325 | return -EINVAL; | 1325 | return -EINVAL; |
1326 | 1326 | ||
1327 | if (opcode == IOCB_CMD_PWRITEV) | ||
1328 | file_start_write(file); | ||
1327 | do { | 1329 | do { |
1328 | ret = rw_op(iocb, &iocb->ki_iovec[iocb->ki_cur_seg], | 1330 | ret = rw_op(iocb, &iocb->ki_iovec[iocb->ki_cur_seg], |
1329 | iocb->ki_nr_segs - iocb->ki_cur_seg, | 1331 | iocb->ki_nr_segs - iocb->ki_cur_seg, |
@@ -1336,6 +1338,8 @@ static ssize_t aio_rw_vect_retry(struct kiocb *iocb) | |||
1336 | } while (ret > 0 && iocb->ki_left > 0 && | 1338 | } while (ret > 0 && iocb->ki_left > 0 && |
1337 | (opcode == IOCB_CMD_PWRITEV || | 1339 | (opcode == IOCB_CMD_PWRITEV || |
1338 | (!S_ISFIFO(inode->i_mode) && !S_ISSOCK(inode->i_mode)))); | 1340 | (!S_ISFIFO(inode->i_mode) && !S_ISSOCK(inode->i_mode)))); |
1341 | if (opcode == IOCB_CMD_PWRITEV) | ||
1342 | file_end_write(file); | ||
1339 | 1343 | ||
1340 | /* This means we must have transferred all that we could */ | 1344 | /* This means we must have transferred all that we could */ |
1341 | /* No need to retry anymore */ | 1345 | /* No need to retry anymore */ |
diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c index 5b4ea5f55b8f..254aeb72915f 100644 --- a/fs/btrfs/file.c +++ b/fs/btrfs/file.c | |||
@@ -1514,8 +1514,6 @@ static ssize_t btrfs_file_aio_write(struct kiocb *iocb, | |||
1514 | size_t count, ocount; | 1514 | size_t count, ocount; |
1515 | bool sync = (file->f_flags & O_DSYNC) || IS_SYNC(file->f_mapping->host); | 1515 | bool sync = (file->f_flags & O_DSYNC) || IS_SYNC(file->f_mapping->host); |
1516 | 1516 | ||
1517 | sb_start_write(inode->i_sb); | ||
1518 | |||
1519 | mutex_lock(&inode->i_mutex); | 1517 | mutex_lock(&inode->i_mutex); |
1520 | 1518 | ||
1521 | err = generic_segment_checks(iov, &nr_segs, &ocount, VERIFY_READ); | 1519 | err = generic_segment_checks(iov, &nr_segs, &ocount, VERIFY_READ); |
@@ -1617,7 +1615,6 @@ static ssize_t btrfs_file_aio_write(struct kiocb *iocb, | |||
1617 | if (sync) | 1615 | if (sync) |
1618 | atomic_dec(&BTRFS_I(inode)->sync_writers); | 1616 | atomic_dec(&BTRFS_I(inode)->sync_writers); |
1619 | out: | 1617 | out: |
1620 | sb_end_write(inode->i_sb); | ||
1621 | current->backing_dev_info = NULL; | 1618 | current->backing_dev_info = NULL; |
1622 | return num_written ? num_written : err; | 1619 | return num_written ? num_written : err; |
1623 | } | 1620 | } |
diff --git a/fs/cifs/file.c b/fs/cifs/file.c index 7a0dd99e4507..2d4a231dd70b 100644 --- a/fs/cifs/file.c +++ b/fs/cifs/file.c | |||
@@ -2520,8 +2520,6 @@ cifs_writev(struct kiocb *iocb, const struct iovec *iov, | |||
2520 | 2520 | ||
2521 | BUG_ON(iocb->ki_pos != pos); | 2521 | BUG_ON(iocb->ki_pos != pos); |
2522 | 2522 | ||
2523 | sb_start_write(inode->i_sb); | ||
2524 | |||
2525 | /* | 2523 | /* |
2526 | * We need to hold the sem to be sure nobody modifies lock list | 2524 | * We need to hold the sem to be sure nobody modifies lock list |
2527 | * with a brlock that prevents writing. | 2525 | * with a brlock that prevents writing. |
@@ -2545,7 +2543,6 @@ cifs_writev(struct kiocb *iocb, const struct iovec *iov, | |||
2545 | } | 2543 | } |
2546 | 2544 | ||
2547 | up_read(&cinode->lock_sem); | 2545 | up_read(&cinode->lock_sem); |
2548 | sb_end_write(inode->i_sb); | ||
2549 | return rc; | 2546 | return rc; |
2550 | } | 2547 | } |
2551 | 2548 | ||
diff --git a/fs/compat.c b/fs/compat.c index d487985dd0ea..daa3b771d64d 100644 --- a/fs/compat.c +++ b/fs/compat.c | |||
@@ -1103,10 +1103,12 @@ static ssize_t compat_do_readv_writev(int type, struct file *file, | |||
1103 | fnv = file->f_op->aio_write; | 1103 | fnv = file->f_op->aio_write; |
1104 | } | 1104 | } |
1105 | 1105 | ||
1106 | if (fnv) | 1106 | if (fnv) { |
1107 | file_start_write(file); | ||
1107 | ret = do_sync_readv_writev(file, iov, nr_segs, tot_len, | 1108 | ret = do_sync_readv_writev(file, iov, nr_segs, tot_len, |
1108 | pos, fnv); | 1109 | pos, fnv); |
1109 | else | 1110 | file_end_write(file); |
1111 | } else | ||
1110 | ret = do_loop_readv_writev(file, iov, nr_segs, pos, fn); | 1112 | ret = do_loop_readv_writev(file, iov, nr_segs, pos, fn); |
1111 | 1113 | ||
1112 | out: | 1114 | out: |
diff --git a/fs/fuse/file.c b/fs/fuse/file.c index 34b80ba95bad..d15c6f21c17f 100644 --- a/fs/fuse/file.c +++ b/fs/fuse/file.c | |||
@@ -971,7 +971,6 @@ static ssize_t fuse_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
971 | return err; | 971 | return err; |
972 | 972 | ||
973 | count = ocount; | 973 | count = ocount; |
974 | sb_start_write(inode->i_sb); | ||
975 | mutex_lock(&inode->i_mutex); | 974 | mutex_lock(&inode->i_mutex); |
976 | 975 | ||
977 | /* We can write back this queue in page reclaim */ | 976 | /* We can write back this queue in page reclaim */ |
@@ -1030,7 +1029,6 @@ static ssize_t fuse_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
1030 | out: | 1029 | out: |
1031 | current->backing_dev_info = NULL; | 1030 | current->backing_dev_info = NULL; |
1032 | mutex_unlock(&inode->i_mutex); | 1031 | mutex_unlock(&inode->i_mutex); |
1033 | sb_end_write(inode->i_sb); | ||
1034 | 1032 | ||
1035 | return written ? written : err; | 1033 | return written ? written : err; |
1036 | } | 1034 | } |
diff --git a/fs/ntfs/file.c b/fs/ntfs/file.c index 5b2d4f0853ac..1da4b81e6f76 100644 --- a/fs/ntfs/file.c +++ b/fs/ntfs/file.c | |||
@@ -2129,7 +2129,6 @@ static ssize_t ntfs_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
2129 | 2129 | ||
2130 | BUG_ON(iocb->ki_pos != pos); | 2130 | BUG_ON(iocb->ki_pos != pos); |
2131 | 2131 | ||
2132 | sb_start_write(inode->i_sb); | ||
2133 | mutex_lock(&inode->i_mutex); | 2132 | mutex_lock(&inode->i_mutex); |
2134 | ret = ntfs_file_aio_write_nolock(iocb, iov, nr_segs, &iocb->ki_pos); | 2133 | ret = ntfs_file_aio_write_nolock(iocb, iov, nr_segs, &iocb->ki_pos); |
2135 | mutex_unlock(&inode->i_mutex); | 2134 | mutex_unlock(&inode->i_mutex); |
@@ -2138,7 +2137,6 @@ static ssize_t ntfs_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
2138 | if (err < 0) | 2137 | if (err < 0) |
2139 | ret = err; | 2138 | ret = err; |
2140 | } | 2139 | } |
2141 | sb_end_write(inode->i_sb); | ||
2142 | return ret; | 2140 | return ret; |
2143 | } | 2141 | } |
2144 | 2142 | ||
diff --git a/fs/ocfs2/file.c b/fs/ocfs2/file.c index 6474cb44004d..1c93e771e950 100644 --- a/fs/ocfs2/file.c +++ b/fs/ocfs2/file.c | |||
@@ -2248,8 +2248,6 @@ static ssize_t ocfs2_file_aio_write(struct kiocb *iocb, | |||
2248 | if (iocb->ki_left == 0) | 2248 | if (iocb->ki_left == 0) |
2249 | return 0; | 2249 | return 0; |
2250 | 2250 | ||
2251 | sb_start_write(inode->i_sb); | ||
2252 | |||
2253 | appending = file->f_flags & O_APPEND ? 1 : 0; | 2251 | appending = file->f_flags & O_APPEND ? 1 : 0; |
2254 | direct_io = file->f_flags & O_DIRECT ? 1 : 0; | 2252 | direct_io = file->f_flags & O_DIRECT ? 1 : 0; |
2255 | 2253 | ||
@@ -2423,7 +2421,6 @@ out_sems: | |||
2423 | ocfs2_iocb_clear_sem_locked(iocb); | 2421 | ocfs2_iocb_clear_sem_locked(iocb); |
2424 | 2422 | ||
2425 | mutex_unlock(&inode->i_mutex); | 2423 | mutex_unlock(&inode->i_mutex); |
2426 | sb_end_write(inode->i_sb); | ||
2427 | 2424 | ||
2428 | if (written) | 2425 | if (written) |
2429 | ret = written; | 2426 | ret = written; |
diff --git a/fs/read_write.c b/fs/read_write.c index f7b5a23b804b..3e1791a2cfd6 100644 --- a/fs/read_write.c +++ b/fs/read_write.c | |||
@@ -398,6 +398,7 @@ ssize_t do_sync_write(struct file *filp, const char __user *buf, size_t len, lof | |||
398 | struct kiocb kiocb; | 398 | struct kiocb kiocb; |
399 | ssize_t ret; | 399 | ssize_t ret; |
400 | 400 | ||
401 | file_start_write(filp); | ||
401 | init_sync_kiocb(&kiocb, filp); | 402 | init_sync_kiocb(&kiocb, filp); |
402 | kiocb.ki_pos = *ppos; | 403 | kiocb.ki_pos = *ppos; |
403 | kiocb.ki_left = len; | 404 | kiocb.ki_left = len; |
@@ -413,6 +414,7 @@ ssize_t do_sync_write(struct file *filp, const char __user *buf, size_t len, lof | |||
413 | if (-EIOCBQUEUED == ret) | 414 | if (-EIOCBQUEUED == ret) |
414 | ret = wait_on_sync_kiocb(&kiocb); | 415 | ret = wait_on_sync_kiocb(&kiocb); |
415 | *ppos = kiocb.ki_pos; | 416 | *ppos = kiocb.ki_pos; |
417 | file_end_write(filp); | ||
416 | return ret; | 418 | return ret; |
417 | } | 419 | } |
418 | 420 | ||
@@ -758,10 +760,12 @@ static ssize_t do_readv_writev(int type, struct file *file, | |||
758 | fnv = file->f_op->aio_write; | 760 | fnv = file->f_op->aio_write; |
759 | } | 761 | } |
760 | 762 | ||
761 | if (fnv) | 763 | if (fnv) { |
764 | file_start_write(file); | ||
762 | ret = do_sync_readv_writev(file, iov, nr_segs, tot_len, | 765 | ret = do_sync_readv_writev(file, iov, nr_segs, tot_len, |
763 | pos, fnv); | 766 | pos, fnv); |
764 | else | 767 | file_end_write(file); |
768 | } else | ||
765 | ret = do_loop_readv_writev(file, iov, nr_segs, pos, fn); | 769 | ret = do_loop_readv_writev(file, iov, nr_segs, pos, fn); |
766 | 770 | ||
767 | out: | 771 | out: |
diff --git a/fs/xfs/xfs_file.c b/fs/xfs/xfs_file.c index f03bf1a456fb..3800128d2171 100644 --- a/fs/xfs/xfs_file.c +++ b/fs/xfs/xfs_file.c | |||
@@ -775,8 +775,6 @@ xfs_file_aio_write( | |||
775 | if (ocount == 0) | 775 | if (ocount == 0) |
776 | return 0; | 776 | return 0; |
777 | 777 | ||
778 | sb_start_write(inode->i_sb); | ||
779 | |||
780 | if (XFS_FORCED_SHUTDOWN(ip->i_mount)) { | 778 | if (XFS_FORCED_SHUTDOWN(ip->i_mount)) { |
781 | ret = -EIO; | 779 | ret = -EIO; |
782 | goto out; | 780 | goto out; |
@@ -800,7 +798,6 @@ xfs_file_aio_write( | |||
800 | } | 798 | } |
801 | 799 | ||
802 | out: | 800 | out: |
803 | sb_end_write(inode->i_sb); | ||
804 | return ret; | 801 | return ret; |
805 | } | 802 | } |
806 | 803 | ||
diff --git a/include/linux/fs.h b/include/linux/fs.h index 2c28271ab9d4..578a66e6ee72 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
@@ -2223,6 +2223,20 @@ static inline struct inode *file_inode(struct file *f) | |||
2223 | return f->f_inode; | 2223 | return f->f_inode; |
2224 | } | 2224 | } |
2225 | 2225 | ||
2226 | static inline void file_start_write(struct file *file) | ||
2227 | { | ||
2228 | if (!S_ISREG(file_inode(file)->i_mode)) | ||
2229 | return; | ||
2230 | __sb_start_write(file_inode(file)->i_sb, SB_FREEZE_WRITE, true); | ||
2231 | } | ||
2232 | |||
2233 | static inline void file_end_write(struct file *file) | ||
2234 | { | ||
2235 | if (!S_ISREG(file_inode(file)->i_mode)) | ||
2236 | return; | ||
2237 | __sb_end_write(file_inode(file)->i_sb, SB_FREEZE_WRITE); | ||
2238 | } | ||
2239 | |||
2226 | /* | 2240 | /* |
2227 | * get_write_access() gets write permission for a file. | 2241 | * get_write_access() gets write permission for a file. |
2228 | * put_write_access() releases this write permission. | 2242 | * put_write_access() releases this write permission. |
diff --git a/mm/filemap.c b/mm/filemap.c index e1979fdca805..cbde8842a374 100644 --- a/mm/filemap.c +++ b/mm/filemap.c | |||
@@ -2528,7 +2528,6 @@ ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
2528 | 2528 | ||
2529 | BUG_ON(iocb->ki_pos != pos); | 2529 | BUG_ON(iocb->ki_pos != pos); |
2530 | 2530 | ||
2531 | sb_start_write(inode->i_sb); | ||
2532 | mutex_lock(&inode->i_mutex); | 2531 | mutex_lock(&inode->i_mutex); |
2533 | ret = __generic_file_aio_write(iocb, iov, nr_segs, &iocb->ki_pos); | 2532 | ret = __generic_file_aio_write(iocb, iov, nr_segs, &iocb->ki_pos); |
2534 | mutex_unlock(&inode->i_mutex); | 2533 | mutex_unlock(&inode->i_mutex); |
@@ -2540,7 +2539,6 @@ ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | |||
2540 | if (err < 0 && ret > 0) | 2539 | if (err < 0 && ret > 0) |
2541 | ret = err; | 2540 | ret = err; |
2542 | } | 2541 | } |
2543 | sb_end_write(inode->i_sb); | ||
2544 | return ret; | 2542 | return ret; |
2545 | } | 2543 | } |
2546 | EXPORT_SYMBOL(generic_file_aio_write); | 2544 | EXPORT_SYMBOL(generic_file_aio_write); |