aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChuck Lever <chuck.lever@oracle.com>2007-09-24 15:39:50 -0400
committerTrond Myklebust <Trond.Myklebust@netapp.com>2007-10-09 17:18:14 -0400
commit6e88e0618cb1e354a44cc49a996df4dd89511039 (patch)
treee5da37374d186cf3b6bd91ba2349675abe9d0a6d
parent113632d00acb569420b14eb7575833ac7e2eb311 (diff)
NFS: Verify server address before invoking in-kernel mount client
Re-order mount option sanity checking slightly to ensure we have a valid server address *before* trying to do the mountd RPC call. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
-rw-r--r--fs/nfs/super.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/fs/nfs/super.c b/fs/nfs/super.c
index 11ab7ff6e087..13a3ab30b143 100644
--- a/fs/nfs/super.c
+++ b/fs/nfs/super.c
@@ -1100,6 +1100,10 @@ static int nfs_validate_mount_data(void *options,
1100 if (mntfh->size < sizeof(mntfh->data)) 1100 if (mntfh->size < sizeof(mntfh->data))
1101 memset(mntfh->data + mntfh->size, 0, 1101 memset(mntfh->data + mntfh->size, 0,
1102 sizeof(mntfh->data) - mntfh->size); 1102 sizeof(mntfh->data) - mntfh->size);
1103
1104 if (!nfs_verify_server_address((struct sockaddr *) &data->addr))
1105 goto out_no_address;
1106
1103 /* 1107 /*
1104 * Translate to nfs_parsed_mount_data, which nfs_fill_super 1108 * Translate to nfs_parsed_mount_data, which nfs_fill_super
1105 * can deal with. 1109 * can deal with.
@@ -1131,6 +1135,10 @@ static int nfs_validate_mount_data(void *options,
1131 if (nfs_parse_mount_options((char *)options, args) == 0) 1135 if (nfs_parse_mount_options((char *)options, args) == 0)
1132 return -EINVAL; 1136 return -EINVAL;
1133 1137
1138 if (!nfs_verify_server_address((struct sockaddr *)
1139 &args->nfs_server.address))
1140 goto out_no_address;
1141
1134 c = strchr(dev_name, ':'); 1142 c = strchr(dev_name, ':');
1135 if (c == NULL) 1143 if (c == NULL)
1136 return -EINVAL; 1144 return -EINVAL;
@@ -1159,10 +1167,6 @@ static int nfs_validate_mount_data(void *options,
1159 goto out_v3_not_compiled; 1167 goto out_v3_not_compiled;
1160#endif /* !CONFIG_NFS_V3 */ 1168#endif /* !CONFIG_NFS_V3 */
1161 1169
1162 if (!nfs_verify_server_address((struct sockaddr *)
1163 &args->nfs_server.address))
1164 goto out_no_address;
1165
1166 return 0; 1170 return 0;
1167 1171
1168out_no_data: 1172out_no_data: