diff options
| author | Trond Myklebust <trond.myklebust@hammerspace.com> | 2020-12-10 09:34:34 -0500 | 
|---|---|---|
| committer | Trond Myklebust <trond.myklebust@hammerspace.com> | 2020-12-14 06:51:08 -0500 | 
| commit | 5c3485bb12c90945f86d6b1c901bbe76aa8b45c9 (patch) | |
| tree | fbcacff4bd0fcc1d048b39c3de6ffa3b1e8132fc | |
| parent | 7aedc687c9f62e0d22b3231a100030e02344be1a (diff) | |
NFSv4.2/pnfs: Don't use READ_PLUS with pNFS yet
We have no way of tracking server READ_PLUS support in pNFS for now, so
just disable it.
Reported-by: "Mkrtchyan, Tigran" <tigran.mkrtchyan@desy.de>
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
| -rw-r--r-- | fs/nfs/nfs4proc.c | 15 | 
1 files changed, 8 insertions, 7 deletions
| diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index 7ab40d0e6a74..61a07dcb963d 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c @@ -5320,17 +5320,17 @@ static int nfs4_read_done(struct rpc_task *task, struct nfs_pgio_header *hdr)  }  #ifdef CONFIG_NFS_V4_2 -static void nfs42_read_plus_support(struct nfs_server *server, struct rpc_message *msg) +static void nfs42_read_plus_support(struct nfs_pgio_header *hdr, +				    struct rpc_message *msg)  { -	if (server->caps & NFS_CAP_READ_PLUS) +	/* Note: We don't use READ_PLUS with pNFS yet */ +	if (nfs_server_capable(hdr->inode, NFS_CAP_READ_PLUS) && !hdr->ds_clp)  		msg->rpc_proc = &nfs4_procedures[NFSPROC4_CLNT_READ_PLUS]; -	else -		msg->rpc_proc = &nfs4_procedures[NFSPROC4_CLNT_READ];  }  #else -static void nfs42_read_plus_support(struct nfs_server *server, struct rpc_message *msg) +static void nfs42_read_plus_support(struct nfs_pgio_header *hdr, +				    struct rpc_message *msg)  { -	msg->rpc_proc = &nfs4_procedures[NFSPROC4_CLNT_READ];  }  #endif /* CONFIG_NFS_V4_2 */ @@ -5340,7 +5340,8 @@ static void nfs4_proc_read_setup(struct nfs_pgio_header *hdr,  	hdr->timestamp   = jiffies;  	if (!hdr->pgio_done_cb)  		hdr->pgio_done_cb = nfs4_read_done_cb; -	nfs42_read_plus_support(NFS_SERVER(hdr->inode), msg); +	msg->rpc_proc = &nfs4_procedures[NFSPROC4_CLNT_READ]; +	nfs42_read_plus_support(hdr, msg);  	nfs4_init_sequence(&hdr->args.seq_args, &hdr->res.seq_res, 0, 0);  } | 
