[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date: Sat, 13 Dec 2008 05:38:55 +0300
From: Evgeniy Polyakov <zbr@...emap.net>
To: Herbert Xu <herbert@...dor.apana.org.au>
Cc: "David S. Miller" <davem@...emloft.net>, netdev@...r.kernel.org
Subject: Re: [PATCH 1/8] net: Add frag_list support to skb_segment
On Sat, Dec 13, 2008 at 08:41:25AM +1100, Herbert Xu (herbert@...dor.apana.org.au) wrote:
> > > + nskb->truesize += skb_end_pointer(nskb) - nskb->head -
> > > + hsize;
> > > + skb_release_head_state(nskb);
> > > + __skb_push(nskb, doffset);
> > > + } else {
> > > + nskb = alloc_skb(hsize + doffset + headroom,
> > > + GFP_ATOMIC);
> > > +
> > > + if (unlikely(!nskb))
> > > + goto err;
> > > +
> >
> > The same.
>
> nskb is NULL here.
Yup, I meant below 'goto err' when we failed to clone skb.
> > > + if (pos < offset + len) {
> > > + struct sk_buff *fskb2 = fskb;
> > > +
> > > + BUG_ON(pos + fskb->len != offset + len);
> > > +
> > > + pos += fskb->len;
> > > + fskb = fskb->next;
> > > +
> > > + if (fskb2->next) {
> > > + fskb2 = skb_clone(fskb2, GFP_ATOMIC);
> > > + if (!fskb2)
> > > + goto err;
> > > + } else
> > > + skb_get(fskb2);
> > > +
> > > + skb_shinfo(nskb)->frag_list = fskb2;
--
Evgeniy Polyakov
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists