lib,rlc_am_nr: stop/restart reassembly timer for segmented SDUs with gaps

master
Robert Falkenberg 3 years ago
parent d8cb4ec700
commit 77ae5182a6

@ -1189,12 +1189,11 @@ void rlc_am_nr_rx::handle_data_pdu(uint8_t* payload, uint32_t nof_bytes)
if (st.rx_next_status_trigger == st.rx_next) { if (st.rx_next_status_trigger == st.rx_next) {
stop_reassembly_timer = true; stop_reassembly_timer = true;
} }
// TODO: Finish this condition if (rx_mod_base_nr(st.rx_next_status_trigger) == rx_mod_base_nr(st.rx_next + 1)) {
// if (rx_mod_base_nr(st.rx_next_status_trigger) == rx_mod_base_nr(st.rx_next + 1)) { if (not(*rx_window)[st.rx_next].has_gap) {
// if (not (*rx_window)[st.rx_next].has_segment_gap) { stop_reassembly_timer = true;
// stop_reassembly_timer = true; }
// } }
// }
if (not inside_rx_window(st.rx_next_status_trigger)) { if (not inside_rx_window(st.rx_next_status_trigger)) {
stop_reassembly_timer = true; stop_reassembly_timer = true;
} }
@ -1217,9 +1216,7 @@ void rlc_am_nr_rx::handle_data_pdu(uint8_t* payload, uint32_t nof_bytes)
restart_reassembly_timer = true; restart_reassembly_timer = true;
} }
if (rx_mod_base_nr(st.rx_next_highest) == rx_mod_base_nr(st.rx_next + 1)) { if (rx_mod_base_nr(st.rx_next_highest) == rx_mod_base_nr(st.rx_next + 1)) {
// TODO: Replace this condition by if (rx_window->has_sn(st.rx_next) && (*rx_window)[st.rx_next].has_gap) {
// if ((*rx_window)[st.rx_next].has_segment_gap) {
if (rx_window->has_sn(st.rx_next) && not(*rx_window)[st.rx_next].fully_received) {
restart_reassembly_timer = true; restart_reassembly_timer = true;
} }
} }
@ -1447,10 +1444,7 @@ void rlc_am_nr_rx::timer_expired(uint32_t timeout_id)
restart_reassembly_timer = true; restart_reassembly_timer = true;
} }
if (rx_mod_base_nr(st.rx_next_highest) == rx_mod_base_nr(st.rx_highest_status + 1)) { if (rx_mod_base_nr(st.rx_next_highest) == rx_mod_base_nr(st.rx_highest_status + 1)) {
// TODO: Replace this condition "not(*rx_window)[st.rx_highest_status].fully_received" by if (rx_window->has_sn(st.rx_highest_status) && (*rx_window)[st.rx_highest_status].has_gap) {
// if ((*rx_window)[st.rx_next].has_segment_gap) {
if (not rx_window->has_sn(st.rx_highest_status) ||
(rx_window->has_sn(st.rx_highest_status) && not(*rx_window)[st.rx_highest_status].fully_received)) {
restart_reassembly_timer = true; restart_reassembly_timer = true;
} }
} }

Loading…
Cancel
Save