rlc, nr: increment sequence numbers using modulus 'mod_nr'

master
Robert Falkenberg 3 years ago
parent 8f6e3996d3
commit c75b8d1708

@ -197,7 +197,7 @@ uint32_t rlc_am_nr_tx::build_new_pdu(uint8_t* payload, uint32_t nof_bytes)
} }
// Update TX Next // Update TX Next
st.tx_next = (st.tx_next + 1) % MOD; st.tx_next = (st.tx_next + 1) % mod_nr;
memcpy(payload, tx_sdu->msg, tx_sdu->N_bytes); memcpy(payload, tx_sdu->msg, tx_sdu->N_bytes);
RlcDebug("wrote RLC PDU - %d bytes", tx_sdu->N_bytes); RlcDebug("wrote RLC PDU - %d bytes", tx_sdu->N_bytes);
@ -374,8 +374,8 @@ uint32_t rlc_am_nr_tx::build_continuation_sdu_segment(rlc_amd_tx_pdu_nr& tx_pdu,
RlcInfo("grant is large enough for full SDU." RlcInfo("grant is large enough for full SDU."
"Removing current SDU info"); "Removing current SDU info");
sdu_under_segmentation_sn = INVALID_RLC_SN; sdu_under_segmentation_sn = INVALID_RLC_SN;
// SDU is fully TX'ed. Increment TX_NEXt // SDU is fully TX'ed. Increment TX_NEXT
st.tx_next++; st.tx_next = (st.tx_next + 1) % mod_nr;
} }
return hdr_len + segment_payload_len; return hdr_len + segment_payload_len;
@ -710,7 +710,7 @@ void rlc_am_nr_tx::handle_control_pdu(uint8_t* payload, uint32_t nof_bytes)
if (tx_window.has_sn(sn)) { if (tx_window.has_sn(sn)) {
notify_info_vec.push_back(tx_window[sn].pdcp_sn); notify_info_vec.push_back(tx_window[sn].pdcp_sn);
tx_window.remove_pdu(sn); tx_window.remove_pdu(sn);
st.tx_next_ack = sn + 1; st.tx_next_ack = (sn + 1) % mod_nr;
} else { } else {
RlcError("Missing ACKed SN from TX window"); RlcError("Missing ACKed SN from TX window");
break; break;
@ -978,7 +978,7 @@ void rlc_am_nr_rx::handle_data_pdu(uint8_t* payload, uint32_t nof_bytes)
// 5.2.3.2.3 Actions when an AMD PDU is placed in the reception buffer // 5.2.3.2.3 Actions when an AMD PDU is placed in the reception buffer
// Update Rx_Next_Highest // Update Rx_Next_Highest
if (rx_mod_base_nr(header.sn) >= rx_mod_base_nr(st.rx_next_highest)) { if (rx_mod_base_nr(header.sn) >= rx_mod_base_nr(st.rx_next_highest)) {
st.rx_next_highest = (header.sn + 1) % MOD; st.rx_next_highest = (header.sn + 1) % mod_nr;
} }
// Update RX_Highest_Status // Update RX_Highest_Status
@ -1203,7 +1203,7 @@ uint32_t rlc_am_nr_rx::get_status_pdu(rlc_am_nr_status_pdu_t* status, uint32_t m
// make sure we don't exceed grant size (FIXME) // make sure we don't exceed grant size (FIXME)
rlc_am_nr_write_status_pdu(*status, rlc_am_nr_sn_size_t::size12bits, &tmp_buf); rlc_am_nr_write_status_pdu(*status, rlc_am_nr_sn_size_t::size12bits, &tmp_buf);
// TODO // TODO
i = (i + 1) % MOD; i = (i + 1) % mod_nr;
} }
if (max_len != UINT32_MAX) { if (max_len != UINT32_MAX) {

Loading…
Cancel
Save