aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfsd/export.c
diff options
context:
space:
mode:
authorJ. Bruce Fields <bfields@citi.umich.edu>2007-07-17 07:04:46 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-07-17 13:23:07 -0400
commit3ab4d8b1215d61736e2a9a26bea7cc2e6b029e3d (patch)
tree6b256e44c4ed5295dfd55eef8641093b91692559 /fs/nfsd/export.c
parent0989a7889695831e49e2c53c1884f52645516a90 (diff)
knfsd: nfsd: set rq_client to ip-address-determined-domain
We want it to be possible for users to restrict exports both by IP address and by pseudoflavor. The pseudoflavor information has previously been passed using special auth_domains stored in the rq_client field. After the preceding patch that stored the pseudoflavor in rq_pflavor, that's now superfluous; so now we use rq_client for the ip information, as auth_null and auth_unix do. However, we keep around the special auth_domain in the rq_gssclient field for backwards compatibility purposes, so we can still do upcalls using the old "gss/pseudoflavor" auth_domain if upcalls using the unix domain to give us an appropriate export. This allows us to continue supporting old mountd. In fact, for this first patch, we always use the "gss/pseudoflavor" auth_domain (and only it) if it is available; thus rq_client is ignored in the auth_gss case, and this patch on its own makes no change in behavior; that will be left to later patches. Note on idmap: I'm almost tempted to just replace the auth_domain in the idmap upcall by a dummy value--no version of idmapd has ever used it, and it's unlikely anyone really wants to perform idmapping differently depending on the where the client is (they may want to perform *credential* mapping differently, but that's a different matter--the idmapper just handles id's used in getattr and setattr). But I'm updating the idmapd code anyway, just out of general backwards-compatibility paranoia. Signed-off-by: "J. Bruce Fields" <bfields@citi.umich.edu> Signed-off-by: Neil Brown <neilb@suse.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/nfsd/export.c')
-rw-r--r--fs/nfsd/export.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/fs/nfsd/export.c b/fs/nfsd/export.c
index 9b569af695ab..ac225a79376c 100644
--- a/fs/nfsd/export.c
+++ b/fs/nfsd/export.c
@@ -1237,21 +1237,28 @@ struct svc_export *
1237rqst_exp_get_by_name(struct svc_rqst *rqstp, struct vfsmount *mnt, 1237rqst_exp_get_by_name(struct svc_rqst *rqstp, struct vfsmount *mnt,
1238 struct dentry *dentry) 1238 struct dentry *dentry)
1239{ 1239{
1240 return exp_get_by_name(rqstp->rq_client, mnt, dentry, 1240 struct auth_domain *clp;
1241 &rqstp->rq_chandle); 1241
1242 clp = rqstp->rq_gssclient ? rqstp->rq_gssclient : rqstp->rq_client;
1243 return exp_get_by_name(clp, mnt, dentry, &rqstp->rq_chandle);
1242} 1244}
1243 1245
1244struct svc_export * 1246struct svc_export *
1245rqst_exp_find(struct svc_rqst *rqstp, int fsid_type, u32 *fsidv) 1247rqst_exp_find(struct svc_rqst *rqstp, int fsid_type, u32 *fsidv)
1246{ 1248{
1247 return exp_find(rqstp->rq_client, fsid_type, fsidv, 1249 struct auth_domain *clp;
1248 &rqstp->rq_chandle); 1250
1251 clp = rqstp->rq_gssclient ? rqstp->rq_gssclient : rqstp->rq_client;
1252 return exp_find(clp, fsid_type, fsidv, &rqstp->rq_chandle);
1249} 1253}
1250 1254
1251struct svc_export * 1255struct svc_export *
1252rqst_exp_parent(struct svc_rqst *rqstp, struct vfsmount *mnt, 1256rqst_exp_parent(struct svc_rqst *rqstp, struct vfsmount *mnt,
1253 struct dentry *dentry) 1257 struct dentry *dentry)
1254{ 1258{
1259 struct auth_domain *clp;
1260
1261 clp = rqstp->rq_gssclient ? rqstp->rq_gssclient : rqstp->rq_client;
1255 return exp_parent(rqstp->rq_client, mnt, dentry, &rqstp->rq_chandle); 1262 return exp_parent(rqstp->rq_client, mnt, dentry, &rqstp->rq_chandle);
1256} 1263}
1257 1264