/** * * \section COPYRIGHT * * Copyright 2013-2021 Software Radio Systems Limited * * By using this file, you agree to the terms and conditions set * forth in the LICENSE file which can be found at the top level of * the distribution. * */ #ifndef SRSRAN_DUMMY_RX_HARQ_PROC_H #define SRSRAN_DUMMY_RX_HARQ_PROC_H #include #include #include #include #include #include class dummy_rx_harq_proc { private: srsran::byte_buffer_t data; srsran_softbuffer_rx_t softbuffer = {}; std::atomic tbs = {0}; bool first = true; uint32_t ndi = 0; public: dummy_rx_harq_proc() : data(0) { // Initialise softbuffer if (srsran_softbuffer_rx_init_guru(&softbuffer, SRSRAN_SCH_NR_MAX_NOF_CB_LDPC, SRSRAN_LDPC_MAX_LEN_ENCODED_CB) < SRSRAN_SUCCESS) { ERROR("Error Tx buffer"); } } ~dummy_rx_harq_proc() { srsran_softbuffer_rx_free(&softbuffer); } srsran_softbuffer_rx_t& get_softbuffer(uint32_t ndi_, uint32_t tbs_) { if (ndi != ndi_ || first) { srsran_softbuffer_rx_reset(&softbuffer); ndi = ndi_; tbs = tbs_; first = false; } return softbuffer; } uint32_t get_tbs() const { return tbs; } }; class dummy_rx_harq_entity : public srsran::circular_array {}; #endif // SRSRAN_DUMMY_RX_HARQ_PROC_H