Fix NR PUCCH decoder memory access

master
Xavier Arteaga 4 years ago committed by Xavier Arteaga
parent fc8fe032ff
commit 64f4767c4f

@ -560,7 +560,7 @@ static int pucch_nr_format2_encode(srsran_pucch_nr_t* q,
return SRSRAN_ERROR; return SRSRAN_ERROR;
} }
// Calculate number of encoded symbols // Calculate number of encoded bits
int e = srsran_uci_nr_pucch_format_2_3_4_E(resource); int e = srsran_uci_nr_pucch_format_2_3_4_E(resource);
if (e < SRSRAN_SUCCESS) { if (e < SRSRAN_SUCCESS) {
ERROR("Error selecting E"); ERROR("Error selecting E");
@ -605,8 +605,13 @@ static int pucch_nr_format2_decode(srsran_pucch_nr_t* q,
return SRSRAN_ERROR; return SRSRAN_ERROR;
} }
// Calculate number of encoded symbols // Calculate number of encoded bits
uint32_t E = srsran_uci_nr_pucch_format_2_3_4_E(resource); int e = srsran_uci_nr_pucch_format_2_3_4_E(resource);
if (e < SRSRAN_SUCCESS) {
ERROR("Error selecting E");
return SRSRAN_ERROR;
}
uint32_t E = (uint32_t)e;
// Undo mapping to physical resources // Undo mapping to physical resources
uint32_t l_start = resource->start_symbol_idx; uint32_t l_start = resource->start_symbol_idx;
@ -634,13 +639,13 @@ static int pucch_nr_format2_decode(srsran_pucch_nr_t* q,
} }
// Equalise // Equalise
if (srsran_predecoding_single(q->d, q->ce, q->d, NULL, E, 1.0f, chest_res->noise_estimate) < SRSRAN_SUCCESS) { if (srsran_predecoding_single(q->d, q->ce, q->d, NULL, E / 2, 1.0f, chest_res->noise_estimate) < SRSRAN_SUCCESS) {
ERROR("Error Pre-decoding"); ERROR("Error Pre-decoding");
return SRSRAN_ERROR; return SRSRAN_ERROR;
} }
// Soft-demodulate // Soft-demodulate
if (srsran_demod_soft_demodulate_b(SRSRAN_MOD_QPSK, q->d, llr, E) < SRSRAN_SUCCESS) { if (srsran_demod_soft_demodulate_b(SRSRAN_MOD_QPSK, q->d, llr, E / 2) < SRSRAN_SUCCESS) {
ERROR("Error soft-demodulate"); ERROR("Error soft-demodulate");
return SRSRAN_ERROR; return SRSRAN_ERROR;
} }

Loading…
Cancel
Save