/** * * \section COPYRIGHT * * Copyright 2013-2020 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 "srslte/common/interfaces_common.h" #include "srslte/common/mac_pcap.h" #include "srslte/common/timers.h" #include "ul_sps.h" using namespace srslte; namespace srsue { class ul_harq_entity { public: ul_harq_entity(const uint8_t cc_idx_); bool init(mac_interface_rrc_common::ue_rnti_t* rntis_, ra_proc* ra_proc_h_, mux* mux_unit_); void reset(); void reset_ndi(); void set_config(srslte::ul_harq_cfg_t& harq_cfg); void start_pcap(srslte::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: mac_interface_phy_lte::mac_grant_ul_t cur_grant; uint32_t pid; uint32_t current_tx_nb; uint32_t current_irv; bool harq_feedback; bool is_grant_configured; bool is_initiated; srslog::basic_logger& logger; ul_harq_entity* harq_entity; srslte_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; srslte::mac_pcap* pcap = nullptr; srslog::basic_logger& logger; mac_interface_rrc_common::ue_rnti_t* rntis = nullptr; srslte::ul_harq_cfg_t harq_cfg = {}; float average_retx = 0.0; uint64_t 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