Commit c87b3905 authored by francescomani's avatar francescomani

code formatting

parent 2039a4f2
...@@ -299,7 +299,7 @@ uint16_t get_dmrs_freq_idx_ul(uint16_t n, uint8_t k_prime, uint8_t delta, uint8_ ...@@ -299,7 +299,7 @@ uint16_t get_dmrs_freq_idx_ul(uint16_t n, uint8_t k_prime, uint8_t delta, uint8_
int8_t get_next_dmrs_symbol_in_slot(uint16_t ul_dmrs_symb_pos, uint8_t counter, uint8_t end_symbol) int8_t get_next_dmrs_symbol_in_slot(uint16_t ul_dmrs_symb_pos, uint8_t counter, uint8_t end_symbol)
{ {
for(uint8_t symbol = counter; symbol < end_symbol; symbol++) { for(uint8_t symbol = counter; symbol < end_symbol; symbol++) {
if((ul_dmrs_symb_pos >> symbol) & 0x01 ) { if((ul_dmrs_symb_pos >> symbol) & 0x01) {
return symbol; return symbol;
} }
} }
...@@ -318,23 +318,23 @@ uint8_t get_dmrs_symbols_in_slot(uint16_t l_prime_mask, uint16_t nb_symb, uint8 ...@@ -318,23 +318,23 @@ uint8_t get_dmrs_symbols_in_slot(uint16_t l_prime_mask, uint16_t nb_symb, uint8
} }
/* return the position of valid dmrs symbol in a slot for channel compensation */ /* return the position of valid dmrs symbol in a slot for channel compensation */
int8_t get_valid_dmrs_idx_for_channel_est(uint16_t dmrs_symb_pos, uint8_t counter) int8_t get_valid_dmrs_idx_for_channel_est(uint16_t dmrs_symb_pos, uint8_t counter)
{ {
int8_t symbIdx = -1; int8_t symbIdx = -1;
/* if current symbol is DMRS then return this index */ /* if current symbol is DMRS then return this index */
if(is_dmrs_symbol(counter, dmrs_symb_pos ) ==1) { if(is_dmrs_symbol(counter, dmrs_symb_pos) == 1) {
return counter; return counter;
} }
/* find previous DMRS symbol */ /* find previous DMRS symbol */
for(int8_t symbol = counter;symbol >=0 ; symbol--) { for(int8_t symbol = counter; symbol >= 0 ; symbol--) {
if((1<<symbol & dmrs_symb_pos)> 0) { if((1 << symbol & dmrs_symb_pos) > 0) {
symbIdx = symbol; symbIdx = symbol;
break; break;
} }
} }
/* if there is no previous dmrs available then find the next possible*/ /* if there is no previous dmrs available then find the next possible*/
if(symbIdx == -1) { if(symbIdx == -1) {
symbIdx = get_next_dmrs_symbol_in_slot(dmrs_symb_pos,counter,15); symbIdx = get_next_dmrs_symbol_in_slot(dmrs_symb_pos, counter, 15);
} }
return symbIdx; return symbIdx;
} }
......
...@@ -276,16 +276,16 @@ void nr_idft(int32_t *z, uint32_t Msc_PUSCH) ...@@ -276,16 +276,16 @@ void nr_idft(int32_t *z, uint32_t Msc_PUSCH)
} }
static void nr_ulsch_extract_rbs (c16_t* const rxdataF, static void nr_ulsch_extract_rbs(c16_t* const rxdataF,
c16_t* const chF, c16_t* const chF,
c16_t *rxFext, c16_t *rxFext,
c16_t *chFext, c16_t *chFext,
int rxoffset, int rxoffset,
int choffset, int choffset,
int aarx, int aarx,
int is_dmrs_symbol, int is_dmrs_symbol,
nfapi_nr_pusch_pdu_t *pusch_pdu, nfapi_nr_pusch_pdu_t *pusch_pdu,
NR_DL_FRAME_PARMS *frame_parms) NR_DL_FRAME_PARMS *frame_parms)
{ {
uint8_t delta = 0; uint8_t delta = 0;
...@@ -301,8 +301,7 @@ static void nr_ulsch_extract_rbs (c16_t* const rxdataF, ...@@ -301,8 +301,7 @@ static void nr_ulsch_extract_rbs (c16_t* const rxdataF,
if (is_dmrs_symbol == 0) { if (is_dmrs_symbol == 0) {
if (start_re + nb_re_pusch <= frame_parms->ofdm_symbol_size) if (start_re + nb_re_pusch <= frame_parms->ofdm_symbol_size)
memcpy(rxF_ext, &rxF[start_re], nb_re_pusch * sizeof(c16_t)); memcpy(rxF_ext, &rxF[start_re], nb_re_pusch * sizeof(c16_t));
else else {
{
int neg_length = frame_parms->ofdm_symbol_size - start_re; int neg_length = frame_parms->ofdm_symbol_size - start_re;
int pos_length = nb_re_pusch - neg_length; int pos_length = nb_re_pusch - neg_length;
memcpy(rxF_ext, &rxF[start_re], neg_length * sizeof(c16_t)); memcpy(rxF_ext, &rxF[start_re], neg_length * sizeof(c16_t));
...@@ -310,57 +309,47 @@ static void nr_ulsch_extract_rbs (c16_t* const rxdataF, ...@@ -310,57 +309,47 @@ static void nr_ulsch_extract_rbs (c16_t* const rxdataF,
} }
memcpy(ul_ch0_ext, ul_ch0, nb_re_pusch * sizeof(c16_t)); memcpy(ul_ch0_ext, ul_ch0, nb_re_pusch * sizeof(c16_t));
} }
else if (pusch_pdu->dmrs_config_type == pusch_dmrs_type1) // 6 REs / PRB else if (pusch_pdu->dmrs_config_type == pusch_dmrs_type1) { // 6 REs / PRB
{
AssertFatal(delta == 0 || delta == 1, "Illegal delta %d\n",delta); AssertFatal(delta == 0 || delta == 1, "Illegal delta %d\n",delta);
c16_t *rxF32 = &rxF[start_re]; c16_t *rxF32 = &rxF[start_re];
if (start_re + nb_re_pusch < frame_parms->ofdm_symbol_size) { if (start_re + nb_re_pusch < frame_parms->ofdm_symbol_size) {
for (int idx = 1 - delta; idx < nb_re_pusch; idx += 2) for (int idx = 1 - delta; idx < nb_re_pusch; idx += 2) {
{
*rxF_ext++ = rxF32[idx]; *rxF_ext++ = rxF32[idx];
*ul_ch0_ext++ = ul_ch0[idx]; *ul_ch0_ext++ = ul_ch0[idx];
} }
} }
else // handle the two pieces around DC else { // handle the two pieces around DC
{
int neg_length = frame_parms->ofdm_symbol_size - start_re; int neg_length = frame_parms->ofdm_symbol_size - start_re;
int pos_length = nb_re_pusch - neg_length; int pos_length = nb_re_pusch - neg_length;
int idx, idx2; int idx, idx2;
for (idx = 1 - delta; idx < neg_length; idx += 2) for (idx = 1 - delta; idx < neg_length; idx += 2) {
{
*rxF_ext++ = rxF32[idx]; *rxF_ext++ = rxF32[idx];
*ul_ch0_ext++= ul_ch0[idx]; *ul_ch0_ext++= ul_ch0[idx];
} }
rxF32 = rxF; rxF32 = rxF;
idx2 = idx; idx2 = idx;
for (idx = 1 - delta; idx < pos_length; idx += 2, idx2 += 2) for (idx = 1 - delta; idx < pos_length; idx += 2, idx2 += 2) {
{
*rxF_ext++ = rxF32[idx]; *rxF_ext++ = rxF32[idx];
*ul_ch0_ext++ = ul_ch0[idx2]; *ul_ch0_ext++ = ul_ch0[idx2];
} }
} }
} }
else if (pusch_pdu->dmrs_config_type == pusch_dmrs_type2) // 8 REs / PRB else if (pusch_pdu->dmrs_config_type == pusch_dmrs_type2) { // 8 REs / PRB
{
AssertFatal(delta==0||delta==2||delta==4,"Illegal delta %d\n",delta); AssertFatal(delta==0||delta==2||delta==4,"Illegal delta %d\n",delta);
if (start_re + nb_re_pusch < frame_parms->ofdm_symbol_size) if (start_re + nb_re_pusch < frame_parms->ofdm_symbol_size) {
{ for (int idx = 0; idx < nb_re_pusch; idx ++) {
for (int idx = 0; idx < nb_re_pusch; idx ++)
{
if (idx % 6 == 2 * delta || idx % 6 == 2 * delta + 1) if (idx % 6 == 2 * delta || idx % 6 == 2 * delta + 1)
continue; continue;
*rxF_ext++ = rxF[idx]; *rxF_ext++ = rxF[idx];
*ul_ch0_ext++ = ul_ch0[idx]; *ul_ch0_ext++ = ul_ch0[idx];
} }
} }
else else {
{
int neg_length = frame_parms->ofdm_symbol_size - start_re; int neg_length = frame_parms->ofdm_symbol_size - start_re;
int pos_length = nb_re_pusch - neg_length; int pos_length = nb_re_pusch - neg_length;
c16_t *rxF64 = &rxF[start_re]; c16_t *rxF64 = &rxF[start_re];
int idx, idx2; int idx, idx2;
for (idx = 0; idx < neg_length; idx ++) for (idx = 0; idx < neg_length; idx ++) {
{
if (idx % 6 == 2 * delta || idx % 6 == 2 * delta + 1) if (idx % 6 == 2 * delta || idx % 6 == 2 * delta + 1)
continue; continue;
*rxF_ext++ = rxF64[idx]; *rxF_ext++ = rxF64[idx];
...@@ -368,8 +357,7 @@ static void nr_ulsch_extract_rbs (c16_t* const rxdataF, ...@@ -368,8 +357,7 @@ static void nr_ulsch_extract_rbs (c16_t* const rxdataF,
} }
rxF64 = rxF; rxF64 = rxF;
idx2 = idx; idx2 = idx;
for (idx = 0; idx < pos_length; idx++, idx2++) for (idx = 0; idx < pos_length; idx++, idx2++) {
{
if (idx % 6 == 2 * delta || idx % 6 == 2 * delta + 1) if (idx % 6 == 2 * delta || idx % 6 == 2 * delta + 1)
continue; continue;
*rxF_ext++ = rxF64[idx]; *rxF_ext++ = rxF64[idx];
...@@ -1293,15 +1281,15 @@ static void inner_rx(PHY_VARS_gNB *gNB, ...@@ -1293,15 +1281,15 @@ static void inner_rx(PHY_VARS_gNB *gNB,
for (int aarx = 0; aarx < nb_rx_ant; aarx++) { for (int aarx = 0; aarx < nb_rx_ant; aarx++) {
for (int aatx = 0; aatx < nb_layer; aatx++) { for (int aatx = 0; aatx < nb_layer; aatx++) {
nr_ulsch_extract_rbs(rxF[aarx], nr_ulsch_extract_rbs(rxF[aarx],
(c16_t *)pusch_vars->ul_ch_estimates[aatx * nb_rx_ant + aarx], (c16_t *)pusch_vars->ul_ch_estimates[aatx * nb_rx_ant + aarx],
rxFext[aarx], rxFext[aarx],
chFext[aatx][aarx], chFext[aatx][aarx],
soffset+(symbol * frame_parms->ofdm_symbol_size), soffset+(symbol * frame_parms->ofdm_symbol_size),
dmrs_symbol * frame_parms->ofdm_symbol_size, dmrs_symbol * frame_parms->ofdm_symbol_size,
aarx, aarx,
dmrs_symbol_flag, dmrs_symbol_flag,
rel15_ul, rel15_ul,
frame_parms); frame_parms);
} }
} }
c16_t rho[nb_layer][nb_layer][buffer_length] __attribute__((aligned(32))); c16_t rho[nb_layer][nb_layer][buffer_length] __attribute__((aligned(32)));
...@@ -1369,10 +1357,10 @@ static void inner_rx(PHY_VARS_gNB *gNB, ...@@ -1369,10 +1357,10 @@ static void inner_rx(PHY_VARS_gNB *gNB,
else { else {
nr_ulsch_mmse_2layers(frame_parms, nr_ulsch_mmse_2layers(frame_parms,
(int32_t **)pusch_vars->rxdataF_comp, (int32_t **)pusch_vars->rxdataF_comp,
(int **)rxF_ch_maga, (int **)rxF_ch_maga,
(int **)rxF_ch_magb, (int **)rxF_ch_magb,
(int **)rxF_ch_magc, (int **)rxF_ch_magc,
(int **)chFext, (int **)chFext,
rel15_ul->rb_size, rel15_ul->rb_size,
frame_parms->nb_antennas_rx, frame_parms->nb_antennas_rx,
rel15_ul->qam_mod_order, rel15_ul->qam_mod_order,
...@@ -1427,14 +1415,14 @@ static void nr_pusch_symbol_processing(void *arg) ...@@ -1427,14 +1415,14 @@ static void nr_pusch_symbol_processing(void *arg)
ulsch_id, ulsch_id,
slot, slot,
frame_parms, frame_parms,
pusch_vars, pusch_vars,
rel15_ul, rel15_ul,
gNB->common_vars.rxdataF, gNB->common_vars.rxdataF,
(c16_t**)gNB->pusch_vars[ulsch_id].ul_ch_estimates, (c16_t**)gNB->pusch_vars[ulsch_id].ul_ch_estimates,
rdata->llr_layers, rdata->llr_layers,
soffset, soffset,
gNB->pusch_vars[ulsch_id].ul_valid_re_per_slot[symbol], gNB->pusch_vars[ulsch_id].ul_valid_re_per_slot[symbol],
symbol, symbol,
gNB->pusch_vars[ulsch_id].log2_maxh, gNB->pusch_vars[ulsch_id].log2_maxh,
rdata->nvar); rdata->nvar);
...@@ -1502,9 +1490,9 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB, ...@@ -1502,9 +1490,9 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
} }
// measure the SNR from the channel estimation // measure the SNR from the channel estimation
nr_gnb_measurements(gNB, nr_gnb_measurements(gNB,
&gNB->ulsch[ulsch_id], &gNB->ulsch[ulsch_id],
pusch_vars, pusch_vars,
symbol, symbol,
rel15_ul->nrOfLayers); rel15_ul->nrOfLayers);
allocCast2D(n0_subband_power, allocCast2D(n0_subband_power,
unsigned int, unsigned int,
...@@ -1586,10 +1574,13 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB, ...@@ -1586,10 +1574,13 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
int nb_re_pusch = 0, meas_symbol = -1; int nb_re_pusch = 0, meas_symbol = -1;
for(meas_symbol = rel15_ul->start_symbol_index; meas_symbol < end_symbol; meas_symbol++) for(meas_symbol = rel15_ul->start_symbol_index; meas_symbol < end_symbol; meas_symbol++)
if ((nb_re_pusch = get_nb_re_pusch(frame_parms,rel15_ul,meas_symbol)) > 0) if ((nb_re_pusch = get_nb_re_pusch(frame_parms, rel15_ul, meas_symbol)) > 0)
break; break;
AssertFatal(nb_re_pusch>0 && meas_symbol>=0,"nb_re_pusch %d cannot be 0 or meas_symbol %d cannot be negative here\n",nb_re_pusch,meas_symbol); AssertFatal(nb_re_pusch > 0 && meas_symbol >= 0,
"nb_re_pusch %d cannot be 0 or meas_symbol %d cannot be negative here\n",
nb_re_pusch,
meas_symbol);
// extract the first dmrs for the channel level computation // extract the first dmrs for the channel level computation
// extract the data in the OFDM frame, to the start of the array // extract the data in the OFDM frame, to the start of the array
...@@ -1605,15 +1596,15 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB, ...@@ -1605,15 +1596,15 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
for (int aarx = 0; aarx < frame_parms->nb_antennas_rx; aarx++) for (int aarx = 0; aarx < frame_parms->nb_antennas_rx; aarx++)
for (int aatx = 0; aatx < rel15_ul->nrOfLayers; aatx++) for (int aatx = 0; aatx < rel15_ul->nrOfLayers; aatx++)
nr_ulsch_extract_rbs(gNB->common_vars.rxdataF[aarx], nr_ulsch_extract_rbs(gNB->common_vars.rxdataF[aarx],
(c16_t *)pusch_vars->ul_ch_estimates[aatx * frame_parms->nb_antennas_rx + aarx], (c16_t*)pusch_vars->ul_ch_estimates[aatx * frame_parms->nb_antennas_rx + aarx],
(c16_t*)&pusch_vars->rxdataF_ext[aarx][meas_symbol * nb_re_pusch], (c16_t*)&pusch_vars->rxdataF_ext[aarx][meas_symbol * nb_re_pusch],
(c16_t*)&pusch_vars->ul_ch_estimates_ext[aatx*frame_parms->nb_antennas_rx+aarx][meas_symbol * nb_re_pusch], (c16_t*)&pusch_vars->ul_ch_estimates_ext[aatx * frame_parms->nb_antennas_rx+aarx][meas_symbol * nb_re_pusch],
soffset + meas_symbol * frame_parms->ofdm_symbol_size, soffset + meas_symbol * frame_parms->ofdm_symbol_size,
dmrs_symbol * frame_parms->ofdm_symbol_size, dmrs_symbol * frame_parms->ofdm_symbol_size,
aarx, aarx,
(rel15_ul->ul_dmrs_symb_pos >> meas_symbol) & 0x01, (rel15_ul->ul_dmrs_symb_pos >> meas_symbol) & 0x01,
rel15_ul, rel15_ul,
frame_parms); frame_parms);
int avgs = 0; int avgs = 0;
int avg[frame_parms->nb_antennas_rx*rel15_ul->nrOfLayers]; int avg[frame_parms->nb_antennas_rx*rel15_ul->nrOfLayers];
...@@ -1657,10 +1648,9 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB, ...@@ -1657,10 +1648,9 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
start_meas(&gNB->rx_pusch_symbol_processing_stats); start_meas(&gNB->rx_pusch_symbol_processing_stats);
int numSymbols = gNB->num_pusch_symbols_per_thread; int numSymbols = gNB->num_pusch_symbols_per_thread;
for(uint8_t symbol = rel15_ul->start_symbol_index; symbol < end_symbol; symbol += numSymbols) for(uint8_t symbol = rel15_ul->start_symbol_index; symbol < end_symbol; symbol += numSymbols) {
{
int total_res = 0; int total_res = 0;
for (int s = 0; s < numSymbols;s++) { for (int s = 0; s < numSymbols; s++) {
pusch_vars->ul_valid_re_per_slot[symbol+s] = get_nb_re_pusch(frame_parms,rel15_ul,symbol+s); pusch_vars->ul_valid_re_per_slot[symbol+s] = get_nb_re_pusch(frame_parms,rel15_ul,symbol+s);
pusch_vars->llr_offset[symbol+s] = ((symbol+s) == rel15_ul->start_symbol_index) ? pusch_vars->llr_offset[symbol+s] = ((symbol+s) == rel15_ul->start_symbol_index) ?
0 : 0 :
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment