Gleb Smirnoff 0e2bc05c47 Fix tcp_output() so that tcpcb is updated in the same manner when an
mbuf allocation fails, as in a case when ip_output() returns error.

To achieve that, move large block of code that updates tcpcb below
the out: label.

This fixes a panic, that requires the following sequence to happen:

1) The SYN was sent to the network, tp->snd_nxt = iss + 1, tp->snd_una = iss
2) The retransmit timeout happened for the SYN we had sent,
   tcp_timer_rexmt() sets tp->snd_nxt = tp->snd_una, and calls tcp_output().
   In tcp_output m_get() fails.
3) Later on the SYN|ACK for the SYN sent in step 1) came,
   tcp_input sets tp->snd_una += 1, which leads to
   tp->snd_una > tp->snd_nxt inconsistency, that later panics in
   socket buffer code.

For reference, this bug fixed in DragonflyBSD repo:

http://gitweb.dragonflybsd.org/dragonfly.git/commitdiff/1ff9b7d322dc5a26f7173aa8c38ecb79da80e419

Reviewed by:	andre
Tested by:	pho
Sponsored by:	Nginx, Inc.
PR:		kern/177456
Submitted by:	HouYeFei&XiBoLiu <lglion718 163.com>
2013-04-11 18:23:56 +00:00
..
2011-04-13 11:28:46 +00:00
2013-01-31 08:55:21 +00:00
2012-01-24 14:27:14 +00:00
2013-04-10 08:09:25 +00:00
2013-01-31 08:55:21 +00:00
2012-08-07 07:52:25 +00:00
2012-10-12 09:24:24 +00:00
2012-09-06 07:03:56 +00:00
2012-11-25 14:25:08 +00:00
2012-06-25 17:15:09 +00:00
2012-11-17 20:04:04 +00:00
2012-05-24 23:03:23 +00:00
2012-11-27 19:07:28 +00:00