From 610edac8015f2d98f07b4d2632ca53ad8e78bf7d Mon Sep 17 00:00:00 2001 From: Xavier Arteaga Date: Mon, 5 Feb 2018 12:59:06 +0100 Subject: [PATCH 01/13] Do not append RI in RM30 if no TM3/4 --- srsue/src/phy/phch_worker.cc | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/srsue/src/phy/phch_worker.cc b/srsue/src/phy/phch_worker.cc index 9caa0102a..61c767e7a 100644 --- a/srsue/src/phy/phch_worker.cc +++ b/srsue/src/phy/phch_worker.cc @@ -940,11 +940,16 @@ void phch_worker::set_uci_aperiodic_cqi() srslte_cqi_to_str(uci_data.uci_cqi, uci_data.uci_cqi_len, cqi_str, SRSLTE_CQI_STR_MAX_CHAR); /* Set RI = 1 */ - uci_data.uci_ri = ri; - uci_data.uci_ri_len = 1; + if (phy->config->dedicated.antenna_info_explicit_value.tx_mode == LIBLTE_RRC_TRANSMISSION_MODE_3 || + phy->config->dedicated.antenna_info_explicit_value.tx_mode == LIBLTE_RRC_TRANSMISSION_MODE_4) { + uci_data.uci_ri = ri; + uci_data.uci_ri_len = 1; + } else { + uci_data.uci_ri_len = 0; + } - Info("PUSCH: Aperiodic RM30 ri%s, CQI=%s, SNR=%.1f dB, for %d subbands\n", - (uci_data.uci_ri == 0)?"=1":"~1", cqi_str, phy->avg_snr_db, cqi_report.subband_hl.N); + Info("PUSCH: Aperiodic RM30 CQI=%s, SNR=%.1f dB, for %d subbands\n", + (uci_data.uci_ri_len)?((uci_data.uci_ri == 0)?"ri=0, ":"ri=1, "):"", cqi_str, phy->avg_snr_db, cqi_report.subband_hl.N); } break; case LIBLTE_RRC_CQI_REPORT_MODE_APERIODIC_RM31: From 4949759cdc8485f01db8deeb0f6e97e93bd1edef Mon Sep 17 00:00:00 2001 From: Xavier Arteaga Date: Tue, 6 Feb 2018 10:42:35 +0100 Subject: [PATCH 02/13] Fixed simultaneous PHICH (ACK) and CQI request. --- srsue/hdr/mac/ul_harq.h | 4 ++-- srsue/src/phy/phch_worker.cc | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/srsue/hdr/mac/ul_harq.h b/srsue/hdr/mac/ul_harq.h index 7418d23bf..b98a7497a 100644 --- a/srsue/hdr/mac/ul_harq.h +++ b/srsue/hdr/mac/ul_harq.h @@ -206,7 +206,7 @@ private: { if (ack) { if (grant) { - if (grant->ndi[0] == get_ndi()) { + if (grant->ndi[0] == get_ndi() && grant->phy_grant.ul.mcs.tbs != 0) { *ack = false; } } @@ -215,7 +215,7 @@ private: // Reset HARQ process if TB has changed if (harq_feedback && has_grant() && grant) { - if (grant->n_bytes[0] != cur_grant.n_bytes[0] && cur_grant.n_bytes[0] > 0) { + if (grant->n_bytes[0] != cur_grant.n_bytes[0] && cur_grant.n_bytes[0] > 0 && grant->n_bytes[0] > 0) { Debug("UL %d: Reset due to change of grant size last_grant=%d, new_grant=%d\n", pid, cur_grant.n_bytes[0], grant->n_bytes[0]); reset(); diff --git a/srsue/src/phy/phch_worker.cc b/srsue/src/phy/phch_worker.cc index 61c767e7a..720f0557e 100644 --- a/srsue/src/phy/phch_worker.cc +++ b/srsue/src/phy/phch_worker.cc @@ -931,7 +931,7 @@ void phch_worker::set_uci_aperiodic_cqi() int cqi_len = srslte_cqi_value_pack(&cqi_report, uci_data.uci_cqi); if (cqi_len < 0) { - Error("Error packing CQI value (Aperiodic reporting mode RM31)."); + Error("Error packing CQI value (Aperiodic reporting mode RM30)."); return; } uci_data.uci_cqi_len = (uint32_t) cqi_len; @@ -948,8 +948,8 @@ void phch_worker::set_uci_aperiodic_cqi() uci_data.uci_ri_len = 0; } - Info("PUSCH: Aperiodic RM30 CQI=%s, SNR=%.1f dB, for %d subbands\n", - (uci_data.uci_ri_len)?((uci_data.uci_ri == 0)?"ri=0, ":"ri=1, "):"", cqi_str, phy->avg_snr_db, cqi_report.subband_hl.N); + Info("PUSCH: Aperiodic RM30 CQI=%s, %sSNR=%.1f dB, for %d subbands\n", + cqi_str, (uci_data.uci_ri_len)?((uci_data.uci_ri == 0)?"ri=0, ":"ri=1, "):"", phy->avg_snr_db, cqi_report.subband_hl.N); } break; case LIBLTE_RRC_CQI_REPORT_MODE_APERIODIC_RM31: From 9dab102a7ee4b80198a643d58d7f4af9e1d0f405 Mon Sep 17 00:00:00 2001 From: Ismael Gomez Date: Tue, 6 Feb 2018 12:55:28 +0100 Subject: [PATCH 03/13] Removed debug printf from enb scheduler --- srsenb/src/mac/scheduler.cc | 11 +---------- 1 file changed, 1 insertion(+), 10 deletions(-) diff --git a/srsenb/src/mac/scheduler.cc b/srsenb/src/mac/scheduler.cc index fee1e5e5d..b7dc63898 100644 --- a/srsenb/src/mac/scheduler.cc +++ b/srsenb/src/mac/scheduler.cc @@ -864,16 +864,7 @@ int sched::ul_sched(uint32_t tti, srsenb::sched_interface::ul_sched_res_t* sched printf("SCHED: Could not schedule UL DCI rnti=0x%x, pid=%d, L=%d, sf_idx=%d\n", rnti, h->get_id(), aggr_level, sf_idx); - sched_ue::sched_dci_cce_t *loc=user->get_locations(current_cfi, sf_idx); - for (int i=0;inof_loc[aggr_level];i++) { - printf("n=%d\n", loc->cce_start[aggr_level][i]); - } - printf("used=["); - for (int i=0;ipusch[nof_dci_elems].needs_pdcch = false; + sched_result->pusch[nof_dci_elems].needs_pdcch = false; } else { sched_result->pusch[nof_dci_elems].needs_pdcch = true; } From f17cfa3ac30b0414b11f90906d0aa0cf00e7dbb6 Mon Sep 17 00:00:00 2001 From: Ismael Gomez Date: Tue, 6 Feb 2018 15:37:00 +0100 Subject: [PATCH 04/13] Fixed possible mod netgative SR period calculation --- lib/src/phy/ue/ue_ul.c | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/lib/src/phy/ue/ue_ul.c b/lib/src/phy/ue/ue_ul.c index a0accb579..5cf913bfa 100644 --- a/lib/src/phy/ue/ue_ul.c +++ b/lib/src/phy/ue/ue_ul.c @@ -626,13 +626,12 @@ int srslte_ue_ul_sr_send_tti(uint32_t I_sr, uint32_t current_tti) { } else { return SRSLTE_ERROR; } - uint32_t sfn = current_tti/10; - uint32_t subf = current_tti%10; - if ((10*sfn+subf-sr_N_offset)%sr_periodicity==0) { - return 1; - } else { - return SRSLTE_SUCCESS; + if (current_tti >= sr_N_offset) { + if ((current_tti - sr_N_offset) % sr_periodicity == 0) { + return 1; + } } + return SRSLTE_SUCCESS; } From 8f850754f3ca6f7fd7f6a4b9dd89f171e0455702 Mon Sep 17 00:00:00 2001 From: Andre Puschmann Date: Tue, 6 Feb 2018 16:42:43 +0100 Subject: [PATCH 05/13] check malloc return value in various tests --- lib/src/phy/phch/test/pdsch_pdcch_file_test.c | 7 ++++++- lib/src/phy/phch/test/pmch_file_test.c | 12 +++++++++--- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/lib/src/phy/phch/test/pdsch_pdcch_file_test.c b/lib/src/phy/phch/test/pdsch_pdcch_file_test.c index 76f48b959..baab97cea 100644 --- a/lib/src/phy/phch/test/pdsch_pdcch_file_test.c +++ b/lib/src/phy/phch/test/pdsch_pdcch_file_test.c @@ -175,6 +175,10 @@ int main(int argc, char **argv) { } uint8_t *data[] = {malloc(100000)}; + if (!data[0]) { + perror("malloc"); + exit(-1); + } ret = -1; nof_frames = 0; @@ -195,7 +199,8 @@ int main(int argc, char **argv) { } while (nof_frames <= max_frames && ret == 0); base_free(); - free(data[0]); + if (data[0]) + free(data[0]); if (ret > 0) { exit(0); } else { diff --git a/lib/src/phy/phch/test/pmch_file_test.c b/lib/src/phy/phch/test/pmch_file_test.c index 1d0715caa..fa6d04092 100644 --- a/lib/src/phy/phch/test/pmch_file_test.c +++ b/lib/src/phy/phch/test/pmch_file_test.c @@ -181,13 +181,17 @@ int main(int argc, char **argv) { exit(-1); } - uint8_t *data[] = {malloc(100000)}; + uint8_t *data = malloc(100000); + if (!data) { + perror("malloc"); + exit(-1); + } ret = -1; srslte_filesource_read(&fsrc, input_buffer[0], flen); INFO("Reading %d samples sub-frame %d\n", flen, sf_idx); - ret = srslte_ue_dl_decode_mbsfn(&ue_dl, data[0], sf_idx); + ret = srslte_ue_dl_decode_mbsfn(&ue_dl, data, sf_idx); if(ret > 0) { printf("PMCH Decoded OK!\n"); } else if (ret < 0) { @@ -195,7 +199,9 @@ int main(int argc, char **argv) { } base_free(); - free(data[0]); + if (data != NULL) { + free(data); + } if (ret > 0) { exit(0); } else { From 77b3cc97cd5d6331efd02d7ae4e2bd9618412455 Mon Sep 17 00:00:00 2001 From: Pedro Alvarez Date: Tue, 6 Feb 2018 17:46:27 +0000 Subject: [PATCH 06/13] Changing AMF value in user_db.csv to to have a separation bit of 1. --- srsepc/user_db.csv.example | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/srsepc/user_db.csv.example b/srsepc/user_db.csv.example index 89d0dedf1..4919ed6bb 100644 --- a/srsepc/user_db.csv.example +++ b/srsepc/user_db.csv.example @@ -10,4 +10,4 @@ # # Note: Lines starting by '#' are ignored ue1,001010123456789,00112233445566778899aabbccddeeff,63BFA50EE6523365FF14C1F45F88737D,9001 -ue2,001010123456780,00112233445566778899aabbccddeeaa,63BFA50EE6523365FF14C1F45F88737D,2000 +ue2,001010123456780,00112233445566778899aabbccddeeaa,63BFA50EE6523365FF14C1F45F88737D,8000 From 1fd2341932993ea777c8713f12b8def871ea4f40 Mon Sep 17 00:00:00 2001 From: Paul Sutton Date: Wed, 7 Feb 2018 09:37:26 +0000 Subject: [PATCH 07/13] Minor typo fix --- CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index a21ed4fa9..d67985c49 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -371,7 +371,7 @@ if(RF_FOUND) message(STATUS "Building with srsENB") add_subdirectory(srsenb) else(ENABLE_SRSENB) - message(STATUS "srsUE build disabled") + message(STATUS "srsENB build disabled") endif(ENABLE_SRSENB) else(RF_FOUND) message(STATUS "srsUE and srsENB builds disabled due to missing RF driver") From eb8a884e908ce3b7da760db58414dacc76c31f59 Mon Sep 17 00:00:00 2001 From: yagoda Date: Wed, 7 Feb 2018 16:51:23 +0000 Subject: [PATCH 08/13] small optimization in neon viterbi --- lib/src/phy/fec/viterbi37_neon.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/src/phy/fec/viterbi37_neon.c b/lib/src/phy/fec/viterbi37_neon.c index 452dba567..82ed190cc 100644 --- a/lib/src/phy/fec/viterbi37_neon.c +++ b/lib/src/phy/fec/viterbi37_neon.c @@ -176,7 +176,7 @@ void print_uint8x16_t(char *s, uint8x16_t val) { printf("\n"); } -int movemask_neon(uint8x16_t movemask_low_in) +static inline int movemask_neon(uint8x16_t movemask_low_in) { uint8x8_t lo = vget_low_u8(movemask_low_in); uint8x8_t hi = vget_high_u8(movemask_low_in); From 34233e64a4deec5ce3a27bc3a7812dca26ea58ee Mon Sep 17 00:00:00 2001 From: Xavier Arteaga Date: Tue, 6 Feb 2018 12:33:26 +0100 Subject: [PATCH 09/13] Fixed SNR source from equalizer to average --- srsue/src/phy/phch_worker.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/srsue/src/phy/phch_worker.cc b/srsue/src/phy/phch_worker.cc index 720f0557e..6951574f5 100644 --- a/srsue/src/phy/phch_worker.cc +++ b/srsue/src/phy/phch_worker.cc @@ -367,7 +367,7 @@ void phch_worker::work_imp() update_measurements(); if (chest_ok) { - if (phy->avg_rsrp_dbm > -130.0 && 10*log10(srslte_chest_dl_get_snr(&ue_dl.chest)) > -30.0) { + if (phy->avg_rsrp_dbm > -130.0 && phy->avg_snr_db > -30.0) { log_h->debug("SNR=%.1f dB, RSRP=%.1f dBm sync=in-sync from channel estimator\n", 10*log10(srslte_chest_dl_get_snr(&ue_dl.chest)), phy->avg_rsrp_dbm); chest_loop->in_sync(); From 0c2f0ac03844e4879978d994b8b4b1bc0dba1d97 Mon Sep 17 00:00:00 2001 From: Xavier Arteaga Date: Wed, 7 Feb 2018 18:36:06 +0100 Subject: [PATCH 10/13] Fixed srsue freq_offset compensation for UL --- lib/include/srslte/radio/radio.h | 1 + lib/src/radio/radio.cc | 5 ++++ srsue/hdr/phy/phch_worker.h | 2 ++ srsue/src/phy/phch_worker.cc | 47 ++++++++++++++++++++++++++++---- 4 files changed, 50 insertions(+), 5 deletions(-) diff --git a/lib/include/srslte/radio/radio.h b/lib/include/srslte/radio/radio.h index 6ff0c5100..454f1578f 100644 --- a/lib/include/srslte/radio/radio.h +++ b/lib/include/srslte/radio/radio.h @@ -101,6 +101,7 @@ namespace srslte { void set_tx_freq(double freq); void set_rx_freq(double freq); + double get_freq_offset(); double get_tx_freq(); double get_rx_freq(); diff --git a/lib/src/radio/radio.cc b/lib/src/radio/radio.cc index f592db71f..f3baad4a5 100644 --- a/lib/src/radio/radio.cc +++ b/lib/src/radio/radio.cc @@ -313,6 +313,11 @@ double radio::get_rx_freq() return rx_freq; } +double radio::get_freq_offset() +{ + return freq_offset; +} + double radio::get_tx_freq() { return tx_freq; diff --git a/srsue/hdr/phy/phch_worker.h b/srsue/hdr/phy/phch_worker.h index d73214514..c154ff514 100644 --- a/srsue/hdr/phy/phch_worker.h +++ b/srsue/hdr/phy/phch_worker.h @@ -70,6 +70,8 @@ public: void start_plot(); float get_ref_cfo(); + float get_cfo(); + float get_ul_cfo(); private: /* Inherited from thread_pool::worker. Function called every subframe to run the DL/UL processing */ diff --git a/srsue/src/phy/phch_worker.cc b/srsue/src/phy/phch_worker.cc index 6951574f5..f7e1381f8 100644 --- a/srsue/src/phy/phch_worker.cc +++ b/srsue/src/phy/phch_worker.cc @@ -203,6 +203,25 @@ float phch_worker::get_ref_cfo() return srslte_chest_dl_get_cfo(&ue_dl.chest); } +float phch_worker::get_cfo() +{ + return cfo; +} + +float phch_worker::get_ul_cfo() { + srslte::radio *radio = phy->get_radio(); + + if (radio->get_freq_offset() != 0.0f) { + /* Compensates the radio frequency offset applied equally to DL and UL */ + const float ul_dl_ratio = (float) radio->get_tx_freq() / (float) radio->get_rx_freq(); + const float offset_hz = (float) radio->get_freq_offset() * (1.0f - ul_dl_ratio); + return cfo - offset_hz / (15000); + } else { + return cfo; + } + +} + void phch_worker::work_imp() { if (!cell_initiated) { @@ -324,7 +343,7 @@ void phch_worker::work_imp() } /* Set UL CFO before transmission */ - srslte_ue_ul_set_cfo(&ue_ul, cfo); + srslte_ue_ul_set_cfo(&ue_ul, get_ul_cfo()); /* Transmit PUSCH, PUCCH or SRS */ bool signal_ready = false; @@ -1476,6 +1495,13 @@ plot_scatter_t pconst; float tmp_plot[SCATTER_PDSCH_BUFFER_LEN]; cf_t tmp_plot2[SRSLTE_SF_LEN_RE(SRSLTE_MAX_PRB, SRSLTE_CP_NORM)]; +#define CFO_PLOT_LEN 0 /* Set to non zero for enabling CFO plot */ +#if CFO_PLOT_LEN > 0 +static plot_real_t pcfo; +static uint32_t icfo = 0; +static float cfo_buffer[CFO_PLOT_LEN]; +#endif /* CFO_PLOT_LEN > 0 */ + void *plot_thread_run(void *arg) { srsue::phch_worker *worker = (srsue::phch_worker*) arg; @@ -1500,10 +1526,14 @@ void *plot_thread_run(void *arg) { plot_scatter_addToWindowGrid(&pconst, (char*)"srsue", 0, worker->get_rx_nof_antennas()); +#if CFO_PLOT_LEN > 0 + plot_real_init(&pcfo); + plot_real_setTitle(&pcfo, (char*) "CFO (Hz)"); + plot_real_setLabels(&pcfo, (char *) "Time", (char *) "Hz"); + plot_real_setYAxisScale(&pcfo, -4000, 4000); - - - + plot_scatter_addToWindowGrid(&pcfo, (char*)"srsue", 1, worker->get_rx_nof_antennas()); +#endif /* CFO_PLOT_LEN > 0 */ int n; int readed_pdsch_re=0; @@ -1527,7 +1557,14 @@ void *plot_thread_run(void *arg) { } readed_pdsch_re = 0; } - } + +#if CFO_PLOT_LEN > 0 + cfo_buffer[icfo] = worker->get_cfo() * 15000.0f; + icfo = (icfo + 1)%CFO_PLOT_LEN; + plot_real_setNewData(&pcfo, cfo_buffer, CFO_PLOT_LEN); +#endif /* CFO_PLOT_LEN > 0 */ + + } return NULL; } From ed76d73bbcef8756a7a48d52a46521f82cb85f26 Mon Sep 17 00:00:00 2001 From: Ismael Gomez Date: Thu, 8 Feb 2018 20:57:36 +0100 Subject: [PATCH 11/13] Print tpc_pucch for format2 dci also --- lib/src/phy/phch/dci.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/lib/src/phy/phch/dci.c b/lib/src/phy/phch/dci.c index 6766ca5f0..7bb2f9c19 100644 --- a/lib/src/phy/phch/dci.c +++ b/lib/src/phy/phch/dci.c @@ -426,7 +426,8 @@ uint32_t srslte_dci_dl_info(char *info_str, uint32_t len, srslte_ra_dl_dci_t *dc n += snprintf(&info_str[n], len - n, "%d}, ", dci_msg->ndi_1); } - if (format == SRSLTE_DCI_FORMAT1 || format == SRSLTE_DCI_FORMAT1A || format == SRSLTE_DCI_FORMAT1B) { + if (format == SRSLTE_DCI_FORMAT1 || format == SRSLTE_DCI_FORMAT1A || format == SRSLTE_DCI_FORMAT1B || + format == SRSLTE_DCI_FORMAT2 || format == SRSLTE_DCI_FORMAT2A || format == SRSLTE_DCI_FORMAT2B) { n += snprintf(&info_str[n], len-n, "tpc_pucch=%d, ", dci_msg->tpc_pucch); } if (format == SRSLTE_DCI_FORMAT2 || format == SRSLTE_DCI_FORMAT2A || format == SRSLTE_DCI_FORMAT2B) { From 7ae186d4991f11098f0c47a808dfab2e94cceb0c Mon Sep 17 00:00:00 2001 From: Ismael Gomez Date: Thu, 8 Feb 2018 20:58:00 +0100 Subject: [PATCH 12/13] Typo in printing default pdsch_ue help --- lib/examples/pdsch_ue.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/examples/pdsch_ue.c b/lib/examples/pdsch_ue.c index 1e17fa59d..74bac426d 100644 --- a/lib/examples/pdsch_ue.c +++ b/lib/examples/pdsch_ue.c @@ -162,8 +162,8 @@ void usage(prog_args_t *args, char *prog) { printf("\t-r RNTI in Hex [Default 0x%x]\n",args->rnti); printf("\t-l Force N_id_2 [Default best]\n"); printf("\t-C Disable CFO correction [Default %s]\n", args->disable_cfo?"Disabled":"Enabled"); - printf("\t-F Enable RS-based CFO correction [Default %s]\n", args->enable_cfo_ref?"Disabled":"Enabled"); - printf("\t-R Average channel estimates on 1 ms [Default %s]\n", args->average_subframe?"Disabled":"Enabled"); + printf("\t-F Enable RS-based CFO correction [Default %s]\n", !args->enable_cfo_ref?"Disabled":"Enabled"); + printf("\t-R Average channel estimates on 1 ms [Default %s]\n", !args->average_subframe?"Disabled":"Enabled"); printf("\t-t Add time offset [Default %d]\n", args->time_offset); #ifndef DISABLE_GRAPHICS printf("\t-d disable plots [Default enabled]\n"); From c429f3031f9c859ae1a9dded07dda6da5609f323 Mon Sep 17 00:00:00 2001 From: Ismael Gomez Date: Thu, 8 Feb 2018 20:58:43 +0100 Subject: [PATCH 13/13] Proper normalization to noise power estimation in chest_dl --- lib/src/phy/ch_estimation/chest_dl.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/lib/src/phy/ch_estimation/chest_dl.c b/lib/src/phy/ch_estimation/chest_dl.c index d63933ced..98ff6618c 100644 --- a/lib/src/phy/ch_estimation/chest_dl.c +++ b/lib/src/phy/ch_estimation/chest_dl.c @@ -282,10 +282,14 @@ static float estimate_noise_pilots(srslte_chest_dl_t *q, uint32_t port_id, srslt /* Compute average power. Normalized for filter len 3 using matlab */ float norm = 1; - if (q->smooth_filter_len == 3) { - float a = q->smooth_filter[0]; - float norm3 = 6.143*a*a+0.04859*a-0.002774; - norm /= norm3; + if (q->average_subframe) { + norm = 32; + } else { + if (q->smooth_filter_len == 3) { + float a = q->smooth_filter[0]; + float norm3 = 6.143*a*a+0.04859*a-0.002774; + norm /= norm3; + } } float power = norm*q->cell.nof_ports*srslte_vec_avg_power_cf(q->tmp_noise, nref); return power;