diff --git a/openair1/PHY/LTE_TRANSPORT/dci_tools.c b/openair1/PHY/LTE_TRANSPORT/dci_tools.c index be64bccb06858e275416916606a7c069aec5c2a3..a040c64b23b01abc297a17fc0f33242575452ffc 100644 --- a/openair1/PHY/LTE_TRANSPORT/dci_tools.c +++ b/openair1/PHY/LTE_TRANSPORT/dci_tools.c @@ -5110,7 +5110,7 @@ double sinr_eff_cqi_calc(PHY_VARS_UE *phy_vars_ue, uint8_t eNB_id){ sinr_eff_qam64 = (p_qam64[0]*pow(I_qam64_avg,7) + p_qam64[1]*pow(I_qam64_avg,6) + p_qam64[2]*pow(I_qam64_avg,5) + p_qam64[3]*pow(I_qam64_avg,4) + p_qam64[4]*pow(I_qam64_avg,3) + p_qam64[5]*pow(I_qam64_avg,2) + p_qam64[6]*I_qam64_avg + p_qam64[7]); sinr_eff = cmax3(sinr_eff_qpsk,sinr_eff_qam16,sinr_eff_qam64); - msg("SINR_Eff = %e\n",sinr_eff); + //msg("SINR_Eff = %e\n",sinr_eff); return(sinr_eff); } diff --git a/openair1/PHY/TOOLS/lte_phy_scope.c b/openair1/PHY/TOOLS/lte_phy_scope.c index 421a60f7dece6a9a91dbb7d17d93c898549dad79..1e997483cad161e8aab1552652e901125aa9e27d 100644 --- a/openair1/PHY/TOOLS/lte_phy_scope.c +++ b/openair1/PHY/TOOLS/lte_phy_scope.c @@ -158,7 +158,7 @@ void phy_scope_eNB(FD_lte_phy_scope_enb *form, float *chest_f_abs; float time[FRAME_LENGTH_COMPLEX_SAMPLES]; float freq[nsymb_ce*nb_antennas_rx*nb_antennas_tx]; - int frame = phy_vars_enb->frame; + int frame = phy_vars_enb->proc[0].frame_tx; uint32_t total_dlsch_bitrate = phy_vars_enb->total_dlsch_bitrate; int coded_bits_per_codeword = 0; uint8_t harq_pid; // in TDD config 3 it is sf-2, i.e., can be 0,1,2 @@ -469,6 +469,7 @@ void phy_scope_UE(FD_lte_phy_scope_ue *form, phy_vars_ue->dlsch_ue[eNB_id][0]->harq_processes[harq_pid]->nb_rb, phy_vars_ue->dlsch_ue[eNB_id][0]->harq_processes[harq_pid]->rb_alloc, get_Qm(mcs), + phy_vars_ue->dlsch_ue[eNB_id][0]->harq_processes[harq_pid]->Nl, num_pdcch_symbols, frame, subframe); diff --git a/openair2/LAYER2/MAC/eNB_scheduler_dlsch.c b/openair2/LAYER2/MAC/eNB_scheduler_dlsch.c index 6ab1a483d50cf3530211b55f5a97edf7d1d8d659..4c7bed36607b59d45e51ae06f8d13ab3f7447f80 100644 --- a/openair2/LAYER2/MAC/eNB_scheduler_dlsch.c +++ b/openair2/LAYER2/MAC/eNB_scheduler_dlsch.c @@ -1688,10 +1688,10 @@ void fill_DLSCH_dci(module_id_t module_idP,frame_t frameP, sub_frame_t subframeP } } // RA is scheduled in this subframeP - printf("Doing UE_spec DCIs\n"); + LOG_I(MAC,"Doing UE_spec DCIs\n"); // UE specific DCIs for (UE_id=UE_list->head;UE_id>=0;UE_id=UE_list->next[UE_id]) { - printf("UE_id: %d => status %d\n",UE_id,eNB_dlsch_info[module_idP][UE_id].status); + LOG_I(MAC,"UE_id: %d => status %d\n",UE_id,eNB_dlsch_info[module_idP][UE_id].status); if (eNB_dlsch_info[module_idP][UE_id].status == S_DL_SCHEDULED) { // clear scheduling flag diff --git a/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.c b/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.c index b199b9be77e4e9eb3b806d96d7c5f056c9549d21..e9f0c312bb677c3ff815de5b3f40eb632b1b8c6f 100644 --- a/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.c +++ b/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.c @@ -255,7 +255,7 @@ int openair0_device_init(openair0_device *device, openair0_config_t *openair0_cf // Initialize card int ret; int ant; - + int resampling_factor=2; ret = openair0_open(); @@ -292,11 +292,23 @@ int openair0_device_init(openair0_device *device, openair0_config_t *openair0_cf p_exmimo_config->framing.eNB_flag = 1;//!UE_flag; p_exmimo_config->framing.tdd_config = DUPLEXMODE_FDD + TXRXSWITCH_LSB; + + if (openair0_cfg->sample_rate==30.72e6) + resampling_factor = 0; + else if (openair0_cfg->sample_rate==15.36e6) + resampling_factor = 1; + else if (openair0_cfg->sample_rate==7.68e6) + resampling_factor = 2; + else { + printf("Sampling rate not supported, using default 7.68MHz"); + resampling_factor = 2; + } + #if (BOARD_SWREV_CNTL2>=0x0A) for (ant=0; ant<4; ant++) - p_exmimo_config->framing.resampling_factor[ant] = 2; + p_exmimo_config->framing.resampling_factor[ant] = resampling_factor; #else - p_exmimo_config->framing.resampling_factor = 2; + p_exmimo_config->framing.resampling_factor = resampling_factor; #endif if (!openair0_cfg) { diff --git a/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.h b/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.h index 3d3c0012f7f478cbd85c1ea99e7f3f70350b1874..3c07c3815de6b948a2719a0215922ef34354931b 100644 --- a/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.h +++ b/targets/ARCH/EXMIMO/USERSPACE/LIB/openair0_lib.h @@ -84,6 +84,6 @@ int openair0_stop(int card); int openair0_stop_without_reset(int card); // return the DAQ block counter -unsigned int *openair0_daq_cnt(); +unsigned int *openair0_daq_cnt(void); #endif diff --git a/targets/RT/USER/lte-softmodem.c b/targets/RT/USER/lte-softmodem.c index 7c41adcfae45517202a4fe918d758d31980fc3d5..130692a56a45d26804c8587b01b63bd5a0706e31 100644 --- a/targets/RT/USER/lte-softmodem.c +++ b/targets/RT/USER/lte-softmodem.c @@ -424,14 +424,14 @@ static void *scope_thread(void *arg) { # ifdef ENABLE_XFORMS_WRITE_STATS len = # endif - dump_ue_stats (PHY_vars_UE_g[0], stats_buffer, 0, mode,rx_input_level_dBm); + dump_ue_stats (PHY_vars_UE_g[0][0], stats_buffer, 0, mode,rx_input_level_dBm); fl_set_object_label(form_stats->stats_text, stats_buffer); # ifdef ENABLE_XFORMS_WRITE_STATS rewind (UE_stats); fwrite (stats_buffer, 1, len, UE_stats); # endif phy_scope_UE(form_ue[UE_id], - PHY_vars_UE_g[UE_id], + PHY_vars_UE_g[UE_id][0], eNB_id, UE_id,7); @@ -1047,7 +1047,6 @@ void init_eNB_proc() { pthread_attr_setschedparam (&attr_eNB_proc_rx[CC_id][i], &sched_param_eNB_proc_rx[CC_id][i]); pthread_attr_setschedpolicy (&attr_eNB_proc_rx[CC_id][i], SCHED_FIFO); - for (CC_id=0;CC_id<MAX_NUM_CCs;CC_id++) { PHY_vars_eNB_g[0][CC_id]->proc[i].instance_cnt_tx=-1; PHY_vars_eNB_g[0][CC_id]->proc[i].instance_cnt_rx=-1; PHY_vars_eNB_g[0][CC_id]->proc[i].subframe=i; @@ -1067,7 +1066,6 @@ void init_eNB_proc() { PHY_vars_eNB_g[0][CC_id]->proc[i].subframe_rx = i; PHY_vars_eNB_g[0][CC_id]->proc[i].subframe_tx = (i+2)%10; #endif - } } @@ -1371,10 +1369,10 @@ static void *eNB_thread(void *arg) if (multi_thread == 0) { if ((slot&1) == 0) { LOG_I(PHY,"[eNB] Single thread slot %d\n",slot); - for (CC_id=0;CC_id<MAX_NUM_CCs;CC_id++) { - phy_procedures_eNB_lte ((2+(slot>>1))%10, PHY_vars_eNB_g[0][CC_id], 0, no_relay,NULL); - do_OFDM_mod((2+(slot>>1))%10,PHY_vars_eNB_g[0][CC_id]); - } + phy_procedures_eNB_lte ((2+(slot>>1))%10, PHY_vars_eNB_g[0], 0, no_relay,NULL); + for (CC_id=0;CC_id<MAX_NUM_CCs;CC_id++) { + do_OFDM_mod((2+(slot>>1))%10,PHY_vars_eNB_g[0][CC_id]); + } } } else { // multi-thread > 0 @@ -1881,8 +1879,8 @@ static void get_options (int argc, char **argv) { frame_parms->tdd_config_S = enb_properties->properties[i]->tdd_config_s; for (j=0; j < enb_properties->properties[i]->nb_cc; j++ ){ - frame_parms->Nid_cell = enb_properties->properties[i]->cell_id; - frame_parms->N_RB_DL = enb_properties->properties[i]->N_RB_DL; + frame_parms->Nid_cell = enb_properties->properties[i]->cell_id[j]; + frame_parms->N_RB_DL = enb_properties->properties[i]->N_RB_DL[j]; } // j glog_level = enb_properties->properties[i]->glog_level; @@ -1941,7 +1939,9 @@ int main(int argc, char **argv) { // int ret, ant; int ant_offset=0; - +#ifdef XFORMS + int ret; +#endif #if defined (EMOS) || (! defined (RTAI)) int error_code; #endif @@ -2204,7 +2204,7 @@ int main(int argc, char **argv) { NB_INST=1; openair_daq_vars.ue_dl_rb_alloc=0x1fff; - openair_daq_vars.target_ue_dl_mcs=16; + openair_daq_vars.target_ue_dl_mcs=20; openair_daq_vars.ue_ul_nb_rb=6; openair_daq_vars.target_ue_ul_mcs=6;