diff options
author | Chuck Lever <chuck.lever@oracle.com> | 2008-03-14 14:25:39 -0400 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2008-03-19 18:00:57 -0400 |
commit | 496951743100b2d2ccd8b268257e79425e489851 (patch) | |
tree | e52e804c132f8322699354640c7fee7541b9a317 /fs/lockd/mon.c | |
parent | 099bd05f27ff24a3041d54e7ed42d2eb681484b9 (diff) |
lockd: refactor SM_MON mon_name argument encoder
Clean up: introduce a new XDR encoder specifically for the mon_name
argument of SM_MON requests. This will be updated later to support IPv6
addresses in addition to IPv4 addresses.
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/lockd/mon.c')
-rw-r--r-- | fs/lockd/mon.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/fs/lockd/mon.c b/fs/lockd/mon.c index 84fd84cb67b7..87bd4e4d65dd 100644 --- a/fs/lockd/mon.c +++ b/fs/lockd/mon.c | |||
@@ -18,6 +18,8 @@ | |||
18 | 18 | ||
19 | #define NLMDBG_FACILITY NLMDBG_MONITOR | 19 | #define NLMDBG_FACILITY NLMDBG_MONITOR |
20 | 20 | ||
21 | #define XDR_ADDRBUF_LEN (20) | ||
22 | |||
21 | static struct rpc_clnt * nsm_create(void); | 23 | static struct rpc_clnt * nsm_create(void); |
22 | 24 | ||
23 | static struct rpc_program nsm_program; | 25 | static struct rpc_program nsm_program; |
@@ -158,6 +160,29 @@ static __be32 *xdr_encode_nsm_string(__be32 *p, char *string) | |||
158 | return xdr_encode_opaque(p, string, len); | 160 | return xdr_encode_opaque(p, string, len); |
159 | } | 161 | } |
160 | 162 | ||
163 | /* | ||
164 | * "mon_name" specifies the host to be monitored. | ||
165 | * | ||
166 | * Linux uses a text version of the IP address of the remote | ||
167 | * host as the host identifier (the "mon_name" argument). | ||
168 | * | ||
169 | * Linux statd always looks up the canonical hostname first for | ||
170 | * whatever remote hostname it receives, so this works alright. | ||
171 | */ | ||
172 | static __be32 *xdr_encode_mon_name(__be32 *p, struct nsm_args *argp) | ||
173 | { | ||
174 | char buffer[XDR_ADDRBUF_LEN + 1]; | ||
175 | char *name = argp->mon_name; | ||
176 | |||
177 | if (!nsm_use_hostnames) { | ||
178 | snprintf(buffer, XDR_ADDRBUF_LEN, | ||
179 | NIPQUAD_FMT, NIPQUAD(argp->addr)); | ||
180 | name = buffer; | ||
181 | } | ||
182 | |||
183 | return xdr_encode_nsm_string(p, name); | ||
184 | } | ||
185 | |||
161 | static __be32 * | 186 | static __be32 * |
162 | xdr_encode_common(struct rpc_rqst *rqstp, __be32 *p, struct nsm_args *argp) | 187 | xdr_encode_common(struct rpc_rqst *rqstp, __be32 *p, struct nsm_args *argp) |
163 | { | 188 | { |