/** * * \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 SRSUE_UL_HARQ_H #define SRSUE_UL_HARQ_H #include "mux.h" #include "proc_ra.h" #include "srsran/common/interfaces_common.h" #include "srsran/common/mac_pcap.h" #include "srsran/common/timers.h" #include "ul_sps.h" using namespace srsran; namespace srsue { class ul_harq_entity { public: ul_harq_entity(const uint8_t cc_idx_); bool init(ue_rnti* rntis_, ra_proc* ra_proc_h_, mux* mux_unit_); void reset(); void reset_ndi(); void set_config(srsran::ul_harq_cfg_t& harq_cfg); void start_pcap(srsran::mac_pcap* pcap_); /***************** PHY->MAC interface for UL processes **************************/ void new_grant_ul(mac_interface_phy_lte::mac_grant_ul_t grant, mac_interface_phy_lte::tb_action_ul_t* action); int get_current_tbs(uint32_t pid); float get_average_retx(); private: class ul_harq_process { public: ul_harq_process(); ~ul_harq_process(); bool init(uint32_t pid_, ul_harq_entity* parent); void reset(); void reset_ndi(); uint32_t get_rv(); bool has_grant(); bool get_ndi(); bool is_sps(); uint32_t get_nof_retx(); int get_current_tbs(); // Implements Section 5.4.2.1 void new_grant_ul(mac_interface_phy_lte::mac_grant_ul_t grant, mac_interface_phy_lte::tb_action_ul_t* action); private: /// Thread safe wrapper for a mac_grant_ul_t object. class lockable_grant { mac_interface_phy_lte::mac_grant_ul_t grant = {}; mutable std::mutex mutex; public: void set(const mac_interface_phy_lte::mac_grant_ul_t& other) { std::lock_guard lock(mutex); grant = other; } void reset() { std::lock_guard lock(mutex); grant = {}; } void set_ndi(bool ndi) { std::lock_guard lock(mutex); grant.tb.ndi = ndi; } bool get_ndi() const { std::lock_guard lock(mutex); return grant.tb.ndi; } uint32_t get_tbs() const { std::lock_guard lock(mutex); return grant.tb.tbs; } int get_rv() const { std::lock_guard lock(mutex); return grant.tb.rv; } void set_rv(int rv) { std::lock_guard lock(mutex); grant.tb.rv = rv; } }; lockable_grant cur_grant; uint32_t pid; std::atomic current_tx_nb = {0}; std::atomic current_irv = {0}; bool harq_feedback; bool is_grant_configured; bool is_initiated; srslog::basic_logger& logger; ul_harq_entity* harq_entity; srsran_softbuffer_tx_t softbuffer; const static int payload_buffer_len = 128 * 1024; std::unique_ptr payload_buffer = nullptr; uint8_t* pdu_ptr; void generate_tx(mac_interface_phy_lte::tb_action_ul_t* action); void generate_retx(mac_interface_phy_lte::mac_grant_ul_t grant, mac_interface_phy_lte::tb_action_ul_t* action); void generate_new_tx(mac_interface_phy_lte::mac_grant_ul_t grant, mac_interface_phy_lte::tb_action_ul_t* action); }; ul_sps ul_sps_assig; std::vector proc; mux* mux_unit = nullptr; srsran::mac_pcap* pcap = nullptr; srslog::basic_logger& logger; ue_rnti* rntis = nullptr; srsran::ul_harq_cfg_t harq_cfg = {}; std::mutex config_mutex; std::atomic average_retx{0}; std::atomic nof_pkts{0}; ra_proc* ra_procedure = nullptr; uint8_t cc_idx = 0; }; typedef std::unique_ptr ul_harq_entity_ptr; typedef std::array ul_harq_entity_vector; } // namespace srsue #endif // SRSUE_UL_HARQ_H