|
|
@ -159,8 +159,8 @@ std::string sf_cch_allocator::result_to_string(bool verbose) const
|
|
|
|
|
|
|
|
|
|
|
|
sf_cch_allocator::alloc_tree_t::alloc_tree_t(uint32_t this_cfi,
|
|
|
|
sf_cch_allocator::alloc_tree_t::alloc_tree_t(uint32_t this_cfi,
|
|
|
|
const sched_cell_params_t& cc_params,
|
|
|
|
const sched_cell_params_t& cc_params,
|
|
|
|
srslte_pucch_cfg_t& pucch_cfg) :
|
|
|
|
srslte_pucch_cfg_t& pucch_cfg_common) :
|
|
|
|
cfi(this_cfi), cc_cfg(&cc_params), pucch_cfg(&pucch_cfg), nof_cces(cc_params.nof_cce_table[this_cfi - 1])
|
|
|
|
cfi(this_cfi), cc_cfg(&cc_params), pucch_cfg_temp(&pucch_cfg_common), nof_cces(cc_params.nof_cce_table[this_cfi - 1])
|
|
|
|
{
|
|
|
|
{
|
|
|
|
dci_alloc_tree.reserve(8);
|
|
|
|
dci_alloc_tree.reserve(8);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -172,10 +172,10 @@ void sf_cch_allocator::alloc_tree_t::reset()
|
|
|
|
dci_alloc_tree.clear();
|
|
|
|
dci_alloc_tree.clear();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool is_pucch_sr_collision(const srslte_pucch_cfg_t& pucch_cfg, tti_point tti_tx_dl, uint32_t n1_pucch)
|
|
|
|
bool is_pucch_sr_collision(const srslte_pucch_cfg_t& ue_pucch_cfg, tti_point tti_tx_dl_ack, uint32_t n1_pucch)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (pucch_cfg.sr_configured && srslte_ue_ul_sr_send_tti(&pucch_cfg, tti_tx_dl.to_uint())) {
|
|
|
|
if (ue_pucch_cfg.sr_configured && srslte_ue_ul_sr_send_tti(&ue_pucch_cfg, tti_tx_dl_ack.to_uint())) {
|
|
|
|
return n1_pucch == pucch_cfg.n_pucch_sr;
|
|
|
|
return n1_pucch == ue_pucch_cfg.n_pucch_sr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -209,14 +209,15 @@ bool sf_cch_allocator::alloc_tree_t::add_tree_node_leaves(int
|
|
|
|
|
|
|
|
|
|
|
|
if (dci_record.alloc_type == alloc_type_t::DL_DATA and not dci_record.pusch_uci) {
|
|
|
|
if (dci_record.alloc_type == alloc_type_t::DL_DATA and not dci_record.pusch_uci) {
|
|
|
|
// The UE needs to allocate space in PUCCH for HARQ-ACK
|
|
|
|
// The UE needs to allocate space in PUCCH for HARQ-ACK
|
|
|
|
pucch_cfg->n_pucch = ncce_pos + pucch_cfg->N_pucch_1;
|
|
|
|
pucch_cfg_temp->n_pucch = ncce_pos + pucch_cfg_temp->N_pucch_1;
|
|
|
|
|
|
|
|
|
|
|
|
if (is_pucch_sr_collision(*pucch_cfg, to_tx_dl_ack(tti_rx_), pucch_cfg->n_pucch)) {
|
|
|
|
if (is_pucch_sr_collision(
|
|
|
|
|
|
|
|
dci_record.user->get_ue_cfg().pucch_cfg, to_tx_dl_ack(tti_rx_), pucch_cfg_temp->n_pucch)) {
|
|
|
|
// avoid collision of HARQ-ACK with own SR n(1)_pucch
|
|
|
|
// avoid collision of HARQ-ACK with own SR n(1)_pucch
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pucch_prbidx = srslte_pucch_n_prb(&cc_cfg->cfg.cell, pucch_cfg, 0);
|
|
|
|
pucch_prbidx = srslte_pucch_n_prb(&cc_cfg->cfg.cell, pucch_cfg_temp, 0);
|
|
|
|
if (not cc_cfg->sched_cfg->pucch_mux_enabled and parent_pucch_mask.test(pucch_prbidx)) {
|
|
|
|
if (not cc_cfg->sched_cfg->pucch_mux_enabled and parent_pucch_mask.test(pucch_prbidx)) {
|
|
|
|
// PUCCH allocation would collide with other PUCCH/PUSCH grants. Try another CCE position
|
|
|
|
// PUCCH allocation would collide with other PUCCH/PUSCH grants. Try another CCE position
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|