All of lore.kernel.org
 help / color / mirror / Atom feed
From: Pablo Neira Ayuso <pablo@netfilter.org>
To: Simon Horman <horms@verge.net.au>
Cc: lvs-devel@vger.kernel.org, netdev@vger.kernel.org,
	netfilter-devel@vger.kernel.org,
	Wensong Zhang <wensong@linux-vs.org>,
	Julian Anastasov <ja@ssi.bg>
Subject: Re: [PATCH 01/34] net: add skb_dst_set_noref_force
Date: Mon, 1 Apr 2013 14:06:44 +0200	[thread overview]
Message-ID: <20130401120644.GA4882@localhost> (raw)
In-Reply-To: <1364530311-11512-2-git-send-email-horms@verge.net.au>

Hi Simon,

On Fri, Mar 29, 2013 at 01:11:18PM +0900, Simon Horman wrote:
> From: Julian Anastasov <ja@ssi.bg>
> 
> Rename skb_dst_set_noref to __skb_dst_set_noref and
> add force flag as suggested by David Miller. The new wrapper
> skb_dst_set_noref_force will force dst entries that are not
> cached to be attached as skb dst without taking reference
> as long as provided dst is reclaimed after RCU grace period.
> 
> Signed-off-by: Julian Anastasov <ja@ssi.bg>
> Signed-off by: Hans Schillstrom <hans@schillstrom.com>
> Signed-off-by: Simon Horman <horms@verge.net.au>

I think was acked by David, right?

> ---
>  include/linux/skbuff.h |   35 ++++++++++++++++++++++++++++++++++-
>  net/core/dst.c         |    9 +++++----
>  2 files changed, 39 insertions(+), 5 deletions(-)
> 
> diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h
> index 878e0ee..364e244 100644
> --- a/include/linux/skbuff.h
> +++ b/include/linux/skbuff.h
> @@ -575,7 +575,40 @@ static inline void skb_dst_set(struct sk_buff *skb, struct dst_entry *dst)
>  	skb->_skb_refdst = (unsigned long)dst;
>  }
>  
> -extern void skb_dst_set_noref(struct sk_buff *skb, struct dst_entry *dst);
> +extern void __skb_dst_set_noref(struct sk_buff *skb, struct dst_entry *dst,
> +				bool force);
> +
> +/**
> + * skb_dst_set_noref - sets skb dst, hopefully, without taking reference
> + * @skb: buffer
> + * @dst: dst entry
> + *
> + * Sets skb dst, assuming a reference was not taken on dst.
> + * If dst entry is cached, we do not take reference and dst_release
> + * will be avoided by refdst_drop. If dst entry is not cached, we take
> + * reference, so that last dst_release can destroy the dst immediately.
> + */
> +static inline void skb_dst_set_noref(struct sk_buff *skb, struct dst_entry *dst)
> +{
> +	__skb_dst_set_noref(skb, dst, false);
> +}
> +
> +/**
> + * skb_dst_set_noref_force - sets skb dst, without taking reference
> + * @skb: buffer
> + * @dst: dst entry
> + *
> + * Sets skb dst, assuming a reference was not taken on dst.
> + * No reference is taken and no dst_release will be called. While for
> + * cached dsts deferred reclaim is a basic feature, for entries that are
> + * not cached it is caller's job to guarantee that last dst_release for
> + * provided dst happens when nobody uses it, eg. after a RCU grace period.
> + */
> +static inline void skb_dst_set_noref_force(struct sk_buff *skb,
> +					   struct dst_entry *dst)
> +{
> +	__skb_dst_set_noref(skb, dst, true);
> +}
>  
>  /**
>   * skb_dst_is_noref - Test if skb dst isn't refcounted
> diff --git a/net/core/dst.c b/net/core/dst.c
> index 35fd12f..df9cc81 100644
> --- a/net/core/dst.c
> +++ b/net/core/dst.c
> @@ -320,27 +320,28 @@ void __dst_destroy_metrics_generic(struct dst_entry *dst, unsigned long old)
>  EXPORT_SYMBOL(__dst_destroy_metrics_generic);
>  
>  /**
> - * skb_dst_set_noref - sets skb dst, without a reference
> + * __skb_dst_set_noref - sets skb dst, without a reference
>   * @skb: buffer
>   * @dst: dst entry
> + * @force: if force is set, use noref version even for DST_NOCACHE entries
>   *
>   * Sets skb dst, assuming a reference was not taken on dst
>   * skb_dst_drop() should not dst_release() this dst
>   */
> -void skb_dst_set_noref(struct sk_buff *skb, struct dst_entry *dst)
> +void __skb_dst_set_noref(struct sk_buff *skb, struct dst_entry *dst, bool force)
>  {
>  	WARN_ON(!rcu_read_lock_held() && !rcu_read_lock_bh_held());
>  	/* If dst not in cache, we must take a reference, because
>  	 * dst_release() will destroy dst as soon as its refcount becomes zero
>  	 */
> -	if (unlikely(dst->flags & DST_NOCACHE)) {
> +	if (unlikely((dst->flags & DST_NOCACHE) && !force)) {
>  		dst_hold(dst);
>  		skb_dst_set(skb, dst);
>  	} else {
>  		skb->_skb_refdst = (unsigned long)dst | SKB_DST_NOREF;
>  	}
>  }
> -EXPORT_SYMBOL(skb_dst_set_noref);
> +EXPORT_SYMBOL(__skb_dst_set_noref);
>  
>  /* Dirty hack. We did it in 2.2 (in __dst_free),
>   * we have _very_ good reasons not to repeat
> -- 
> 1.7.10.4
> 

  reply	other threads:[~2013-04-01 12:06 UTC|newest]

Thread overview: 42+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-03-29  4:11 [GIT PULL nf-next] IPVS optimisations for v3.10 Simon Horman
2013-03-29  4:11 ` [PATCH 01/34] net: add skb_dst_set_noref_force Simon Horman
2013-04-01 12:06   ` Pablo Neira Ayuso [this message]
2013-04-01 16:57     ` David Miller
2013-04-01 22:42       ` Pablo Neira Ayuso
2013-04-02  1:11         ` Simon Horman
2013-03-29  4:11 ` [PATCH 02/34] ipvs: avoid routing by TOS for real server Simon Horman
2013-03-29  4:11 ` [PATCH 03/34] ipvs: prefer NETDEV_DOWN event to free cached dsts Simon Horman
2013-03-29  4:11 ` [PATCH 04/34] ipvs: convert the IP_VS_XMIT macros to functions Simon Horman
2013-03-29  4:11 ` [PATCH 05/34] ipvs: rename functions related to dst_cache reset Simon Horman
2013-03-29  4:11 ` [PATCH 06/34] ipvs: no need to reroute anymore on DNAT over loopback Simon Horman
2013-03-29 14:44   ` Sergei Shtylyov
2013-03-29 21:47     ` Julian Anastasov
2013-03-29  4:11 ` [PATCH 07/34] ipvs: do not use skb_share_check Simon Horman
2013-03-29  4:11 ` [PATCH 08/34] ipvs: consolidate all dst checks on transmit in one place Simon Horman
2013-03-29  4:11 ` [PATCH 09/34] ipvs: optimize dst usage for real server Simon Horman
2013-03-29  4:11 ` [PATCH 10/34] ipvs: convert app locks Simon Horman
2013-03-29  4:11 ` [PATCH 11/34] ipvs: remove rs_lock by using RCU Simon Horman
2013-03-29  4:11 ` [PATCH 12/34] ipvs: convert locks used in persistence engines Simon Horman
2013-03-29  4:11 ` [PATCH 13/34] ipvs: convert connection locking Simon Horman
2013-03-29  4:11 ` [PATCH 14/34] ipvs: reorder keys in connection structure Simon Horman
2013-03-29  4:11 ` [PATCH 15/34] ipvs: avoid kmem_cache_zalloc in ip_vs_conn_new Simon Horman
2013-03-29  4:11 ` [PATCH 16/34] ipvs: change ip_vs_sched_lock to mutex Simon Horman
2013-03-29  4:11 ` [PATCH 17/34] ipvs: preparations for using rcu in schedulers Simon Horman
2013-03-29  4:11 ` [PATCH 18/34] ipvs: add ip_vs_dest_hold and ip_vs_dest_put Simon Horman
2013-03-29  4:11 ` [PATCH 19/34] ipvs: convert dh scheduler to rcu Simon Horman
2013-03-29  4:11 ` [PATCH 20/34] ipvs: convert lblc " Simon Horman
2013-03-29  4:11 ` [PATCH 21/34] ipvs: convert lblcr " Simon Horman
2013-03-29  4:11 ` [PATCH 22/34] ipvs: convert lc " Simon Horman
2013-03-29  4:11 ` [PATCH 23/34] ipvs: convert nq " Simon Horman
2013-03-29  4:11 ` [PATCH 24/34] ipvs: convert rr " Simon Horman
2013-03-29  4:11 ` [PATCH 25/34] ipvs: convert sed " Simon Horman
2013-03-29  4:11 ` [PATCH 26/34] ipvs: convert sh " Simon Horman
2013-03-29  4:11 ` [PATCH 27/34] ipvs: convert wlc " Simon Horman
2013-03-29  4:11 ` [PATCH 28/34] ipvs: convert wrr " Simon Horman
2013-03-29  4:11 ` [PATCH 29/34] ipvs: reorganize dest trash Simon Horman
2013-03-29  4:11 ` [PATCH 30/34] ipvs: do not expect result from done_service Simon Horman
2013-03-29  4:11 ` [PATCH 31/34] ipvs: convert sched_lock to spin lock Simon Horman
2013-03-29  4:11 ` [PATCH 32/34] ipvs: convert dests to rcu Simon Horman
2013-03-29  4:11 ` [PATCH 33/34] ipvs: convert services " Simon Horman
2013-03-29  4:11 ` [PATCH 34/34] ipvs: do not disable bh for long time Simon Horman
2013-04-01 22:41 ` [GIT PULL nf-next] IPVS optimisations for v3.10 Pablo Neira Ayuso

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=20130401120644.GA4882@localhost \
    --to=pablo@netfilter.org \
    --cc=horms@verge.net.au \
    --cc=ja@ssi.bg \
    --cc=lvs-devel@vger.kernel.org \
    --cc=netdev@vger.kernel.org \
    --cc=netfilter-devel@vger.kernel.org \
    --cc=wensong@linux-vs.org \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.