From d005ec8f9bf07d7461ac2183b33caa66c1d025f6 Mon Sep 17 00:00:00 2001 From: ismagom Date: Thu, 4 Jun 2015 11:38:51 +0100 Subject: [PATCH] MAC MUX rounding up SDU payload size --- srsapps/ue/mac/src/mux.cc | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/srsapps/ue/mac/src/mux.cc b/srsapps/ue/mac/src/mux.cc index 9d2e57f21..eedd53a03 100644 --- a/srsapps/ue/mac/src/mux.cc +++ b/srsapps/ue/mac/src/mux.cc @@ -239,6 +239,7 @@ bool mux::assemble_pdu(uint32_t pdu_sz_nbits) { } // MAC control element for PHR // TODO + printf("1 nof_subh=%d, rem_size=%d\n", pdu_msg.nof_subh(), pdu_msg.rem_size()); // data from any Logical Channel, except data from UL-CCCH; // first only those with positive Bj @@ -251,12 +252,15 @@ bool mux::assemble_pdu(uint32_t pdu_sz_nbits) { } } } + printf("2 nof_subh=%d, rem_size=%d\n", pdu_msg.nof_subh(), pdu_msg.rem_size()); // If resources remain, allocate regardless of their Bj value for (int i=0;igenerate_bsr_on_ul_grant(pdu_msg.rem_size(), &bsr); // Insert Padding BSR if not inserted Regular/Periodic BSR if (!bsr_payload_sz && send_bsr) { @@ -309,16 +313,19 @@ bool mux::allocate_sdu(uint32_t lcid, sch_pdu *pdu_msg, uint32_t *sdu_sz, bool * uint32_t buff_len = 0; uint8_t *buff_ptr = (uint8_t*) mac_io_h->get(mac_io::MAC_LCH_CCCH_UL + lcid)->pop(&buff_len, nof_tx_pkts[lcid]); + uint32_t nbytes = (buff_len-1)/8 + 1; + if (buff_ptr && buff_len > 0) { // there is pending SDU to allocate if (sdu_sz) { *sdu_sz = buff_len; } if (pdu_msg->new_subh()) { // there is space for a new subheader pdu_msg->next(); - if (pdu_msg->get()->set_sdu(lcid, buff_ptr, buff_len/8, is_first?*is_first:false)) { // new SDU could be added + if (pdu_msg->get()->set_sdu(lcid, buff_ptr, nbytes, is_first?*is_first:false)) { // new SDU could be added if (is_first) { *is_first = false; } + Info("Allocated SDU lcid=%d nbytes=%d\n", lcid, nbytes); // Increase number of pop'ed packets from queue nof_tx_pkts[lcid]++; return true;