summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSachin Prabhu <sprabhu@redhat.com>2015-02-04 13:10:26 +0000
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2015-04-19 10:10:22 +0200
commit7d57ccdfa65f6aa47b8f9a987869978d13ce2ff4 (patch)
tree10d333f2caccd581fa070bdddefc83910b160415
parentb1ff43a8757d7a57b49231db1713c5ec36477bdf (diff)
downloadlwn-7d57ccdfa65f6aa47b8f9a987869978d13ce2ff4.tar.gz
lwn-7d57ccdfa65f6aa47b8f9a987869978d13ce2ff4.zip
cifs: smb2_clone_range() - exit on unhandled error
commit 2477bc58d49edb1c0baf59df7dc093dce682af2b upstream. While attempting to clone a file on a samba server, we receive a STATUS_INVALID_DEVICE_REQUEST. This is mapped to -EOPNOTSUPP which isn't handled in smb2_clone_range(). We end up looping in the while loop making same call to the samba server over and over again. The proposed fix is to exit and return the error value when encountered with an unhandled error. Signed-off-by: Sachin Prabhu <sprabhu@redhat.com> Signed-off-by: Steve French <steve.french@primarydata.com> Signed-off-by: Steve French <smfrench@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--fs/cifs/smb2ops.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c
index 96b5d40a2ece..eab05e1aa587 100644
--- a/fs/cifs/smb2ops.c
+++ b/fs/cifs/smb2ops.c
@@ -684,7 +684,8 @@ smb2_clone_range(const unsigned int xid,
/* No need to change MaxChunks since already set to 1 */
chunk_sizes_updated = true;
- }
+ } else
+ goto cchunk_out;
}
cchunk_out: