diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2015-04-07 11:28:12 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2015-04-11 22:29:47 -0400 |
commit | 5f380c7fa7e01f15ca0816bd241ece9a64a73192 (patch) | |
tree | 2136f54098eb85d21d17ee43f73724a5befd70a1 /fs/cifs | |
parent | 0b8def9d6dfa6b2a9a2740cf81d8d2c134688d39 (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.c | 39 |
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) { | 2702 | out: |
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; |