Protect access to ul buffers (#2227)

* Protect access to ul buffers

* Fix interval calculation when removing old buffers
master
Ismael Gomez 4 years ago committed by GitHub
parent 6ca8bc12ec
commit fed4e0ad82
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -124,6 +124,7 @@ private:
std::vector<std::array<std::array<srslte::unique_byte_buffer_t, SRSLTE_MAX_TB>, SRSLTE_FDD_NOF_HARQ> > std::vector<std::array<std::array<srslte::unique_byte_buffer_t, SRSLTE_MAX_TB>, SRSLTE_FDD_NOF_HARQ> >
tx_payload_buffer; tx_payload_buffer;
std::mutex rx_buffers_mutex;
std::vector<std::map<uint32_t, uint8_t*> > rx_used_buffers; std::vector<std::map<uint32_t, uint8_t*> > rx_used_buffers;
srslte::block_queue<uint32_t> pending_ta_commands; srslte::block_queue<uint32_t> pending_ta_commands;

@ -77,11 +77,14 @@ ue::~ue()
srslte_softbuffer_tx_free(&buffer); srslte_softbuffer_tx_free(&buffer);
} }
} }
for (auto& rx_buffers_cc : rx_used_buffers) { {
for (auto& q : rx_buffers_cc) { std::unique_lock<std::mutex> lock(rx_buffers_mutex);
pdus.deallocate(q.second); for (auto& rx_buffers_cc : rx_used_buffers) {
for (auto& q : rx_buffers_cc) {
pdus.deallocate(q.second);
}
rx_buffers_cc.clear();
} }
rx_buffers_cc.clear();
} }
} }
@ -170,6 +173,7 @@ ue::get_tx_softbuffer(const uint32_t ue_cc_idx, const uint32_t harq_process, con
uint8_t* ue::request_buffer(uint32_t tti, uint32_t ue_cc_idx, const uint32_t len) uint8_t* ue::request_buffer(uint32_t tti, uint32_t ue_cc_idx, const uint32_t len)
{ {
std::unique_lock<std::mutex> lock(rx_buffers_mutex);
uint8_t* pdu = nullptr; uint8_t* pdu = nullptr;
if (len > 0) { if (len > 0) {
// Deallocate oldest buffer if we didn't deallocate it // Deallocate oldest buffer if we didn't deallocate it
@ -191,11 +195,17 @@ uint8_t* ue::request_buffer(uint32_t tti, uint32_t ue_cc_idx, const uint32_t len
void ue::clear_old_buffers(uint32_t tti) void ue::clear_old_buffers(uint32_t tti)
{ {
std::unique_lock<std::mutex> lock(rx_buffers_mutex);
// remove old buffers // remove old buffers
for (auto& rx_buffer_cc : rx_used_buffers) { for (auto& rx_buffer_cc : rx_used_buffers) {
for (auto it = rx_buffer_cc.begin(); it != rx_buffer_cc.end();) { for (auto it = rx_buffer_cc.begin(); it != rx_buffer_cc.end();) {
if (srslte_tti_interval(tti, it->first) > 20) { if (srslte_tti_interval(tti, it->first) > 20 && srslte_tti_interval(tti, it->first) < 500) {
Warning("UE buffers: Removing old buffer tti=%d, rnti=%d, now is %d\n", it->first, rnti, tti); Warning("UE buffers: Removing old buffer tti=%d, rnti=%d, now is %d, interval=%d\n",
it->first,
rnti,
tti,
srslte_tti_interval(tti, it->first));
pdus.deallocate(it->second); pdus.deallocate(it->second);
it = rx_buffer_cc.erase(it); it = rx_buffer_cc.erase(it);
} else { } else {
@ -329,6 +339,8 @@ void ue::process_pdu(uint8_t* pdu, uint32_t nof_bytes, srslte::pdu_queue::channe
void ue::deallocate_pdu(uint32_t tti, uint32_t ue_cc_idx) void ue::deallocate_pdu(uint32_t tti, uint32_t ue_cc_idx)
{ {
std::unique_lock<std::mutex> lock(rx_buffers_mutex);
if (rx_used_buffers.at(ue_cc_idx).count(tti)) { if (rx_used_buffers.at(ue_cc_idx).count(tti)) {
pdus.deallocate(rx_used_buffers.at(ue_cc_idx).at(tti)); pdus.deallocate(rx_used_buffers.at(ue_cc_idx).at(tti));
rx_used_buffers.at(ue_cc_idx).erase(tti); rx_used_buffers.at(ue_cc_idx).erase(tti);
@ -342,6 +354,7 @@ void ue::deallocate_pdu(uint32_t tti, uint32_t ue_cc_idx)
void ue::push_pdu(uint32_t tti, uint32_t ue_cc_idx, uint32_t len) void ue::push_pdu(uint32_t tti, uint32_t ue_cc_idx, uint32_t len)
{ {
std::unique_lock<std::mutex> lock(rx_buffers_mutex);
if (rx_used_buffers.at(ue_cc_idx).count(tti)) { if (rx_used_buffers.at(ue_cc_idx).count(tti)) {
if (len > 0) { if (len > 0) {
pdus.push(rx_used_buffers.at(ue_cc_idx).at(tti), len); pdus.push(rx_used_buffers.at(ue_cc_idx).at(tti), len);

Loading…
Cancel
Save