Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp863053pxb; Tue, 1 Feb 2022 12:01:19 -0800 (PST) X-Google-Smtp-Source: ABdhPJykBOXhbG7RKYTnLNpqh+hXp2UaGBHOCqqcat5fJVgW2pfw0EUT4cJ9Znr9uukm+T7ns4pE X-Received: by 2002:a62:b618:: with SMTP id j24mr26515945pff.69.1643745678884; Tue, 01 Feb 2022 12:01:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643745678; cv=none; d=google.com; s=arc-20160816; b=SY6E7dG5GRM2QgeDm2U/7LkUuUgvrM2lTV2evTUKi+bxt91DzuE0hlxn8CH4U31ki4 Htn26IvETfZSpugRLFiT3mmZKz8kEqbF/3Rlz/7fhOwNrN7HXgbR6kP7hhBiWdte7YyP 1KTrLq3ESbqmQxeGTUn6LqFlQ2Y0UorO6ujqzI0qOuYoUmb8xn8Gu7JqCC7Im56DkILu Bo7ChwbkCiMpzBC73XsSXm9KiecXAaqqyF0hYirbrYktHugUBz5e81m9fzJ6TXGpSmQA oS2ifXErRBKPbcGzEKgs1hTQBpBuDGDcrXo8VrhTZRvEk8OxixeGE67XPfDxlRwFGL7Y m3cA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=d5i5cggI0rOVqOdzUSm55mBtvJdoETj0+0BCqaHDE2k=; b=cMdYhZY0M47VhZ8rvFV30+DVHItxA5ROMiOsKKCAzGO34hp/Ywp/3VD5etq6sTQkCI CPq0/6604uEhA1d0UkLrcBGeoz49dDC+WRvlar9rtSQocE/dcnIakW159/FYa4z00XEQ kNHNmg6Bag/E72qUZXOzXDdfgxm7uSCMjXhj5r26vuLTcoZRGXoxBfxPjrouVp/Rcekj 5ZfIrS5dG3u3oi914k/5VFgwxkoUS5MU+R/VcvLBtViNeA/regJNwidEZSXfb5B9RalQ naOCywCP2HOdBvG14v9q8RdtM+f2DjU2capx6+d3s64l694+NugJJQN0lZm7XRBcoxTJ QfIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="RCUdZo/h"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j3si16243525pfr.288.2022.02.01.12.01.07; Tue, 01 Feb 2022 12:01:18 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="RCUdZo/h"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1376761AbiAaLNM (ORCPT + 99 others); Mon, 31 Jan 2022 06:13:12 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44482 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1377235AbiAaLJt (ORCPT ); Mon, 31 Jan 2022 06:09:49 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 08CE9C061398; Mon, 31 Jan 2022 03:06:41 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id A79E5B82A60; Mon, 31 Jan 2022 11:06:40 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 25373C340EF; Mon, 31 Jan 2022 11:06:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643627199; bh=hRKTuIsnl4WN0VxrzUwjAAfV/KmgykqxL+AVfx9ryCM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=RCUdZo/h1DrWQTvBFsIjnh1ZkJRwuCuVYZ9ea/VYApRNJ69DAV2V2y23FWJfwTTBL IIi1hx8e6upOs/H6zx+NHcJhhUmDH+QljbRrmVWrMzsSOf7sSTooSOdqYgs8nW7BkA trE35hylR4zBtE79ceB9EWy3RDP7STzTacrxKS9w= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Marc Dionne , David Howells , linux-afs@lists.infradead.org, "David S. Miller" , Sasha Levin Subject: [PATCH 5.10 076/100] rxrpc: Adjust retransmission backoff Date: Mon, 31 Jan 2022 11:56:37 +0100 Message-Id: <20220131105222.987434426@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220131105220.424085452@linuxfoundation.org> References: <20220131105220.424085452@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: David Howells [ Upstream commit 2c13c05c5ff4b9fc907b07f7311821910ebaaf8a ] Improve retransmission backoff by only backing off when we retransmit data packets rather than when we set the lost ack timer. To this end: (1) In rxrpc_resend(), use rxrpc_get_rto_backoff() when setting the retransmission timer and only tell it that we are retransmitting if we actually have things to retransmit. Note that it's possible for the retransmission algorithm to race with the processing of a received ACK, so we may see no packets needing retransmission. (2) In rxrpc_send_data_packet(), don't bump the backoff when setting the ack_lost_at timer, as it may then get bumped twice. With this, when looking at one particular packet, the retransmission intervals were seen to be 1.5ms, 2ms, 3ms, 5ms, 9ms, 17ms, 33ms, 71ms, 136ms, 264ms, 544ms, 1.088s, 2.1s, 4.2s and 8.3s. Fixes: c410bf01933e ("rxrpc: Fix the excessive initial retransmission timeout") Suggested-by: Marc Dionne Signed-off-by: David Howells Reviewed-by: Marc Dionne Tested-by: Marc Dionne cc: linux-afs@lists.infradead.org Link: https://lore.kernel.org/r/164138117069.2023386.17446904856843997127.stgit@warthog.procyon.org.uk/ Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- net/rxrpc/call_event.c | 8 +++----- net/rxrpc/output.c | 2 +- 2 files changed, 4 insertions(+), 6 deletions(-) diff --git a/net/rxrpc/call_event.c b/net/rxrpc/call_event.c index 6be2672a65eab..df864e6922679 100644 --- a/net/rxrpc/call_event.c +++ b/net/rxrpc/call_event.c @@ -157,7 +157,7 @@ static void rxrpc_congestion_timeout(struct rxrpc_call *call) static void rxrpc_resend(struct rxrpc_call *call, unsigned long now_j) { struct sk_buff *skb; - unsigned long resend_at, rto_j; + unsigned long resend_at; rxrpc_seq_t cursor, seq, top; ktime_t now, max_age, oldest, ack_ts; int ix; @@ -165,10 +165,8 @@ static void rxrpc_resend(struct rxrpc_call *call, unsigned long now_j) _enter("{%d,%d}", call->tx_hard_ack, call->tx_top); - rto_j = call->peer->rto_j; - now = ktime_get_real(); - max_age = ktime_sub(now, jiffies_to_usecs(rto_j)); + max_age = ktime_sub(now, jiffies_to_usecs(call->peer->rto_j)); spin_lock_bh(&call->lock); @@ -213,7 +211,7 @@ static void rxrpc_resend(struct rxrpc_call *call, unsigned long now_j) } resend_at = nsecs_to_jiffies(ktime_to_ns(ktime_sub(now, oldest))); - resend_at += jiffies + rto_j; + resend_at += jiffies + rxrpc_get_rto_backoff(call->peer, retrans); WRITE_ONCE(call->resend_at, resend_at); if (unacked) diff --git a/net/rxrpc/output.c b/net/rxrpc/output.c index 10f2bf2e9068a..a45c83f22236e 100644 --- a/net/rxrpc/output.c +++ b/net/rxrpc/output.c @@ -468,7 +468,7 @@ done: if (call->peer->rtt_count > 1) { unsigned long nowj = jiffies, ack_lost_at; - ack_lost_at = rxrpc_get_rto_backoff(call->peer, retrans); + ack_lost_at = rxrpc_get_rto_backoff(call->peer, false); ack_lost_at += nowj; WRITE_ONCE(call->ack_lost_at, ack_lost_at); rxrpc_reduce_call_timer(call, ack_lost_at, nowj, -- 2.34.1