android_kernel_xiaomi_sm8350/drivers/net/sk98lin
Herbert Xu 5b057c6b1a [NET]: Avoid allocating skb in skb_pad
First of all it is unnecessary to allocate a new skb in skb_pad since
the existing one is not shared.  More importantly, our hard_start_xmit
interface does not allow a new skb to be allocated since that breaks
requeueing.

This patch uses pskb_expand_head to expand the existing skb and linearize
it if needed.  Actually, someone should sift through every instance of
skb_pad on a non-linear skb as they do not fit the reasons why this was
originally created.

Incidentally, this fixes a minor bug when the skb is cloned (tcpdump,
TCP, etc.).  As it is skb_pad will simply write over a cloned skb.  Because
of the position of the write it is unlikely to cause problems but still
it's best if we don't do it.

Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2006-06-23 02:06:41 -07:00
..
h [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
Makefile
skaddr.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
skdim.c
skethtool.c
skge.c [NET]: Avoid allocating skb in skb_pad 2006-06-23 02:06:41 -07:00
skgehwt.c
skgeinit.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
skgemib.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
skgepnmi.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
skgesirq.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
ski2c.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
sklm80.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
skqueue.c
skrlmt.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
sktimer.c
skvpd.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00
skxmac2.c [PATCH] drivers/net/sk98lin/: possible cleanups 2006-01-17 07:45:52 -05:00