public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: "J. Bruce Fields" <bfields@fieldses.org>
To: Jan Blunck <jblunck@suse.de>
Cc: Linux-Kernel Mailinglist <linux-kernel@vger.kernel.org>,
	Christoph Hellwig <hch@infradead.org>,
	Andrew Morton <akpm@linux-foundation.org>,
	neilb@suse.de
Subject: Re: [PATCH 7/9] Use struct path in struct svc_expkey
Date: Mon, 5 Nov 2007 11:43:53 -0500	[thread overview]
Message-ID: <20071105164353.GF22767@fieldses.org> (raw)
In-Reply-To: <20071105163234.240126105@hasse.suse.de>

On Mon, Nov 05, 2007 at 05:32:39PM +0100, Jan Blunck wrote:
> I'm embedding struct path into struct svc_expkey.

Looks straightforward to me, thanks.

	Acked-by: J. Bruce Fields <bfields@citi.umich.edu>

--b.

> 
> Signed-off-by: Jan Blunck <jblunck@suse.de>
> ---
>  fs/nfsd/export.c            |   30 +++++++++++++-----------------
>  include/linux/nfsd/export.h |    3 +--
>  2 files changed, 14 insertions(+), 19 deletions(-)
> 
> Index: b/fs/nfsd/export.c
> ===================================================================
> --- a/fs/nfsd/export.c
> +++ b/fs/nfsd/export.c
> @@ -63,10 +63,8 @@ static void expkey_put(struct kref *ref)
>  	struct svc_expkey *key = container_of(ref, struct svc_expkey, h.ref);
>  
>  	if (test_bit(CACHE_VALID, &key->h.flags) &&
> -	    !test_bit(CACHE_NEGATIVE, &key->h.flags)) {
> -		dput(key->ek_dentry);
> -		mntput(key->ek_mnt);
> -	}
> +	    !test_bit(CACHE_NEGATIVE, &key->h.flags))
> +		path_put(&key->ek_path);
>  	auth_domain_put(key->ek_client);
>  	kfree(key);
>  }
> @@ -169,9 +167,8 @@ static int expkey_parse(struct cache_det
>  			goto out;
>  
>  		dprintk("Found the path %s\n", buf);
> -		key.ek_mnt = nd.path.mnt;
> -		key.ek_dentry = nd.path.dentry;
> -		
> +		key.ek_path = nd.path;
> +
>  		ek = svc_expkey_update(&key, ek);
>  		if (ek)
>  			cache_put(&ek->h, &svc_expkey_cache);
> @@ -206,7 +203,7 @@ static int expkey_show(struct seq_file *
>  	if (test_bit(CACHE_VALID, &h->flags) && 
>  	    !test_bit(CACHE_NEGATIVE, &h->flags)) {
>  		seq_printf(m, " ");
> -		seq_path(m, ek->ek_mnt, ek->ek_dentry, "\\ \t\n");
> +		seq_path(m, ek->ek_path.mnt, ek->ek_path.dentry, "\\ \t\n");
>  	}
>  	seq_printf(m, "\n");
>  	return 0;
> @@ -243,8 +240,8 @@ static inline void expkey_update(struct 
>  	struct svc_expkey *new = container_of(cnew, struct svc_expkey, h);
>  	struct svc_expkey *item = container_of(citem, struct svc_expkey, h);
>  
> -	new->ek_mnt = mntget(item->ek_mnt);
> -	new->ek_dentry = dget(item->ek_dentry);
> +	new->ek_path = item->ek_path;
> +	path_get(&item->ek_path);
>  }
>  
>  static struct cache_head *expkey_alloc(void)
> @@ -814,8 +811,7 @@ static int exp_set_key(svc_client *clp, 
>  	key.ek_client = clp;
>  	key.ek_fsidtype = fsid_type;
>  	memcpy(key.ek_fsid, fsidv, key_len(fsid_type));
> -	key.ek_mnt = exp->ex_path.mnt;
> -	key.ek_dentry = exp->ex_path.dentry;
> +	key.ek_path = exp->ex_path;
>  	key.h.expiry_time = NEVER;
>  	key.h.flags = 0;
>  
> @@ -864,7 +860,7 @@ static svc_export *exp_get_by_name(svc_c
>  {
>  	struct svc_export *exp, key;
>  	int err;
> -	
> +
>  	if (!clp)
>  		return ERR_PTR(-ENOENT);
>  
> @@ -1036,9 +1032,9 @@ exp_export(struct nfsctl_export *nxp)
>  	/* must make sure there won't be an ex_fsid clash */
>  	if ((nxp->ex_flags & NFSEXP_FSID) &&
>  	    (!IS_ERR(fsid_key = exp_get_fsid_key(clp, nxp->ex_dev))) &&
> -	    fsid_key->ek_mnt &&
> -	    (fsid_key->ek_mnt != nd.path.mnt ||
> -	     fsid_key->ek_dentry != nd.path.dentry))
> +	    fsid_key->ek_path.mnt &&
> +	    (fsid_key->ek_path.mnt != nd.path.mnt ||
> +	     fsid_key->ek_path.dentry != nd.path.dentry))
>  		goto finish;
>  
>  	if (!IS_ERR(exp)) {
> @@ -1219,7 +1215,7 @@ static struct svc_export *exp_find(struc
>  	if (IS_ERR(ek))
>  		return ERR_PTR(PTR_ERR(ek));
>  
> -	exp = exp_get_by_name(clp, ek->ek_mnt, ek->ek_dentry, reqp);
> +	exp = exp_get_by_name(clp, ek->ek_path.mnt, ek->ek_path.dentry, reqp);
>  	cache_put(&ek->h, &svc_expkey_cache);
>  
>  	if (IS_ERR(exp))
> Index: b/include/linux/nfsd/export.h
> ===================================================================
> --- a/include/linux/nfsd/export.h
> +++ b/include/linux/nfsd/export.h
> @@ -106,8 +106,7 @@ struct svc_expkey {
>  	int			ek_fsidtype;
>  	u32			ek_fsid[6];
>  
> -	struct vfsmount *	ek_mnt;
> -	struct dentry *		ek_dentry;
> +	struct path		ek_path;
>  };
>  
>  #define EX_SECURE(exp)		(!((exp)->ex_flags & NFSEXP_INSECURE_PORT))
> 
> 

  reply	other threads:[~2007-11-05 16:44 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-11-05 16:32 [PATCH 0/9] struct path related cleanups of d_path() code (V2) Jan Blunck
2007-11-05 16:32 ` [PATCH 1/9] One less parameter to __d_path Jan Blunck
2007-11-05 16:32 ` [PATCH 2/9] d_path: kerneldoc cleanup Jan Blunck
2007-11-05 16:32 ` [PATCH 3/9] d_path: Use struct path in struct avc_audit_data Jan Blunck
2007-11-05 16:32 ` [PATCH 4/9] d_path: Make proc_get_link() use a struct path argument Jan Blunck
2007-11-05 16:32 ` [PATCH 5/9] d_path: Make get_dcookie() " Jan Blunck
2007-11-05 16:32 ` [PATCH 6/9] Use struct path in struct svc_export Jan Blunck
2007-11-05 16:32 ` [PATCH 7/9] Use struct path in struct svc_expkey Jan Blunck
2007-11-05 16:43   ` J. Bruce Fields [this message]
2007-11-05 16:32 ` [PATCH 8/9] d_path: Make seq_path() use a struct path argument Jan Blunck
2007-11-05 16:32 ` [PATCH 9/9] d_path: Make d_path() use a struct path Jan Blunck

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20071105164353.GF22767@fieldses.org \
    --to=bfields@fieldses.org \
    --cc=akpm@linux-foundation.org \
    --cc=hch@infradead.org \
    --cc=jblunck@suse.de \
    --cc=linux-kernel@vger.kernel.org \
    --cc=neilb@suse.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox