diff options
author | David Howells <dhowells@redhat.com> | 2016-09-23 13:39:23 +0200 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2016-09-23 16:35:45 +0200 |
commit | be8aa3380678183821bd7d7b5dec845f10d776ce (patch) | |
tree | 14e483a5c1e80d0259c8b1467183a61dce362ee4 /net/rxrpc/input.c | |
parent | rxrpc: Need to start the resend timer on initial transmission (diff) | |
download | linux-be8aa3380678183821bd7d7b5dec845f10d776ce.tar.xz linux-be8aa3380678183821bd7d7b5dec845f10d776ce.zip |
rxrpc: Fix accidental cancellation of scheduled resend by ACK parser
When rxrpc_input_soft_acks() is parsing the soft-ACKs from an ACK packet,
it updates the Tx packet annotations in the annotation buffer. If a
soft-ACK is an ACK, then we overwrite unack'd, nak'd or to-be-retransmitted
states and that is fine; but if the soft-ACK is an NACK, we overwrite the
to-be-retransmitted with a nak - which isn't.
Instead, we need to let any scheduled retransmission stand if the packet
was NAK'd.
Note that we don't reissue a resend if the annotation is in the
to-be-retransmitted state because someone else must've scheduled the
resend already.
Signed-off-by: David Howells <dhowells@redhat.com>
Diffstat (limited to 'net/rxrpc/input.c')
-rw-r--r-- | net/rxrpc/input.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/net/rxrpc/input.c b/net/rxrpc/input.c index 06027b6d9c19..d3d69ab1f0a1 100644 --- a/net/rxrpc/input.c +++ b/net/rxrpc/input.c @@ -479,6 +479,8 @@ static void rxrpc_input_soft_acks(struct rxrpc_call *call, u8 *acks, case RXRPC_ACK_TYPE_NACK: if (anno_type == RXRPC_TX_ANNO_NAK) continue; + if (anno_type == RXRPC_TX_ANNO_RETRANS) + continue; call->rxtx_annotations[ix] = RXRPC_TX_ANNO_NAK | annotation; resend = true; |