diff options
author | Malahal Naineni <malahal@us.ibm.com> | 2011-09-20 20:27:14 -0400 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2011-10-20 19:44:04 -0400 |
commit | 940aab490215424a269f93d2eba2794fc8b3e269 (patch) | |
tree | 6dec5a3d9476fd3c409d7a73040e0eafb1eba756 /fs/nfs/client.c | |
parent | b6ee8cd2642f6d822dd1a4ba62298b65ff99b72e (diff) |
Check validity of cl_rpcclient in nfs_server_list_show
As soon as the nfs_client gets created, its cl_rpcclient is set to
ERR_PTR(-EINVAL). The rpc client structure is allocated later. Check
if the client is ready before using the cl_rpcclient pointer.
Signed-off-by: Malahal Naineni <malahal@us.ibm.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/nfs/client.c')
-rw-r--r-- | fs/nfs/client.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/nfs/client.c b/fs/nfs/client.c index b4e41dd4d0f6..873bf00d51a2 100644 --- a/fs/nfs/client.c +++ b/fs/nfs/client.c | |||
@@ -1868,6 +1868,10 @@ static int nfs_server_list_show(struct seq_file *m, void *v) | |||
1868 | /* display one transport per line on subsequent lines */ | 1868 | /* display one transport per line on subsequent lines */ |
1869 | clp = list_entry(v, struct nfs_client, cl_share_link); | 1869 | clp = list_entry(v, struct nfs_client, cl_share_link); |
1870 | 1870 | ||
1871 | /* Check if the client is initialized */ | ||
1872 | if (clp->cl_cons_state != NFS_CS_READY) | ||
1873 | return 0; | ||
1874 | |||
1871 | seq_printf(m, "v%u %s %s %3d %s\n", | 1875 | seq_printf(m, "v%u %s %s %3d %s\n", |
1872 | clp->rpc_ops->version, | 1876 | clp->rpc_ops->version, |
1873 | rpc_peeraddr2str(clp->cl_rpcclient, RPC_DISPLAY_HEX_ADDR), | 1877 | rpc_peeraddr2str(clp->cl_rpcclient, RPC_DISPLAY_HEX_ADDR), |