diff options
author | Andrew Vagin <avagin@openvz.org> | 2012-11-15 08:03:17 +0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-11-16 02:44:58 +0400 |
commit | ec34232575083fd0f43d3a101e8ebb041b203761 (patch) | |
tree | e765164c397880fcae8117f0e9ff65ed1cd8f9b8 /firmware/keyspan | |
parent | 0da9a0c2638c8476b4a5021841912f249e3187dc (diff) | |
download | linux-ec34232575083fd0f43d3a101e8ebb041b203761.tar.xz |
tcp: fix retransmission in repair mode
Currently if a socket was repaired with a few packet in a write queue,
a kernel bug may be triggered:
kernel BUG at net/ipv4/tcp_output.c:2330!
RIP: 0010:[<ffffffff8155784f>] tcp_retransmit_skb+0x5ff/0x610
According to the initial realization v3.4-rc2-963-gc0e88ff,
all skb-s should look like already posted. This patch fixes code
according with this sentence.
Here are three points, which were not done in the initial patch:
1. A tcp send head should not be changed
2. Initialize TSO state of a skb
3. Reset the retransmission time
This patch moves logic from tcp_sendmsg to tcp_write_xmit. A packet
passes the ussual way, but isn't sent to network. This patch solves
all described problems and handles tcp_sendpages.
Cc: Pavel Emelyanov <xemul@parallels.com>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>
Cc: James Morris <jmorris@namei.org>
Cc: Hideaki YOSHIFUJI <yoshfuji@linux-ipv6.org>
Cc: Patrick McHardy <kaber@trash.net>
Signed-off-by: Andrey Vagin <avagin@openvz.org>
Acked-by: Pavel Emelyanov <xemul@parallels.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'firmware/keyspan')
0 files changed, 0 insertions, 0 deletions