|
|
@ -41,7 +41,6 @@ mac::mac(const char* logname, ext_task_sched_handle task_sched_) :
|
|
|
|
dl_harq.at(PCELL_CC_IDX) = dl_harq_entity_ptr(new dl_harq_entity(PCELL_CC_IDX));
|
|
|
|
dl_harq.at(PCELL_CC_IDX) = dl_harq_entity_ptr(new dl_harq_entity(PCELL_CC_IDX));
|
|
|
|
|
|
|
|
|
|
|
|
srsran_softbuffer_rx_init(&pch_softbuffer, 100);
|
|
|
|
srsran_softbuffer_rx_init(&pch_softbuffer, 100);
|
|
|
|
srsran_softbuffer_rx_init(&mch_softbuffer, 100);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Keep initialising members
|
|
|
|
// Keep initialising members
|
|
|
|
bzero(&metrics, sizeof(mac_metrics_t));
|
|
|
|
bzero(&metrics, sizeof(mac_metrics_t));
|
|
|
@ -53,7 +52,6 @@ mac::~mac()
|
|
|
|
stop();
|
|
|
|
stop();
|
|
|
|
|
|
|
|
|
|
|
|
srsran_softbuffer_rx_free(&pch_softbuffer);
|
|
|
|
srsran_softbuffer_rx_free(&pch_softbuffer);
|
|
|
|
srsran_softbuffer_rx_free(&mch_softbuffer);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool mac::init(phy_interface_mac_lte* phy, rlc_interface_mac* rlc, rrc_interface_mac* rrc)
|
|
|
|
bool mac::init(phy_interface_mac_lte* phy, rlc_interface_mac* rlc, rrc_interface_mac* rrc)
|
|
|
@ -324,12 +322,12 @@ void mac::bch_decoded_ok(uint32_t cc_idx, uint8_t* payload, uint32_t len)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void mac::mch_decoded(uint32_t len, bool crc)
|
|
|
|
void mac::mch_decoded(uint32_t len, bool crc, uint8_t* payload)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Parse MAC header
|
|
|
|
// Parse MAC header
|
|
|
|
if (crc) {
|
|
|
|
if (crc) {
|
|
|
|
mch_msg.init_rx(len);
|
|
|
|
mch_msg.init_rx(len);
|
|
|
|
mch_msg.parse_packet(mch_payload_buffer);
|
|
|
|
mch_msg.parse_packet(payload);
|
|
|
|
while (mch_msg.next()) {
|
|
|
|
while (mch_msg.next()) {
|
|
|
|
for (uint32_t i = 0; i < phy_mbsfn_cfg.nof_mbsfn_services; i++) {
|
|
|
|
for (uint32_t i = 0; i < phy_mbsfn_cfg.nof_mbsfn_services; i++) {
|
|
|
|
if (srsran::mch_lcid::MCH_SCHED_INFO == mch_msg.get()->mch_ce_type()) {
|
|
|
|
if (srsran::mch_lcid::MCH_SCHED_INFO == mch_msg.get()->mch_ce_type()) {
|
|
|
@ -343,11 +341,11 @@ void mac::mch_decoded(uint32_t len, bool crc)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
demux_unit.push_pdu_mch(mch_payload_buffer, len);
|
|
|
|
demux_unit.push_pdu_mch(payload, len);
|
|
|
|
process_pdus();
|
|
|
|
process_pdus();
|
|
|
|
|
|
|
|
|
|
|
|
if (pcap) {
|
|
|
|
if (pcap) {
|
|
|
|
pcap->write_dl_mch(mch_payload_buffer, len, true, phy_h->get_current_tti(), 0);
|
|
|
|
pcap->write_dl_mch(payload, len, true, phy_h->get_current_tti(), 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::lock_guard<std::mutex> lock(metrics_mutex);
|
|
|
|
std::lock_guard<std::mutex> lock(metrics_mutex);
|
|
|
@ -521,14 +519,6 @@ void mac::new_grant_ul(uint32_t cc_idx,
|
|
|
|
} // end of holding metrics mutex
|
|
|
|
} // end of holding metrics mutex
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void mac::new_mch_dl(const srsran_pdsch_grant_t& phy_grant, tb_action_dl_t* action)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
action->generate_ack = false;
|
|
|
|
|
|
|
|
action->tb[0].enabled = true;
|
|
|
|
|
|
|
|
action->tb[0].payload = mch_payload_buffer;
|
|
|
|
|
|
|
|
action->tb[0].softbuffer.rx = &mch_softbuffer;
|
|
|
|
|
|
|
|
srsran_softbuffer_rx_reset_cb(&mch_softbuffer, 1);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void mac::setup_timers(int time_alignment_timer)
|
|
|
|
void mac::setup_timers(int time_alignment_timer)
|
|
|
|
{
|
|
|
|
{
|
|
|
|