Starting to add reordering queue in the PDCP.

master
Pedro Alvarez 5 years ago committed by Andre Puschmann
parent f06e1af4e0
commit 6cf2bd7bc3

@ -29,6 +29,7 @@
#include "srslte/common/log.h" #include "srslte/common/log.h"
#include "srslte/common/security.h" #include "srslte/common/security.h"
#include "srslte/common/threads.h" #include "srslte/common/threads.h"
#include <map>
namespace srslte { namespace srslte {
@ -65,6 +66,9 @@ private:
srsue::rrc_interface_pdcp* rrc = nullptr; srsue::rrc_interface_pdcp* rrc = nullptr;
srsue::gw_interface_pdcp* gw = nullptr; srsue::gw_interface_pdcp* gw = nullptr;
// Reordering Queue
std::map<uint32_t, unique_byte_buffer_t> reorder_queue;
// State variables: 3GPP TS 38.323 v15.2.0, section 7.1 // State variables: 3GPP TS 38.323 v15.2.0, section 7.1
uint32_t tx_next = 0; // COUNT value of next SDU to be transmitted. uint32_t tx_next = 0; // COUNT value of next SDU to be transmitted.
uint32_t rx_next = 0; // COUNT value of next SDU expected to be received. uint32_t rx_next = 0; // COUNT value of next SDU expected to be received.

@ -149,8 +149,13 @@ void pdcp_entity_nr::write_pdu(unique_byte_buffer_t pdu)
return; // Invalid count, drop. return; // Invalid count, drop.
} }
// TODO check if PDU has been received // Check if PDU has been received
// TODO Store PDU in reception buffer if (reorder_queue.find(rcvd_count) != reorder_queue.end()) {
return; // PDU already present, drop.
}
// Store PDU in reception buffer
reorder_queue[rcvd_count] = std::move(pdu);
// Update RX_NEXT // Update RX_NEXT
if (rcvd_count >= rx_next) { if (rcvd_count >= rx_next) {
@ -160,20 +165,29 @@ void pdcp_entity_nr::write_pdu(unique_byte_buffer_t pdu)
// TODO if out-of-order configured, submit to upper layer // TODO if out-of-order configured, submit to upper layer
if (rcvd_count == rx_deliv) { if (rcvd_count == rx_deliv) {
// Deliver to upper layers (TODO queueing needs to be implemented) // Deliver to upper layers in ascending order of associeted COUNT
if (is_srb()) { for (std::map<uint32_t, unique_byte_buffer_t>::iterator it = reorder_queue.begin();
rrc->write_pdu(lcid, std::move(pdu)); it != reorder_queue.end();) {
} else { if (it->first == rx_deliv) {
gw->write_pdu(lcid, std::move(pdu)); // Pass to upper layers
if (is_srb()) {
rrc->write_pdu(lcid, std::move(it->second));
} else {
gw->write_pdu(lcid, std::move(it->second));
}
// Remove from queue
reorder_queue.erase(it++);
// Update RX_DELIV
rx_deliv = rx_deliv + 1; // TODO needs to be corrected when queueing is implemented
printf("New RX_deliv %d, rcvd_count %d\n", rx_deliv, rcvd_count);
} else {
break;
}
} }
// Update RX_DELIV
rx_deliv = rcvd_count + 1; // TODO needs to be corrected when queueing is implemented
printf("New RX_deliv %d, rcvd_count %d\n", rx_deliv, rcvd_count);
} }
// Not clear how to update RX_DELIV without reception buffer (TODO)
// TODO handle reordering timers // TODO handle reordering timers
} }
@ -197,7 +211,6 @@ uint32_t pdcp_entity_nr::read_data_header(const unique_byte_buffer_t& pdu)
srslte::uint8_to_uint24(pdu->msg, &rcvd_sn_32); srslte::uint8_to_uint24(pdu->msg, &rcvd_sn_32);
rcvd_sn_32 = SN(rcvd_sn_32); rcvd_sn_32 = SN(rcvd_sn_32);
break; break;
break;
default: default:
log->error("Cannot extract RCVD_SN, invalid SN length configured: %d\n", cfg.sn_len); log->error("Cannot extract RCVD_SN, invalid SN length configured: %d\n", cfg.sn_len);
} }

Loading…
Cancel
Save