netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: David Miller <davem@davemloft.net>
To: mst@redhat.com
Cc: xiaosuo@gmail.com, eric.dumazet@gmail.com,
	socketcan@hartkopp.net, netdev@vger.kernel.org
Subject: Re: [PATCH v2] net: af_packet: don't call tpacket_destruct_skb() until the skb is sent out
Date: Tue, 14 Sep 2010 20:20:23 -0700 (PDT)	[thread overview]
Message-ID: <20100914.202023.193706826.davem@davemloft.net> (raw)
In-Reply-To: <20100912121349.GD22982@redhat.com>

From: "Michael S. Tsirkin" <mst@redhat.com>
Date: Sun, 12 Sep 2010 14:13:49 +0200

> On Sat, Sep 11, 2010 at 11:23:23AM +0800, Changli Gao wrote:
>> @@ -799,7 +806,9 @@ int pskb_expand_head(struct sk_buff *skb, int nhead, int ntail,
>>  
>>  	memcpy((struct skb_shared_info *)(data + size),
>>  	       skb_shinfo(skb),
>> -	       offsetof(struct skb_shared_info, frags[skb_shinfo(skb)->nr_frags]));
>> +	       offsetof(struct skb_shared_info,
>> +			frags[skb_shinfo(skb)->nr_frags]));
>> +	skb_shinfo(skb)->destructor = NULL;
>>  
>>  	/* Check if we can avoid taking references on fragments if we own
>>  	 * the last reference on skb->head. (see skb_release_data())
> 
> So it looks like pskb_expand_head will prevent the shinfo desctructor
> from being called, ever? If so, won't this break af_packet?

>From what I read, he is propagating it into the new SKB data blob
with expanded head area.  It would get invoked when the skb's
new data is put.

I am not sure this is correct, however.

Destructor register only cares about original data area, but what
constitutes "original data" is ambiguous.  In fact it seems
impossible to catch the freeing of all parts properly.

When pskb_expand_head() is invoked we get new linear part, but
non-linear part stays the same.  However, entity which registered
skb data destructor cares about old linear data lifetime, which
we will no longer track after destructor is propagated only to
the new shinfo.

So we need to do something different here.  I bet original code
overriding socket destructor semantics had a similar problem.

Changli, I have one other minor request, please name this something
like "shinfo->data_destructor" and "shinfo->data_destructor_arg".

I think that will make it easier for other humans to understand :)

Thank you.

  reply	other threads:[~2010-09-15  3:20 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-09-11  3:23 [PATCH v2] net: af_packet: don't call tpacket_destruct_skb() until the skb is sent out Changli Gao
2010-09-12 12:13 ` Michael S. Tsirkin
2010-09-15  3:20   ` David Miller [this message]
2010-09-15  5:23     ` Michael S. Tsirkin
2010-09-22  9:35       ` Changli Gao
2010-09-22 10:59         ` Michael S. Tsirkin
2010-09-22  9:24     ` Changli Gao

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=20100914.202023.193706826.davem@davemloft.net \
    --to=davem@davemloft.net \
    --cc=eric.dumazet@gmail.com \
    --cc=mst@redhat.com \
    --cc=netdev@vger.kernel.org \
    --cc=socketcan@hartkopp.net \
    --cc=xiaosuo@gmail.com \
    /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;
as well as URLs for NNTP newsgroup(s).