From: Sachin Prabhu Date: Wed, 4 Feb 2015 13:10:26 +0000 (+0000) Subject: cifs: smb2_clone_range() - exit on unhandled error X-Git-Tag: v3.16.35~2366 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=c2838c9de591f1bc05a8d3f4fdc84576e42ab3a5;p=thirdparty%2Fkernel%2Fstable.git 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 Signed-off-by: Steve French Signed-off-by: Steve French Signed-off-by: Luis Henriques --- diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c index f325c59e12e68..772ee0ecf32aa 100644 --- a/fs/cifs/smb2ops.c +++ b/fs/cifs/smb2ops.c @@ -630,7 +630,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: