]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
batman-adv: tp_meter: initialize dup_acks explicitly
authorSven Eckelmann <sven@narfation.org>
Thu, 28 May 2026 19:14:39 +0000 (21:14 +0200)
committerSven Eckelmann <sven@narfation.org>
Wed, 3 Jun 2026 06:02:19 +0000 (08:02 +0200)
When an ack with a sequence number equal to the last_acked is received, the
dup_acks counter is increased to decide whether fast retransmit should be
performed. Only when the sequence numbers are not equal, the dup_acks is
set to the initial value (0).

But if the initial packet would have the sequence number
BATADV_TP_FIRST_SEQ, dup_acks would not be initialized and atomic_inc would
operate on an undefined starting value. It is therefore required to have it
explicitly initialized during the start of the sender session.

Cc: stable@kernel.org
Fixes: 33a3bb4a3345 ("batman-adv: throughput meter implementation")
Signed-off-by: Sven Eckelmann <sven@narfation.org>
net/batman-adv/tp_meter.c

index 0e39ea33e5f27dbd636b888f30ecb08a9965d48d..8d7308327a9bfa28a7aef536a1e6655656254ae9 100644 (file)
@@ -1045,6 +1045,7 @@ void batadv_tp_start(struct batadv_priv *bat_priv, const u8 *dst,
        tp_vars->icmp_uid = icmp_uid;
 
        tp_vars->last_sent = BATADV_TP_FIRST_SEQ;
+       atomic_set(&tp_vars->dup_acks, 0);
        atomic_set(&tp_vars->last_acked, BATADV_TP_FIRST_SEQ);
        tp_vars->fast_recovery = false;
        tp_vars->recover = BATADV_TP_FIRST_SEQ;