diff options
| author | Trond Myklebust <Trond.Myklebust@netapp.com> | 2009-08-19 18:12:34 -0400 |
|---|---|---|
| committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2009-08-19 18:22:15 -0400 |
| commit | 7d7ea882898f23989209d0359691b356f73240dc (patch) | |
| tree | 8bd90c5c728302b8460f1f451d23168c8fc99433 /fs | |
| parent | e571cbf1a4f8d8b6cfd4898df718dae84c75a8e1 (diff) | |
NFS: Use the DNS resolver in the mount code.
In the referral code, use it to look up the new server's ip address if the
fs_locations attribute contains a hostname.
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs')
| -rw-r--r-- | fs/nfs/nfs4namespace.c | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/fs/nfs/nfs4namespace.c b/fs/nfs/nfs4namespace.c index ef22ee89aa77..2636c26d56fa 100644 --- a/fs/nfs/nfs4namespace.c +++ b/fs/nfs/nfs4namespace.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include <linux/inet.h> | 17 | #include <linux/inet.h> |
| 18 | #include "internal.h" | 18 | #include "internal.h" |
| 19 | #include "nfs4_fs.h" | 19 | #include "nfs4_fs.h" |
| 20 | #include "dns_resolve.h" | ||
| 20 | 21 | ||
| 21 | #define NFSDBG_FACILITY NFSDBG_VFS | 22 | #define NFSDBG_FACILITY NFSDBG_VFS |
| 22 | 23 | ||
| @@ -95,6 +96,20 @@ static int nfs4_validate_fspath(const struct vfsmount *mnt_parent, | |||
| 95 | return 0; | 96 | return 0; |
| 96 | } | 97 | } |
| 97 | 98 | ||
| 99 | static size_t nfs_parse_server_name(char *string, size_t len, | ||
| 100 | struct sockaddr *sa, size_t salen) | ||
| 101 | { | ||
| 102 | ssize_t ret; | ||
| 103 | |||
| 104 | ret = rpc_pton(string, len, sa, salen); | ||
| 105 | if (ret == 0) { | ||
| 106 | ret = nfs_dns_resolve_name(string, len, sa, salen); | ||
| 107 | if (ret < 0) | ||
| 108 | ret = 0; | ||
| 109 | } | ||
| 110 | return ret; | ||
| 111 | } | ||
| 112 | |||
| 98 | static struct vfsmount *try_location(struct nfs_clone_mount *mountdata, | 113 | static struct vfsmount *try_location(struct nfs_clone_mount *mountdata, |
| 99 | char *page, char *page2, | 114 | char *page, char *page2, |
| 100 | const struct nfs4_fs_location *location) | 115 | const struct nfs4_fs_location *location) |
| @@ -121,7 +136,8 @@ static struct vfsmount *try_location(struct nfs_clone_mount *mountdata, | |||
| 121 | 136 | ||
| 122 | if (memchr(buf->data, IPV6_SCOPE_DELIMITER, buf->len)) | 137 | if (memchr(buf->data, IPV6_SCOPE_DELIMITER, buf->len)) |
| 123 | continue; | 138 | continue; |
| 124 | mountdata->addrlen = rpc_pton(buf->data, buf->len, | 139 | mountdata->addrlen = nfs_parse_server_name(buf->data, |
| 140 | buf->len, | ||
| 125 | mountdata->addr, mountdata->addrlen); | 141 | mountdata->addr, mountdata->addrlen); |
| 126 | if (mountdata->addrlen == 0) | 142 | if (mountdata->addrlen == 0) |
| 127 | continue; | 143 | continue; |
