From: Gerrit Renker Date: Mon, 27 Nov 2006 14:25:10 +0000 (-0200) Subject: [DCCP] ccid3: Fix calculation of t_ipi time of scheduled transmission X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=91cf5a17257e1d2ef936fbf0223c3436ca583af9;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git [DCCP] ccid3: Fix calculation of t_ipi time of scheduled transmission Problem: --- diff --git a/net/dccp/ccids/ccid3.c b/net/dccp/ccids/ccid3.c index df88c54b2ec5..fb1a5e89c023 100644 --- a/net/dccp/ccids/ccid3.c +++ b/net/dccp/ccids/ccid3.c @@ -304,11 +304,19 @@ static int ccid3_hc_tx_send_packet(struct sock *sk, break; case TFRC_SSTATE_NO_FBACK: case TFRC_SSTATE_FBACK: - delay = (timeval_delta(&now, &hctx->ccid3hctx_t_nom) - - hctx->ccid3hctx_delta); - delay /= -1000; - /* divide by -1000 is to convert to ms and get sign right */ - rc = delay > 0 ? delay : 0; + delay = timeval_delta(&hctx->ccid3hctx_t_nom, &now); + /* + * Scheduling of packet transmissions [RFC 3448, 4.6] + * + * if (t_now > t_nom - delta) + * // send the packet now + * else + * // send the packet in (t_nom - t_now) milliseconds. + */ + if (delay < hctx->ccid3hctx_delta) + rc = 0; + else + rc = delay/1000L; break; case TFRC_SSTATE_TERM: DCCP_BUG("Illegal %s state TERM, sk=%p", dccp_role(sk), sk);