Chinaunix
标题:
拥塞控制tcp_fastretrans_alert()疑问
[打印本页]
作者:
remaper
时间:
2013-06-25 12:21
标题:
拥塞控制tcp_fastretrans_alert()疑问
内核版本:2.6.34
tcp_input.c: tcp_fastretrans_alert()函数,如下:
if (icsk->icsk_ca_state <= TCP_CA_Disorder)
tcp_try_undo_dsack(sk);
复制代码
这里判断是否需要从disorder恢复,然后我们看看tcp_try_undo_dsack这个函数:
/* Try to undo cwnd reduction, because D-SACKs acked all retransmitted data */
static void tcp_try_undo_dsack(struct sock *sk)
{
struct tcp_sock *tp = tcp_sk(sk);
if (tp->undo_marker && !tp->undo_retrans) {
DBGUNDO(sk, "D-SACK");
tcp_undo_cwr(sk, true);
tp->undo_marker = 0;
NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPDSACKUNDO);
}
}
复制代码
这里为什么需要调用undo_cwr?
作者:
firocu
时间:
2013-08-21 10:58
本帖最后由 firocu 于 2013-08-21 11:00 编辑
个人理解:
首先要区分 tcp_undo_cwr中cwr和TCP_CA_CWR根本就是两回事儿。
前者:还原因为错误预测拥塞而被我们减小的窗口。
后者:标志一种拥塞状态。
所以这里,显然 if (tp->undo_marker && !tp->undo_retrans)如果为真,却是使我们错误的进行拥塞处理。
则我们理所应当的要还原了。
tcp_undo_cwr(sk, true);就是还原到之前sstresh 和cwnd。
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2