diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2007-09-17 01:19:50 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2007-09-17 01:19:50 +0200 |
commit | db7bf6d97c6956b7eb0f22131cb5c37bd41f33c0 (patch) | |
tree | 85aa14dea255e209cd2f85180b47f4f092ec6921 /drivers/net/myri_sbus.c | |
parent | [PPP] pppoe: Fix skb_unshare_check call position (diff) | |
download | linux-db7bf6d97c6956b7eb0f22131cb5c37bd41f33c0.tar.xz linux-db7bf6d97c6956b7eb0f22131cb5c37bd41f33c0.zip |
[PPP] pppoe: Fix data clobbering in __pppoe_xmit and return value
The function __pppoe_xmit modifies the skb data and therefore it needs
to copy and skb data if it's cloned.
In fact, it currently allocates a new skb so that it can return 0 in
case of error without freeing the original skb. This is totally wrong
because returning zero is meant to indicate congestion whereupon pppoe
is supposed to wake up the upper layer once the congestion subsides.
This makes sense for ppp_async and ppp_sync but is out-of-place for
pppoe. This patch makes it always return 1 and free the skb.
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/myri_sbus.c')
0 files changed, 0 insertions, 0 deletions