From 64e8a17ea82813ca4715aec155038a8aa95df6d3 Mon Sep 17 00:00:00 2001 From: Francisco Date: Fri, 12 Mar 2021 16:43:17 +0000 Subject: [PATCH] mac,bugfix - fix incorrect deallocation of PDU --- srsenb/src/stack/mac/ue.cc | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/srsenb/src/stack/mac/ue.cc b/srsenb/src/stack/mac/ue.cc index 51a446982..4d53de2e0 100644 --- a/srsenb/src/stack/mac/ue.cc +++ b/srsenb/src/stack/mac/ue.cc @@ -36,6 +36,7 @@ bool cc_used_buffers_map::push_pdu(tti_point tti, uint32_t len) if (len > 0) { shared_pdu_queue->push(pdu_pair.second, len); } else { + shared_pdu_queue->deallocate(pdu_pair.second); logger->error("Error pushing PDU: null length"); } // clear entry in map @@ -90,7 +91,7 @@ void cc_used_buffers_map::remove_pdu(tti_point tti) bool cc_used_buffers_map::try_deallocate_pdu(tti_point tti) { - if (pdu_map[tti.to_uint()].second == nullptr) { + if (pdu_map[tti.to_uint()].second != nullptr) { remove_pdu(tti); return true; } @@ -100,7 +101,7 @@ bool cc_used_buffers_map::try_deallocate_pdu(tti_point tti) void cc_used_buffers_map::clear() { for (auto& pdu : pdu_map) { - remove_pdu(pdu.first); + try_deallocate_pdu(pdu.first); } }