Commit fc50d58f authored by Chuck Lever's avatar Chuck Lever Committed by Trond Myklebust

NFS: Clean-up: Refactor IP address sanity checks in NFS client

NFS and NFSv4 mounts can now share server address sanity checking.  And, it
provides an easy mechanism for adding IPv6 address checking at some later
point.
Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
Cc: Aurelien Charbon <aurelien.charbon@ext.bull.net>
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent 4d81cd16
...@@ -446,6 +446,23 @@ static void nfs_umount_begin(struct vfsmount *vfsmnt, int flags) ...@@ -446,6 +446,23 @@ static void nfs_umount_begin(struct vfsmount *vfsmnt, int flags)
rpc_killall_tasks(rpc); rpc_killall_tasks(rpc);
} }
/*
* Sanity-check a server address provided by the mount command
*/
static int nfs_verify_server_address(struct sockaddr *addr)
{
switch (addr->sa_family) {
case AF_INET: {
struct sockaddr_in *sa = (struct sockaddr_in *) addr;
if (sa->sin_addr.s_addr != INADDR_ANY)
return 1;
break;
}
}
return 0;
}
/* /*
* Validate the NFS2/NFS3 mount data * Validate the NFS2/NFS3 mount data
* - fills in the mount root filehandle * - fills in the mount root filehandle
...@@ -501,7 +518,7 @@ static int nfs_validate_mount_data(struct nfs_mount_data *data, ...@@ -501,7 +518,7 @@ static int nfs_validate_mount_data(struct nfs_mount_data *data,
#endif /* CONFIG_NFS_V3 */ #endif /* CONFIG_NFS_V3 */
/* We now require that the mount process passes the remote address */ /* We now require that the mount process passes the remote address */
if (data->addr.sin_addr.s_addr == INADDR_ANY) { if (!nfs_verify_server_address((struct sockaddr *) &data->addr)) {
dprintk("%s: mount program didn't pass remote address!\n", dprintk("%s: mount program didn't pass remote address!\n",
__FUNCTION__); __FUNCTION__);
return -EINVAL; return -EINVAL;
...@@ -819,13 +836,12 @@ static int nfs4_get_sb(struct file_system_type *fs_type, ...@@ -819,13 +836,12 @@ static int nfs4_get_sb(struct file_system_type *fs_type,
if (copy_from_user(&addr, data->host_addr, sizeof(addr))) if (copy_from_user(&addr, data->host_addr, sizeof(addr)))
return -EFAULT; return -EFAULT;
if (addr.sin_family != AF_INET || if (!nfs_verify_server_address((struct sockaddr *) &addr)) {
addr.sin_addr.s_addr == INADDR_ANY
) {
dprintk("%s: mount program didn't pass remote IP address!\n", dprintk("%s: mount program didn't pass remote IP address!\n",
__FUNCTION__); __FUNCTION__);
return -EINVAL; return -EINVAL;
} }
/* RFC3530: The default port for NFS is 2049 */ /* RFC3530: The default port for NFS is 2049 */
if (addr.sin_port == 0) if (addr.sin_port == 0)
addr.sin_port = htons(NFS_PORT); addr.sin_port = htons(NFS_PORT);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment