From mboxrd@z Thu Jan 1 00:00:00 1970 From: David Miller Subject: Re: [PATCH] tcp: fix retransmit of partially acked frames Date: Wed, 18 Apr 2012 16:54:00 -0400 (EDT) Message-ID: <20120418.165400.980383816074286216.davem@davemloft.net> References: <1334734196.2472.91.camel@edumazet-glaptop> <1334780063.2472.352.camel@edumazet-glaptop> Mime-Version: 1.0 Content-Type: Text/Plain; charset=us-ascii Content-Transfer-Encoding: 7bit Cc: a.beregalov@gmail.com, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, marc@merlins.org To: eric.dumazet@gmail.com Return-path: In-Reply-To: <1334780063.2472.352.camel@edumazet-glaptop> Sender: linux-kernel-owner@vger.kernel.org List-Id: netdev.vger.kernel.org From: Eric Dumazet Date: Wed, 18 Apr 2012 22:14:23 +0200 > From: Eric Dumazet > > Alexander Beregalov reported skb_over_panic errors and provided stack > trace. > > I occurs commit a21d45726aca (tcp: avoid order-1 allocations on wifi and > tx path) added a regression, when a retransmit is done after a partial > ACK. > > tcp_retransmit_skb() tries to aggregate several frames if the first one > has enough available room to hold the following ones payload. This is > controlled by /proc/sys/net/ipv4/tcp_retrans_collapse tunable (default : > enabled) > > Problem is we must make sure _pskb_trim_head() doesnt fool > skb_availroom() when pulling some bytes from skb (this pull is done when > receiver ACK part of the frame). > > Reported-by: Alexander Beregalov > Cc: Marc MERLIN > Signed-off-by: Eric Dumazet Applied, thanks.