netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Change in alloc_skb() behavior in 3.2+ kernels?
@ 2012-06-06 18:32 Grant Edwards
  2012-06-06 18:42 ` Eric Dumazet
  2012-06-06 18:51 ` David Miller
  0 siblings, 2 replies; 19+ messages in thread
From: Grant Edwards @ 2012-06-06 18:32 UTC (permalink / raw)
  To: netdev

I'm tracking down a problem that appears to be caused by a change in
the behavior of alloc_skb() introduced in kernel version 3.2.  In
kernel versions prior to 3.2, calling alloc_skb(1350), returned an
sk_buff with a tailroom of around 1400 bytes (safely below the default
Ethernet frame size limit of 1500).

In 3.2 and later, calling alloc_skb(1350) returns an sk_buff with a
tailroom of about 1850.

Why has the "extra" space increased from 60 bytes to 500 bytes?

[It's always possible that I've unintentionally changed something in
the kernel configs that causes this, but I've tried to build the
kernels as identically as possible.]

The kernel module that's started failing fills the allocated sk_buff
until tailroom() indicates it is full and then sends it.  The problem
is that sending a packet with a length of 1850 won't work (it's a
MAC-layer Ethernet packet).

I've found man pages for alloc_skb() from a few years ago that state
explicitly that alloc_skb(_size_) will allocate a new sk_buff with no
headroom and a tail room of _size_ bytes.  This doesn't seem to be the
case for recent kernels.  Is there any documentation stating what the
current behavior is supposed to be?

Are callers to alloc_skb() supposed to check the tailroom and
reserve() an appropriate number of bytes such that the tailroom is
correct?

Is the tailroom of the allocated sk_buff guaranteed to be at least as
large as the requested size, or does application code also have to
check for tailroom less than the requested size?

The ultimate question I'm trying to answer is what is the "right" way
to allocate an sk_buff that has a size appropriate for an Ethernet
frame assuming an MTU of 1500?

-- 
Grant Edwards               grant.b.edwards        Yow! Let's send the
                                  at               Russians defective
                              gmail.com            lifestyle accessories!

^ permalink raw reply	[flat|nested] 19+ messages in thread

end of thread, other threads:[~2012-06-07 20:19 UTC | newest]

Thread overview: 19+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-06-06 18:32 Change in alloc_skb() behavior in 3.2+ kernels? Grant Edwards
2012-06-06 18:42 ` Eric Dumazet
2012-06-06 18:59   ` Grant Edwards
2012-06-06 19:02     ` David Miller
2012-06-06 20:22       ` Grant Edwards
2012-06-07  1:23         ` [PATCH net-next] net: Update kernel-doc for __alloc_skb() Ben Hutchings
2012-06-07 20:19           ` David Miller
2012-06-07 13:23       ` Change in alloc_skb() behavior in 3.2+ kernels? Grant Edwards
2012-06-07 14:01         ` Eric Dumazet
2012-06-07 14:16           ` Grant Edwards
2012-06-07 14:25             ` Eric Dumazet
2012-06-06 18:51 ` David Miller
2012-06-06 19:01   ` Grant Edwards
2012-06-06 20:17     ` David Miller
2012-06-06 20:24       ` Grant Edwards
2012-06-06 20:31         ` Eric Dumazet
2012-06-06 20:35           ` Grant Edwards
2012-06-06 19:42   ` Eric Dumazet
2012-06-06 20:26     ` Grant Edwards

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).