SRSUE: add RF channel offset

master
Xavier Arteaga 4 years ago committed by Xavier Arteaga
parent 2d737016be
commit 0c7239e5df

@ -166,6 +166,7 @@ public:
}; };
struct phy_args_nr_t { struct phy_args_nr_t {
uint32_t rf_channel_offset = 0; ///< Specifies the RF channel the NR carrier shall fill
uint32_t nof_carriers = 1; uint32_t nof_carriers = 1;
uint32_t max_nof_prb = 106; uint32_t max_nof_prb = 106;
uint32_t nof_phy_threads = 3; uint32_t nof_phy_threads = 3;

@ -28,9 +28,7 @@ static int plot_worker_id = -1;
namespace srsue { namespace srsue {
namespace nr { namespace nr {
sf_worker::sf_worker(srsran::phy_common_interface& common_, state& phy_state_, srslog::basic_logger& log) : sf_worker::sf_worker(srsran::phy_common_interface& common_, state& phy_state_, srslog::basic_logger& log) :
phy_state(phy_state_), phy_state(phy_state_), common(common_), logger(log)
common(common_),
logger(log)
{ {
for (uint32_t i = 0; i < phy_state.args.nof_carriers; i++) { for (uint32_t i = 0; i < phy_state.args.nof_carriers; i++) {
cc_worker* w = new cc_worker(i, log, phy_state); cc_worker* w = new cc_worker(i, log, phy_state);
@ -87,7 +85,7 @@ void sf_worker::work_imp()
// Check if PRACH is available // Check if PRACH is available
if (prach_ptr != nullptr) { if (prach_ptr != nullptr) {
// PRACH is available, set buffer, transmit and return // PRACH is available, set buffer, transmit and return
tx_buffer.set(0, prach_ptr); tx_buffer.set(phy_state.args.rf_channel_offset, prach_ptr);
tx_buffer.set_nof_samples(SRSRAN_SF_LEN_PRB_NR(phy_state.cfg.carrier.nof_prb)); tx_buffer.set_nof_samples(SRSRAN_SF_LEN_PRB_NR(phy_state.cfg.carrier.nof_prb));
// Notify MAC about PRACH transmission // Notify MAC about PRACH transmission
@ -113,7 +111,7 @@ void sf_worker::work_imp()
// Set Tx buffers // Set Tx buffers
for (uint32_t i = 0; i < (uint32_t)cc_workers.size(); i++) { for (uint32_t i = 0; i < (uint32_t)cc_workers.size(); i++) {
tx_buffer.set(i, cc_workers[i]->get_tx_buffer(0)); tx_buffer.set(i + phy_state.args.rf_channel_offset, cc_workers[i]->get_tx_buffer(0));
} }
tx_buffer.set_nof_samples(SRSRAN_SF_LEN_PRB_NR(phy_state.cfg.carrier.nof_prb)); tx_buffer.set_nof_samples(SRSRAN_SF_LEN_PRB_NR(phy_state.cfg.carrier.nof_prb));

@ -93,6 +93,7 @@ int ue::init(const all_args_t& args_)
srsue::phy_args_nr_t phy_args_nr = {}; srsue::phy_args_nr_t phy_args_nr = {};
phy_args_nr.max_nof_prb = args.phy.nr_max_nof_prb; phy_args_nr.max_nof_prb = args.phy.nr_max_nof_prb;
phy_args_nr.rf_channel_offset = args.phy.nof_lte_carriers;
phy_args_nr.nof_carriers = args.phy.nof_nr_carriers; phy_args_nr.nof_carriers = args.phy.nof_nr_carriers;
phy_args_nr.nof_phy_threads = args.phy.nof_phy_threads; phy_args_nr.nof_phy_threads = args.phy.nof_phy_threads;
phy_args_nr.worker_cpu_mask = args.phy.worker_cpu_mask; phy_args_nr.worker_cpu_mask = args.phy.worker_cpu_mask;

Loading…
Cancel
Save