tcprtt.c

来自「TCP-IP红宝书源代码」· C语言 代码 · 共 49 行

C
49
字号
/* tcprtt.c - tcprtt */

#include <conf.h>
#include <kernel.h>
#include <network.h>

/*------------------------------------------------------------------------
 *  tcprtt - do round trip time estimates & cong. window processing
 *------------------------------------------------------------------------
 */
int
tcprtt(struct tcb *ptcb)
{
	int	rrt,		/* raw round trip		*/
		delta;		/* deviation from smoothed	*/

	rrt = tmclear(tcps_oport, MKEVENT(RETRANSMIT, ptcb-&tcbtab[0]));
	if (rrt != SYSERR && ptcb->tcb_ostate != TCPO_REXMT) {
		if (ptcb->tcb_srt == 0)
			ptcb->tcb_srt = rrt<<3;	/* prime the pump */
		/*
		 * "srt" is scaled X 8 here, so this is really:
		 *	delta = rrt - srt
		 */
		delta = rrt - (ptcb->tcb_srt>>3);
		ptcb->tcb_srt += delta;		/* srt = srt + delta/8	*/
		if (delta < 0)
			delta = -delta;
		/*
		 * "rtde" is scaled X 4 here, so this is really:
		 *	rtde = rtde + (|delta| - rtde)/4
		 */
		ptcb->tcb_rtde += delta - (ptcb->tcb_rtde>>2);
		/*
		 * "srt" is scaled X 8, rtde scaled X 4, so this is:
		 *	rto = srt + 2 * rtde
		 */
		ptcb->tcb_rexmt = ((ptcb->tcb_srt>>2)+ptcb->tcb_rtde)>>1;
		if (ptcb->tcb_rexmt < TCP_MINRXT)
			ptcb->tcb_rexmt = TCP_MINRXT;
	}
	if (ptcb->tcb_cwnd < ptcb->tcb_ssthresh)
		ptcb->tcb_cwnd += ptcb->tcb_smss;
	else
		ptcb->tcb_cwnd += (ptcb->tcb_smss * ptcb->tcb_smss) /
	 		ptcb->tcb_cwnd;
	return OK;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?