|
|
@ -44,7 +44,6 @@ void pdcp_entity_lte::init(uint32_t lcid_, pdcp_config_t cfg_)
|
|
|
|
cfg = cfg_;
|
|
|
|
cfg = cfg_;
|
|
|
|
active = true;
|
|
|
|
active = true;
|
|
|
|
tx_count = 0;
|
|
|
|
tx_count = 0;
|
|
|
|
rx_count = 0;
|
|
|
|
|
|
|
|
integrity_direction = DIRECTION_NONE;
|
|
|
|
integrity_direction = DIRECTION_NONE;
|
|
|
|
encryption_direction = DIRECTION_NONE;
|
|
|
|
encryption_direction = DIRECTION_NONE;
|
|
|
|
|
|
|
|
|
|
|
@ -72,17 +71,15 @@ void pdcp_entity_lte::reestablish()
|
|
|
|
log->info("Re-establish %s with bearer ID: %d\n", rrc->get_rb_name(lcid).c_str(), cfg.bearer_id);
|
|
|
|
log->info("Re-establish %s with bearer ID: %d\n", rrc->get_rb_name(lcid).c_str(), cfg.bearer_id);
|
|
|
|
// For SRBs
|
|
|
|
// For SRBs
|
|
|
|
if (is_srb()) {
|
|
|
|
if (is_srb()) {
|
|
|
|
tx_count = 0;
|
|
|
|
tx_count = 0;
|
|
|
|
rx_count = 0;
|
|
|
|
rx_hfn = 0;
|
|
|
|
rx_hfn = 0;
|
|
|
|
next_pdcp_rx_sn = 0;
|
|
|
|
next_pdcp_rx_sn = 0;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
// Only reset counter in RLC-UM
|
|
|
|
// Only reset counter in RLC-UM
|
|
|
|
if (rlc->rb_is_um(lcid)) {
|
|
|
|
if (rlc->rb_is_um(lcid)) {
|
|
|
|
tx_count = 0;
|
|
|
|
tx_count = 0;
|
|
|
|
rx_count = 0;
|
|
|
|
rx_hfn = 0;
|
|
|
|
rx_hfn = 0;
|
|
|
|
next_pdcp_rx_sn = 0;
|
|
|
|
next_pdcp_rx_sn = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -197,8 +194,6 @@ void pdcp_entity_lte::handle_srb_pdu(srslte::unique_byte_buffer_t pdu)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
rx_count = sn;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Discard header
|
|
|
|
// Discard header
|
|
|
|
discard_data_header(pdu);
|
|
|
|
discard_data_header(pdu);
|
|
|
|
|
|
|
|
|
|
|
@ -234,8 +229,6 @@ void pdcp_entity_lte::handle_um_drb_pdu(srslte::unique_byte_buffer_t pdu)
|
|
|
|
log->debug_hex(pdu->msg, pdu->N_bytes, "%s Rx PDU (decrypted)", rrc->get_rb_name(lcid).c_str());
|
|
|
|
log->debug_hex(pdu->msg, pdu->N_bytes, "%s Rx PDU (decrypted)", rrc->get_rb_name(lcid).c_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
rx_count = sn;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
next_pdcp_rx_sn = sn + 1;
|
|
|
|
next_pdcp_rx_sn = sn + 1;
|
|
|
|
if (next_pdcp_rx_sn > maximum_pdcp_sn) {
|
|
|
|
if (next_pdcp_rx_sn > maximum_pdcp_sn) {
|
|
|
|
next_pdcp_rx_sn = 0;
|
|
|
|
next_pdcp_rx_sn = 0;
|
|
|
@ -302,8 +295,6 @@ void pdcp_entity_lte::handle_am_drb_pdu(srslte::unique_byte_buffer_t pdu)
|
|
|
|
// Update info on last PDU submitted to upper layers
|
|
|
|
// Update info on last PDU submitted to upper layers
|
|
|
|
last_submitted_pdcp_rx_sn = sn;
|
|
|
|
last_submitted_pdcp_rx_sn = sn;
|
|
|
|
|
|
|
|
|
|
|
|
rx_count = sn;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Pass to upper layers
|
|
|
|
// Pass to upper layers
|
|
|
|
log->info_hex(pdu->msg, pdu->N_bytes, "%s Rx PDU SN=%d", rrc->get_rb_name(lcid).c_str(), sn);
|
|
|
|
log->info_hex(pdu->msg, pdu->N_bytes, "%s Rx PDU SN=%d", rrc->get_rb_name(lcid).c_str(), sn);
|
|
|
|
gw->write_pdu(lcid, std::move(pdu));
|
|
|
|
gw->write_pdu(lcid, std::move(pdu));
|
|
|
@ -312,9 +303,9 @@ void pdcp_entity_lte::handle_am_drb_pdu(srslte::unique_byte_buffer_t pdu)
|
|
|
|
/****************************************************************************
|
|
|
|
/****************************************************************************
|
|
|
|
* Security functions
|
|
|
|
* Security functions
|
|
|
|
***************************************************************************/
|
|
|
|
***************************************************************************/
|
|
|
|
uint32_t pdcp_entity_lte::get_dl_count()
|
|
|
|
uint32_t pdcp_entity_lte::get_last_submitted_rx_count()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return rx_count;
|
|
|
|
return COUNT(rx_hfn, last_submitted_pdcp_rx_sn);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
uint32_t pdcp_entity_lte::get_ul_count()
|
|
|
|
uint32_t pdcp_entity_lte::get_ul_count()
|
|
|
@ -328,20 +319,16 @@ void pdcp_entity_lte::get_bearer_status(uint16_t* dlsn, uint16_t* dlhfn, uint16_
|
|
|
|
if (12 == cfg.sn_len) {
|
|
|
|
if (12 == cfg.sn_len) {
|
|
|
|
*dlsn = (uint16_t)(tx_count & 0xFFFu);
|
|
|
|
*dlsn = (uint16_t)(tx_count & 0xFFFu);
|
|
|
|
*dlhfn = (uint16_t)((tx_count - *dlsn) >> 12u);
|
|
|
|
*dlhfn = (uint16_t)((tx_count - *dlsn) >> 12u);
|
|
|
|
*ulsn = (uint16_t)(rx_count & 0xFFFu);
|
|
|
|
|
|
|
|
*ulhfn = (uint16_t)((rx_count - *ulsn) >> 12u);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
*dlsn = (uint16_t)(tx_count & 0x7Fu);
|
|
|
|
*dlsn = (uint16_t)(tx_count & 0x7Fu);
|
|
|
|
*dlhfn = (uint16_t)((tx_count - *dlsn) >> 7u);
|
|
|
|
*dlhfn = (uint16_t)((tx_count - *dlsn) >> 7u);
|
|
|
|
*ulsn = (uint16_t)(rx_count & 0x7Fu);
|
|
|
|
|
|
|
|
*ulhfn = (uint16_t)((rx_count - *ulsn) >> 7u);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else { // is control
|
|
|
|
} else { // is control
|
|
|
|
*dlsn = (uint16_t)(tx_count & 0x1Fu);
|
|
|
|
*dlsn = (uint16_t)(tx_count & 0x1Fu);
|
|
|
|
*dlhfn = (uint16_t)((tx_count - *dlsn) >> 5u);
|
|
|
|
*dlhfn = (uint16_t)((tx_count - *dlsn) >> 5u);
|
|
|
|
*ulsn = (uint16_t)(rx_count & 0x1Fu);
|
|
|
|
|
|
|
|
*ulhfn = (uint16_t)((rx_count - *ulsn) >> 5u);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
*ulsn = (uint16_t)next_pdcp_rx_sn;
|
|
|
|
|
|
|
|
*ulhfn = (uint16_t)rx_hfn;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace srslte
|
|
|
|
} // namespace srslte
|
|
|
|