Re: below top level mounting NFS3 authentication patch

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Aug 14, 2008 at 01:42:19PM +0200, EG Keizer wrote:
> At our faculty we use Linux (Debian) clients and Solaris 9/10 file servers.
> We use the automounter on the Linux clients to access home directories with krb5.
> The servers  export the home directories on the level above the user home
> directories.
> Kernel 2.6.18 allows this behavior, kernels later then 2.6.23 do not.
> The underlying cause for the problem is the interpretation of the wording in
> RFC 2623, sec  2.3.2. This allows fsinfo with UNIX authentication on the
> root of the  export. But the automounter mounts below the root of the export/share
> and the Solaris  server (justly) requires full, i.e. krb5, authentication.
> Thus the mount fails, which makes the automounter useless in our environment.
> The client should try both authentications and use the first one that
> succeeds.
> The nfs_proc_get_root subroutine in nfs3proc already does
> this, but...
> the call to the sget routine earlier in the routine nfs_get_sb causes a
> fsinfo call that always uses UNIX authentication. Which causes the mount
> to fail.
>
> The solution i came up with is simple. Transplant the way get_root
> handles this to fsinfo. This is implemented in the patch to 2.6.24-rc4
> in the attachment.
>
> The are probably better solutions. For example by collapsing the two
> calls to get_root and fsinfo. But all i needed was something that made
> things work for me and did not ruin something for anybody.
>
> It would be nice if this patch found its way into the distribution...

Seems fine to me.  Doesn't v2 need the same treatment as v3 here,
though?

--b.

>
>
> Ed Keizer
> IT group                                        tel: +31 20 5987804
> Faculty of Sciences		                fax: +31 20 5987653
> Vrije Universiteit                              e-mail: keie@xxxxxxxxx
> De Boelelaan 1081A, 1081 HV  Amsterdam, The Netherlands
>
>
>

> diff --git a/fs/dcache.c b/fs/dcache.c
> diff --git a/fs/nfs/nfs3proc.c b/fs/nfs/nfs3proc.c
> index 4cdc236..1215d42 100644
> --- a/fs/nfs/nfs3proc.c
> +++ b/fs/nfs/nfs3proc.c
> @@ -687,7 +687,7 @@ nfs3_proc_statfs(struct nfs_server *server, struct nfs_fh *fhandle,
>  }
>  
>  static int
> -nfs3_proc_fsinfo(struct nfs_server *server, struct nfs_fh *fhandle,
> +do_proc_fsinfo(struct rpc_clnt *client, struct nfs_fh *fhandle,
>  		 struct nfs_fsinfo *info)
>  {
>  	struct rpc_message msg = {
> @@ -699,11 +699,26 @@ nfs3_proc_fsinfo(struct nfs_server *server, struct nfs_fh *fhandle,
>  
>  	dprintk("NFS call  fsinfo\n");
>  	nfs_fattr_init(info->fattr);
> -	status = rpc_call_sync(server->nfs_client->cl_rpcclient, &msg, 0);
> +	status = rpc_call_sync(client, &msg, 0);
>  	dprintk("NFS reply fsinfo: %d\n", status);
>  	return status;
>  }
>  
> +/*
> + * Bare-bones access to fsinfo: this is for nfs_get_root/nfs_get_sb via nfs_create_server
> + */
> +static int
> +nfs3_proc_fsinfo(struct nfs_server *server, struct nfs_fh *fhandle,
> +		   struct nfs_fsinfo *info)
> +{
> +	int	status;
> +
> +	status = do_proc_fsinfo(server->client, fhandle, info);
> +	if (status && server->nfs_client->cl_rpcclient != server->client)
> +		status = do_proc_fsinfo(server->nfs_client->cl_rpcclient, fhandle, info);
> +	return status;
> +}
> +
>  static int
>  nfs3_proc_pathconf(struct nfs_server *server, struct nfs_fh *fhandle,
>  		   struct nfs_pathconf *info)
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux