From 7c42b09e896a35d55480b7d1083cf1f078e1311e Mon Sep 17 00:00:00 2001 From: Pedro Alvarez Date: Tue, 3 May 2022 09:21:52 +0100 Subject: [PATCH] lib,rlc_am_nr: check if rx ACK is smaller than current Tx_Next_Ack --- lib/src/rlc/rlc_am_nr.cc | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/lib/src/rlc/rlc_am_nr.cc b/lib/src/rlc/rlc_am_nr.cc index a5c66a9d6..a04386775 100644 --- a/lib/src/rlc/rlc_am_nr.cc +++ b/lib/src/rlc/rlc_am_nr.cc @@ -800,8 +800,15 @@ void rlc_am_nr_tx::handle_control_pdu(uint8_t* payload, uint32_t nof_bytes) uint32_t stop_sn = status.nacks.size() == 0 ? status.ack_sn : status.nacks[0].nack_sn; // Stop processing ACKs at the first NACK, if it exists. + + if (tx_mod_base_nr(stop_sn) < tx_mod_base_nr(st.tx_next_ack)) { + RlcInfo( + "Received ACK or NACK with SN=%d smaller than TX_NEXT_ACK=%d. Ignoring status report", stop_sn, st.tx_next_ack); + info_state(); + return; + } if (tx_mod_base_nr(stop_sn) > tx_mod_base_nr(st.tx_next)) { - RlcError("Received ACK or NACK with SN=%d larger than TX_NEXT=%d. Ignoring status report", stop_sn, st.tx_next); + RlcInfo("Received ACK or NACK with SN=%d larger than TX_NEXT=%d. Ignoring status report", stop_sn, st.tx_next); info_state(); return; }