/** * * \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 SRSENB_NR_CC_WORKER_H #define SRSENB_NR_CC_WORKER_H #include "srslte/interfaces/gnb_interfaces.h" #include "srslte/phy/enb/enb_dl_nr.h" #include "srslte/srslog/srslog.h" #include #include namespace srsenb { namespace nr { typedef struct { uint32_t nof_carriers; srslte_enb_dl_nr_args_t dl; } phy_nr_args_t; typedef struct { srslte_sch_hl_cfg_nr_t pdsch; } phy_nr_cfg_t; class phy_nr_state { public: phy_nr_args_t args = {}; phy_nr_cfg_t cfg = {}; phy_nr_state() { args.nof_carriers = 1; args.dl.nof_max_prb = 100; args.dl.nof_tx_antennas = 1; args.dl.pdsch.measure_evm = true; args.dl.pdsch.measure_time = true; args.dl.pdsch.sch.disable_simd = true; cfg.pdsch.sch_cfg.mcs_table = srslte_mcs_table_256qam; } }; class cc_worker { public: cc_worker(uint32_t cc_idx, srslog::basic_logger& logger, phy_nr_state* phy_state_); ~cc_worker(); bool set_carrier(const srslte_carrier_nr_t* carrier); void set_tti(uint32_t tti); cf_t* get_tx_buffer(uint32_t antenna_idx); cf_t* get_rx_buffer(uint32_t antenna_idx); uint32_t get_buffer_len(); bool work_dl(const srslte_slot_cfg_t& dl_slot_cfg, stack_interface_phy_nr::dl_sched_t& dl_grants); private: int encode_pdsch(stack_interface_phy_nr::dl_sched_grant_t* grants, uint32_t nof_grants); int encode_pdcch_dl(stack_interface_phy_nr::dl_sched_grant_t* grants, uint32_t nof_grants); srslte_slot_cfg_t dl_slot_cfg = {}; uint32_t cc_idx = 0; std::array tx_buffer = {}; std::array rx_buffer = {}; uint32_t buffer_sz = 0; phy_nr_state* phy_state; srslte_enb_dl_nr_t enb_dl = {}; srslog::basic_logger& logger; }; } // namespace nr } // namespace srsenb #endif // SRSENB_NR_CC_WORKER_H