📄 rtt.c
字号:
/* include rtt1 */#include "unprtt.h"int rtt_d_flag = 0; /* debug flag; can be set nonzero by caller *//* * Calculate the RTO value based on current estimators: * smoothed RTT plus four times the deviation. */#define RTT_RTOCALC(ptr) ((ptr)->rtt_srtt + (4.0 * (ptr)->rtt_rttvar))static floatrtt_minmax(float rto){ if (rto < RTT_RXTMIN) rto = RTT_RXTMIN; else if (rto > RTT_RXTMAX) rto = RTT_RXTMAX; return(rto);}voidrtt_init(struct rtt_info *ptr){ struct timeval tv; Gettimeofday(&tv, NULL); ptr->rtt_base = tv.tv_sec; /* #sec since 1/1/1970 at start */ ptr->rtt_rtt = 0; ptr->rtt_srtt = 0; ptr->rtt_rttvar = 0.75; ptr->rtt_rto = rtt_minmax(RTT_RTOCALC(ptr)); /* first RTO at (srtt + (4 * rttvar)) = 3 seconds */}/* end rtt1 *//* * Return the current timestamp. * Our timestamps are 32-bit integers that count milliseconds since * rtt_init() was called. *//* include rtt_ts */uint32_trtt_ts(struct rtt_info *ptr){ uint32_t ts; struct timeval tv; Gettimeofday(&tv, NULL); ts = ((tv.tv_sec - ptr->rtt_base) * 1000) + (tv.tv_usec / 1000); return(ts);}voidrtt_newpack(struct rtt_info *ptr){ ptr->rtt_nrexmt = 0;}intrtt_start(struct rtt_info *ptr){ return((int) (ptr->rtt_rto + 0.5)); /* round float to int */ /* 4return value can be used as: alarm(rtt_start(&foo)) */}/* end rtt_ts *//* * A response was received. * Stop the timer and update the appropriate values in the structure * based on this packet's RTT. We calculate the RTT, then update the * estimators of the RTT and its mean deviation. * This function should be called right after turning off the * timer with alarm(0), or right after a timeout occurs. *//* include rtt_stop */voidrtt_stop(struct rtt_info *ptr, uint32_t ms){ double delta; ptr->rtt_rtt = ms / 1000.0; /* measured RTT in seconds */ /* * Update our estimators of RTT and mean deviation of RTT. * See Jacobson's SIGCOMM '88 paper, Appendix A, for the details. * We use floating point here for simplicity. */ delta = ptr->rtt_rtt - ptr->rtt_srtt; ptr->rtt_srtt += delta / 8; /* g = 1/8 */ if (delta < 0.0) delta = -delta; /* |delta| */ ptr->rtt_rttvar += (delta - ptr->rtt_rttvar) / 4; /* h = 1/4 */ ptr->rtt_rto = rtt_minmax(RTT_RTOCALC(ptr));}/* end rtt_stop *//* * A timeout has occurred. * Return -1 if it's time to give up, else return 0. *//* include rtt_timeout */intrtt_timeout(struct rtt_info *ptr){ ptr->rtt_rto *= 2; /* next RTO */ if (++ptr->rtt_nrexmt > RTT_MAXNREXMT) return(-1); /* time to give up for this packet */ return(0);}/* end rtt_timeout *//* * Print debugging information on stderr, if the "rtt_d_flag" is nonzero. */voidrtt_debug(struct rtt_info *ptr){ if (rtt_d_flag == 0) return; fprintf(stderr, "rtt = %.3f, srtt = %.3f, rttvar = %.3f, rto = %.3f\n", ptr->rtt_rtt, ptr->rtt_srtt, ptr->rtt_rttvar, ptr->rtt_rto); fflush(stderr);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -