mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-09 04:10:18 +09:00
NFSv4.2: fix handling of COPY ERR_OFFLOAD_NO_REQ
[ Upstream commit5690eed941] If the client sent a synchronous copy and the server replied with ERR_OFFLOAD_NO_REQ indicating that it wants an asynchronous copy instead, the client should retry with asynchronous copy. Fixes:539f57b3e0("NFS handle COPY ERR_OFFLOAD_NO_REQS") Signed-off-by: Olga Kornievskaia <kolga@netapp.com> Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
fdbc9637bf
commit
4030ace74d
@@ -470,8 +470,9 @@ ssize_t nfs42_proc_copy(struct file *src, loff_t pos_src,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
} else if (err == -NFS4ERR_OFFLOAD_NO_REQS && !args.sync) {
|
} else if (err == -NFS4ERR_OFFLOAD_NO_REQS &&
|
||||||
args.sync = true;
|
args.sync != res.synchronous) {
|
||||||
|
args.sync = res.synchronous;
|
||||||
dst_exception.retry = 1;
|
dst_exception.retry = 1;
|
||||||
continue;
|
continue;
|
||||||
} else if ((err == -ESTALE ||
|
} else if ((err == -ESTALE ||
|
||||||
|
|||||||
Reference in New Issue
Block a user