summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChuck Lever <chuck.lever@oracle.com>2009-09-29 10:37:12 -0400
committerSteve Dickson <steved@redhat.com>2009-09-29 10:37:12 -0400
commit3faa54e8a17411de28c7b707207d49b4466ae873 (patch)
tree8c89eb0169e7cdc044b13e0c44f8380b9638ec11
parent88c4f664f869d7450b84f0262fd87fbda4f1f61b (diff)
downloadnfs-utils-3faa54e8a17411de28c7b707207d49b4466ae873.tar.gz
nfs-utils-3faa54e8a17411de28c7b707207d49b4466ae873.tar.xz
nfs-utils-3faa54e8a17411de28c7b707207d49b4466ae873.zip
mount.nfs: Keep server's address in nfsmount_info
We want to pass the server's address around. Put it in the mount context structure. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Steve Dickson <steved@redhat.com>
-rw-r--r--utils/mount/stropts.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/utils/mount/stropts.c b/utils/mount/stropts.c
index 3eb661e..76bbefd 100644
--- a/utils/mount/stropts.c
+++ b/utils/mount/stropts.c
@@ -80,6 +80,8 @@ struct nfsmount_info {
*node, /* mounted-on dir */
*type; /* "nfs" or "nfs4" */
char *hostname; /* server's hostname */
+ struct sockaddr_storage address; /* server's address */
+ socklen_t salen; /* size of server's address */
struct mount_options *options; /* parsed mount options */
char **extra_opts; /* string for /etc/mtab */
@@ -263,14 +265,13 @@ static int nfs_append_sloppy_option(struct mount_options *options)
*/
static int nfs_validate_options(struct nfsmount_info *mi)
{
- struct sockaddr_storage dummy;
- struct sockaddr *sap = (struct sockaddr *)&dummy;
- socklen_t salen = sizeof(dummy);
+ struct sockaddr *sap = (struct sockaddr *)&mi->address;
if (!nfs_parse_devname(mi->spec, &mi->hostname, NULL))
return 0;
- if (!nfs_name_to_address(mi->hostname, sap, &salen))
+ mi->salen = sizeof(mi->address);
+ if (!nfs_name_to_address(mi->hostname, sap, &mi->salen))
return 0;
if (!nfs_nfs_version(mi->options, &mi->version))
@@ -279,7 +280,7 @@ static int nfs_validate_options(struct nfsmount_info *mi)
mi->version = 4;
if (mi->version == 4) {
- if (!nfs_append_clientaddr_option(sap, salen, mi->options))
+ if (!nfs_append_clientaddr_option(sap, mi->salen, mi->options))
return 0;
} else {
if (!nfs_fix_mounthost_option(mi->options))
@@ -291,7 +292,7 @@ static int nfs_validate_options(struct nfsmount_info *mi)
if (!nfs_append_sloppy_option(mi->options))
return 0;
- if (!nfs_append_addr_option(sap, salen, mi->options))
+ if (!nfs_append_addr_option(sap, mi->salen, mi->options))
return 0;
/*