/** * * \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_SCHED_NR_CFG_H #define SRSRAN_SCHED_NR_CFG_H #include "sched_nr_interface.h" #include "sched_nr_rb.h" #include "srsenb/hdr/common/common_enb.h" namespace srsenb { const static size_t SCHED_NR_MAX_USERS = SRSENB_MAX_UES; const static size_t SCHED_NR_NOF_SUBFRAMES = 10; const static size_t SCHED_NR_NOF_HARQS = 16; static const size_t MAX_NOF_AGGR_LEVELS = 5; namespace sched_nr_impl { const static size_t MAX_GRANTS = sched_nr_interface::MAX_GRANTS; using pdcch_dl_t = mac_interface_phy_nr::pdcch_dl_t; using pdcch_ul_t = mac_interface_phy_nr::pdcch_ul_t; using pdsch_t = mac_interface_phy_nr::pdsch_t; using pusch_t = mac_interface_phy_nr::pusch_t; using pucch_t = mac_interface_phy_nr::pucch_t; using pdcch_dl_list_t = srsran::bounded_vector; using pdcch_ul_list_t = srsran::bounded_vector; using pucch_list_t = srsran::bounded_vector; using pusch_list_t = srsran::bounded_vector; using nzp_csi_rs_list = srsran::bounded_vector; using ssb_t = mac_interface_phy_nr::ssb_t; using ssb_list = srsran::bounded_vector; using sched_cfg_t = sched_nr_interface::sched_cfg_t; using cell_cfg_t = sched_nr_interface::cell_cfg_t; using bwp_cfg_t = sched_nr_interface::bwp_cfg_t; using pdcch_cce_pos_list = srsran::bounded_vector; using bwp_cce_pos_list = std::array, SRSRAN_NOF_SF_X_FRAME>; void get_dci_locs(const srsran_coreset_t& coreset, const srsran_search_space_t& search_space, uint16_t rnti, bwp_cce_pos_list& cce_locs); /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// struct bwp_params { const uint32_t bwp_id; const uint32_t cc; const bwp_cfg_t& cfg; const cell_cfg_t& cell_cfg; const sched_cfg_t& sched_cfg; // derived params srslog::basic_logger& logger; uint32_t P; uint32_t N_rbg; struct slot_cfg { bool is_dl; bool is_ul; }; srsran::bounded_vector slots; struct pusch_ra_time_cfg { uint32_t msg3_delay; ///< Includes K2 and delta. See TS 36.214 6.1.2.1.1-2/4/5 uint32_t K; uint32_t S; uint32_t L; }; std::vector pusch_ra_list; bwp_cce_pos_list rar_cce_list; bwp_params(const cell_cfg_t& cell, const sched_cfg_t& sched_cfg_, uint32_t cc, uint32_t bwp_id); }; struct sched_cell_params { const uint32_t cc; const cell_cfg_t cell_cfg; const sched_cfg_t& sched_cfg; std::vector bwps; sched_cell_params(uint32_t cc_, const cell_cfg_t& cell, const sched_cfg_t& sched_cfg_); uint32_t nof_prb() const { return cell_cfg.carrier.nof_prb; } }; struct sched_params { sched_cfg_t sched_cfg; std::vector cells; sched_params() = default; explicit sched_params(const sched_cfg_t& sched_cfg_); }; /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// using prb_bitmap = srsran::bounded_bitset; using pdcchmask_t = srsran::bounded_bitset; /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// using ue_cfg_t = sched_nr_interface::ue_cfg_t; using ue_cc_cfg_t = sched_nr_interface::ue_cc_cfg_t; class bwp_ue_cfg { public: bwp_ue_cfg() = default; explicit bwp_ue_cfg(uint16_t rnti, const bwp_params& bwp_cfg, const ue_cfg_t& uecfg_); const ue_cfg_t* ue_cfg() const { return cfg_; } const srsran::phy_cfg_nr_t& phy() const { return cfg_->phy_cfg; } const bwp_params& active_bwp() const { return *bwp_cfg; } const bwp_cce_pos_list& cce_pos_list(uint32_t search_id) const { return cce_positions_list[ss_id_to_cce_idx[search_id]]; } private: uint16_t rnti = SRSRAN_INVALID_RNTI; const ue_cfg_t* cfg_ = nullptr; const bwp_params* bwp_cfg = nullptr; std::vector cce_positions_list; std::array ss_id_to_cce_idx; }; class ue_cfg_extended : public ue_cfg_t { public: struct search_space_params { const srsran_search_space_t* cfg; bwp_cce_pos_list cce_positions; }; struct coreset_params { srsran_coreset_t* cfg = nullptr; std::vector ss_list; }; struct bwp_params { std::array, SRSRAN_UE_DL_NR_MAX_NOF_SEARCH_SPACE> ss_list; std::vector coresets; }; struct cc_params { srsran::bounded_vector bwps; }; ue_cfg_extended() = default; explicit ue_cfg_extended(uint16_t rnti, const ue_cfg_t& uecfg); const bwp_cce_pos_list& get_dci_pos_list(uint32_t cc, uint32_t bwp_id, uint32_t search_space_id) const { return cc_params[cc].bwps[bwp_id].ss_list[search_space_id]->cce_positions; } uint16_t rnti; std::vector cc_params; }; } // namespace sched_nr_impl } // namespace srsenb #endif // SRSRAN_SCHED_NR_CFG_H