aboutsummaryrefslogtreecommitdiffstats
path: root/fs/cifs
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2015-04-07 11:28:12 -0400
committerAl Viro <viro@zeniv.linux.org.uk>2015-04-11 22:29:47 -0400
commit5f380c7fa7e01f15ca0816bd241ece9a64a73192 (patch)
tree2136f54098eb85d21d17ee43f73724a5befd70a1 /fs/cifs
parent0b8def9d6dfa6b2a9a2740cf81d8d2c134688d39 (diff)
lift generic_write_checks() into callers of __generic_file_write_iter()
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/cifs')
-rw-r--r--fs/cifs/file.c39
1 files changed, 23 insertions, 16 deletions
diff --git a/fs/cifs/file.c b/fs/cifs/file.c
index 3cb04129ddb1..3c5c9bc5cbaf 100644
--- a/fs/cifs/file.c
+++ b/fs/cifs/file.c
@@ -2673,8 +2673,8 @@ cifs_writev(struct kiocb *iocb, struct iov_iter *from)
2673 struct inode *inode = file->f_mapping->host; 2673 struct inode *inode = file->f_mapping->host;
2674 struct cifsInodeInfo *cinode = CIFS_I(inode); 2674 struct cifsInodeInfo *cinode = CIFS_I(inode);
2675 struct TCP_Server_Info *server = tlink_tcon(cfile->tlink)->ses->server; 2675 struct TCP_Server_Info *server = tlink_tcon(cfile->tlink)->ses->server;
2676 ssize_t rc = -EACCES; 2676 ssize_t rc;
2677 loff_t lock_pos = iocb->ki_pos; 2677 size_t count;
2678 2678
2679 /* 2679 /*
2680 * We need to hold the sem to be sure nobody modifies lock list 2680 * We need to hold the sem to be sure nobody modifies lock list
@@ -2682,23 +2682,30 @@ cifs_writev(struct kiocb *iocb, struct iov_iter *from)
2682 */ 2682 */
2683 down_read(&cinode->lock_sem); 2683 down_read(&cinode->lock_sem);
2684 mutex_lock(&inode->i_mutex); 2684 mutex_lock(&inode->i_mutex);
2685 if (file->f_flags & O_APPEND) 2685
2686 lock_pos = i_size_read(inode); 2686 count = iov_iter_count(from);
2687 if (!cifs_find_lock_conflict(cfile, lock_pos, iov_iter_count(from), 2687 rc = generic_write_checks(file, &iocb->ki_pos, &count, 0);
2688 if (rc)
2689 goto out;
2690
2691 if (count == 0)
2692 goto out;
2693
2694 iov_iter_truncate(from, count);
2695
2696 if (!cifs_find_lock_conflict(cfile, iocb->ki_pos, iov_iter_count(from),
2688 server->vals->exclusive_lock_type, NULL, 2697 server->vals->exclusive_lock_type, NULL,
2689 CIFS_WRITE_OP)) { 2698 CIFS_WRITE_OP))
2690 rc = __generic_file_write_iter(iocb, from); 2699 rc = __generic_file_write_iter(iocb, from);
2691 mutex_unlock(&inode->i_mutex); 2700 else
2692 2701 rc = -EACCES;
2693 if (rc > 0) { 2702out:
2694 ssize_t err; 2703 mutex_unlock(&inode->i_mutex);
2695 2704
2696 err = generic_write_sync(file, iocb->ki_pos - rc, rc); 2705 if (rc > 0) {
2697 if (err < 0) 2706 ssize_t err = generic_write_sync(file, iocb->ki_pos - rc, rc);
2698 rc = err; 2707 if (err < 0)
2699 } 2708 rc = err;
2700 } else {
2701 mutex_unlock(&inode->i_mutex);
2702 } 2709 }
2703 up_read(&cinode->lock_sem); 2710 up_read(&cinode->lock_sem);
2704 return rc; 2711 return rc;