Commit 6738b251 authored by Chuck Lever's avatar Chuck Lever Committed by Trond Myklebust

NFS4: Set security flavor default for NFSv4 mounts like other defaults

Set the default security flavor when we set the other mount option
default values for NFSv4.  This cleans up the NFSv4 mount option parsing
path to look like the NFSv2/v3 one.
Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent dd07c947
...@@ -2125,6 +2125,8 @@ static int nfs4_validate_mount_data(void *options, ...@@ -2125,6 +2125,8 @@ static int nfs4_validate_mount_data(void *options,
args->acdirmin = NFS_DEF_ACDIRMIN; args->acdirmin = NFS_DEF_ACDIRMIN;
args->acdirmax = NFS_DEF_ACDIRMAX; args->acdirmax = NFS_DEF_ACDIRMAX;
args->nfs_server.port = NFS_PORT; /* 2049 unless user set port= */ args->nfs_server.port = NFS_PORT; /* 2049 unless user set port= */
args->auth_flavors[0] = RPC_AUTH_UNIX;
args->auth_flavor_len = 0;
switch (data->version) { switch (data->version) {
case 1: case 1:
...@@ -2140,18 +2142,13 @@ static int nfs4_validate_mount_data(void *options, ...@@ -2140,18 +2142,13 @@ static int nfs4_validate_mount_data(void *options,
&args->nfs_server.address)) &args->nfs_server.address))
goto out_no_address; goto out_no_address;
switch (data->auth_flavourlen) { if (data->auth_flavourlen) {
case 0: if (data->auth_flavourlen > 1)
args->auth_flavors[0] = RPC_AUTH_UNIX; goto out_inval_auth;
break;
case 1:
if (copy_from_user(&args->auth_flavors[0], if (copy_from_user(&args->auth_flavors[0],
data->auth_flavours, data->auth_flavours,
sizeof(args->auth_flavors[0]))) sizeof(args->auth_flavors[0])))
return -EFAULT; return -EFAULT;
break;
default:
goto out_inval_auth;
} }
c = strndup_user(data->hostname.data, NFS4_MAXNAMLEN); c = strndup_user(data->hostname.data, NFS4_MAXNAMLEN);
...@@ -2203,15 +2200,8 @@ static int nfs4_validate_mount_data(void *options, ...@@ -2203,15 +2200,8 @@ static int nfs4_validate_mount_data(void *options,
nfs_validate_transport_protocol(args); nfs_validate_transport_protocol(args);
switch (args->auth_flavor_len) { if (args->auth_flavor_len > 1)
case 0:
args->auth_flavors[0] = RPC_AUTH_UNIX;
break;
case 1:
break;
default:
goto out_inval_auth; goto out_inval_auth;
}
if (args->client_address == NULL) if (args->client_address == NULL)
goto out_no_client_address; goto out_no_client_address;
......
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