|
|
@ -97,7 +97,7 @@ void phch_recv::init(srslte::radio_multi *_radio_handler, mac_interface_phy *_ma
|
|
|
|
intra_freq_meas.init(worker_com, rrc, log_h);
|
|
|
|
intra_freq_meas.init(worker_com, rrc, log_h);
|
|
|
|
|
|
|
|
|
|
|
|
reset();
|
|
|
|
reset();
|
|
|
|
|
|
|
|
running = true;
|
|
|
|
// Start main thread
|
|
|
|
// Start main thread
|
|
|
|
if (sync_cpu_affinity < 0) {
|
|
|
|
if (sync_cpu_affinity < 0) {
|
|
|
|
start(prio);
|
|
|
|
start(prio);
|
|
|
@ -125,7 +125,6 @@ void phch_recv::stop()
|
|
|
|
void phch_recv::reset()
|
|
|
|
void phch_recv::reset()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
tx_mutex_cnt = 0;
|
|
|
|
tx_mutex_cnt = 0;
|
|
|
|
running = true;
|
|
|
|
|
|
|
|
phy_state = IDLE;
|
|
|
|
phy_state = IDLE;
|
|
|
|
time_adv_sec = 0;
|
|
|
|
time_adv_sec = 0;
|
|
|
|
next_offset = 0;
|
|
|
|
next_offset = 0;
|
|
|
@ -690,6 +689,12 @@ void phch_recv::run_thread()
|
|
|
|
worker->set_tti(tti, tx_mutex_cnt);
|
|
|
|
worker->set_tti(tti, tx_mutex_cnt);
|
|
|
|
tx_mutex_cnt = (tx_mutex_cnt+1) % nof_tx_mutex;
|
|
|
|
tx_mutex_cnt = (tx_mutex_cnt+1) % nof_tx_mutex;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Reset Uplink TX buffer to avoid mixing packets in TX queue
|
|
|
|
|
|
|
|
if (prach_buffer->is_pending()) {
|
|
|
|
|
|
|
|
Info("SYNC: PRACH pending: Reset UL\n");
|
|
|
|
|
|
|
|
worker_com->reset_ul();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Check if we need to TX a PRACH
|
|
|
|
// Check if we need to TX a PRACH
|
|
|
|
if (prach_buffer->is_ready_to_send(tti)) {
|
|
|
|
if (prach_buffer->is_ready_to_send(tti)) {
|
|
|
|
srslte_timestamp_copy(&tx_time_prach, &rx_time);
|
|
|
|
srslte_timestamp_copy(&tx_time_prach, &rx_time);
|
|
|
@ -706,21 +711,11 @@ void phch_recv::run_thread()
|
|
|
|
srslte_pss_sic(&ue_sync.strack.pss, &buffer[0][SRSLTE_SF_LEN_PRB(cell.nof_prb)/2-ue_sync.strack.fft_size]);
|
|
|
|
srslte_pss_sic(&ue_sync.strack.pss, &buffer[0][SRSLTE_SF_LEN_PRB(cell.nof_prb)/2-ue_sync.strack.fft_size]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
intra_freq_meas.write(tti, buffer[0], SRSLTE_SF_LEN_PRB(cell.nof_prb));
|
|
|
|
intra_freq_meas.write(tti, buffer[0], SRSLTE_SF_LEN_PRB(cell.nof_prb));
|
|
|
|
out_of_sync_cnt = 0;
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 0:
|
|
|
|
case 0:
|
|
|
|
// Signal every 5 errors only (PSS is every 5)
|
|
|
|
out_of_sync();
|
|
|
|
if (out_of_sync_cnt == 0) {
|
|
|
|
|
|
|
|
// Notify RRC of out-of-sync frame
|
|
|
|
|
|
|
|
log_h->error("SYNC: Sync error. Sending out-of-sync to RRC\n");
|
|
|
|
|
|
|
|
rrc->out_of_sync();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
worker->release();
|
|
|
|
worker->release();
|
|
|
|
worker_com->reset_ul();
|
|
|
|
worker_com->reset_ul();
|
|
|
|
out_of_sync_cnt++;
|
|
|
|
|
|
|
|
if (out_of_sync_cnt >= 5) {
|
|
|
|
|
|
|
|
out_of_sync_cnt = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
radio_error();
|
|
|
|
radio_error();
|
|
|
@ -746,14 +741,12 @@ void phch_recv::run_thread()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void phch_recv::out_of_sync() {
|
|
|
|
void phch_recv::in_sync() {
|
|
|
|
out_of_sync2_cnt++;
|
|
|
|
rrc->in_sync();
|
|
|
|
Info("SYNC: Received out_of_sync from channel estimator (%d)\n", out_of_sync2_cnt);
|
|
|
|
|
|
|
|
if (out_of_sync2_cnt >= 2) {
|
|
|
|
|
|
|
|
out_of_sync2_cnt = 0;
|
|
|
|
|
|
|
|
Info("SYNC: Trying to resync signal\n");
|
|
|
|
|
|
|
|
resync_sfn(true, true);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void phch_recv::out_of_sync() {
|
|
|
|
|
|
|
|
rrc->out_of_sync();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1085,7 +1078,7 @@ phch_recv::measure::ret_code phch_recv::measure::run_subframe_sync(srslte_ue_syn
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int sync_res = srslte_ue_sync_zerocopy_multi(ue_sync, buffer);
|
|
|
|
int sync_res = srslte_ue_sync_zerocopy_multi(ue_sync, buffer);
|
|
|
|
if (sync_res == 1) {
|
|
|
|
if (sync_res == 1) {
|
|
|
|
log_h->info("SYNC: CFO=%.1f KHz\n", srslte_ue_sync_get_cfo(ue_sync));
|
|
|
|
log_h->info("SYNC: CFO=%.1f KHz\n", srslte_ue_sync_get_cfo(ue_sync)/1000);
|
|
|
|
return run_subframe(sf_idx);
|
|
|
|
return run_subframe(sf_idx);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
log_h->error("SYNC: Measuring RSRP: Sync error\n");
|
|
|
|
log_h->error("SYNC: Measuring RSRP: Sync error\n");
|
|
|
@ -1284,10 +1277,11 @@ int phch_recv::scell_recv::find_cells(cf_t *input_buffer, float rx_gain_offset,
|
|
|
|
srslte_sync_reset(&sync_find);
|
|
|
|
srslte_sync_reset(&sync_find);
|
|
|
|
srslte_sync_cfo_reset(&sync_find);
|
|
|
|
srslte_sync_cfo_reset(&sync_find);
|
|
|
|
|
|
|
|
|
|
|
|
uint32_t sf5_cnt=0;
|
|
|
|
int sf5_cnt=-1;
|
|
|
|
do {
|
|
|
|
do {
|
|
|
|
|
|
|
|
sf5_cnt++;
|
|
|
|
sync_res = srslte_sync_find(&sync_find, input_buffer, sf5_cnt*5*sf_len, &peak_idx);
|
|
|
|
sync_res = srslte_sync_find(&sync_find, input_buffer, sf5_cnt*5*sf_len, &peak_idx);
|
|
|
|
} while(sync_res != SRSLTE_SYNC_FOUND && sf5_cnt < nof_sf/5);
|
|
|
|
} while(sync_res != SRSLTE_SYNC_FOUND && (uint32_t) sf5_cnt + 1 < nof_sf/5);
|
|
|
|
|
|
|
|
|
|
|
|
switch(sync_res) {
|
|
|
|
switch(sync_res) {
|
|
|
|
case SRSLTE_SYNC_ERROR:
|
|
|
|
case SRSLTE_SYNC_ERROR:
|
|
|
@ -1315,20 +1309,20 @@ int phch_recv::scell_recv::find_cells(cf_t *input_buffer, float rx_gain_offset,
|
|
|
|
-srslte_sync_get_cfo(&sync_find)/sync_find.fft_size);
|
|
|
|
-srslte_sync_get_cfo(&sync_find)/sync_find.fft_size);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
switch(measure_p.run_multiple_subframes(input_cfo_corrected, peak_idx, sf_idx, nof_sf)) {
|
|
|
|
switch(measure_p.run_multiple_subframes(input_cfo_corrected, peak_idx+sf5_cnt*5*sf_len, sf_idx, nof_sf)) {
|
|
|
|
case measure::MEASURE_OK:
|
|
|
|
case measure::MEASURE_OK:
|
|
|
|
cells[nof_cells].pci = found_cell.id;
|
|
|
|
cells[nof_cells].pci = found_cell.id;
|
|
|
|
cells[nof_cells].rsrp = measure_p.rsrp();
|
|
|
|
cells[nof_cells].rsrp = measure_p.rsrp();
|
|
|
|
cells[nof_cells].rsrq = measure_p.rsrq();
|
|
|
|
cells[nof_cells].rsrq = measure_p.rsrq();
|
|
|
|
cells[nof_cells].offset = measure_p.frame_st_idx();
|
|
|
|
cells[nof_cells].offset = measure_p.frame_st_idx();
|
|
|
|
|
|
|
|
|
|
|
|
Info("INTRA: Found neighbour cell %d: PCI=%03d, RSRP=%5.1f dBm, peak_idx=%5d, peak_value=%3.2f n_id_2=%d, CFO=%6.1f Hz\n",
|
|
|
|
Info("INTRA: Found neighbour cell %d: PCI=%03d, RSRP=%5.1f dBm, peak_idx=%5d, peak_value=%3.2f, sf5_cnt=%d, n_id_2=%d, CFO=%6.1f Hz\n",
|
|
|
|
nof_cells, cell_id, measure_p.rsrp(), measure_p.frame_st_idx(), sync_find.peak_value, n_id_2, 15000*srslte_sync_get_cfo(&sync_find));
|
|
|
|
nof_cells, cell_id, measure_p.rsrp(), measure_p.frame_st_idx(), sync_find.peak_value, sf5_cnt, n_id_2, 15000*srslte_sync_get_cfo(&sync_find));
|
|
|
|
|
|
|
|
|
|
|
|
nof_cells++;
|
|
|
|
nof_cells++;
|
|
|
|
|
|
|
|
|
|
|
|
if (sic_pss_enabled) {
|
|
|
|
if (sic_pss_enabled) {
|
|
|
|
srslte_pss_sic(&sync_find.pss, &input_buffer[sf_len/2-fft_sz]);
|
|
|
|
srslte_pss_sic(&sync_find.pss, &input_buffer[sf5_cnt*5*sf_len+sf_len/2-fft_sz]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
@ -1349,7 +1343,7 @@ int phch_recv::scell_recv::find_cells(cf_t *input_buffer, float rx_gain_offset,
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} while (sync_res == SRSLTE_SYNC_FOUND && sic_pss_enabled);
|
|
|
|
} while (sync_res == SRSLTE_SYNC_FOUND && sic_pss_enabled && nof_cells < MAX_CELLS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nof_cells;
|
|
|
|
return nof_cells;
|
|
|
|