@ -34,150 +34,152 @@
# define SRSLTE_RADIO_H
# define SRSLTE_RADIO_H
typedef struct {
typedef struct {
float tx_corr_dc_gain ;
float tx_corr_dc_gain ;
float tx_corr_dc_phase ;
float tx_corr_dc_phase ;
float tx_corr_iq_i ;
float tx_corr_iq_i ;
float tx_corr_iq_q ;
float tx_corr_iq_q ;
float rx_corr_dc_gain ;
float rx_corr_dc_gain ;
float rx_corr_dc_phase ;
float rx_corr_dc_phase ;
float rx_corr_iq_i ;
float rx_corr_iq_i ;
float rx_corr_iq_q ;
float rx_corr_iq_q ;
} rf_cal_t ;
} rf_cal_t ;
namespace srslte {
namespace srslte {
/* Interface to the RF frontend.
/* Interface to the RF frontend.
*/
*/
class radio
class radio {
{
public :
public :
radio ( ) : tr_local_time ( 1024 * 10 ) , tr_usrp_time ( 1024 * 10 ) , tr_tx_time ( 1024 * 10 ) , tr_is_eob ( 1024 * 10 ) {
radio ( ) : tr_local_time ( 1024 * 10 ) , tr_usrp_time ( 1024 * 10 ) , tr_tx_time ( 1024 * 10 ) , tr_is_eob ( 1024 * 10 ) {
bzero ( & rf_device , sizeof ( srslte_rf_t ) ) ;
bzero ( & rf_device , sizeof ( srslte_rf_t ) ) ;
bzero ( & end_of_burst_time , sizeof ( srslte_timestamp_t ) ) ;
bzero ( & end_of_burst_time , sizeof ( srslte_timestamp_t ) ) ;
bzero ( zeros , burst_preamble_max_samples * sizeof ( cf_t ) ) ;
bzero ( zeros , burst_preamble_max_samples * sizeof ( cf_t ) ) ;
burst_preamble_sec = 0 ;
burst_preamble_sec = 0 ;
is_start_of_burst = false ;
is_start_of_burst = false ;
burst_preamble_samples = 0 ;
burst_preamble_samples = 0 ;
burst_preamble_time_rounded = 0 ;
burst_preamble_time_rounded = 0 ;
cur_tx_srate = 0 ;
cur_tx_srate = 0 ;
tx_adv_sec = 0 ;
tx_adv_sec = 0 ;
tx_adv_nsamples = 0 ;
tx_adv_nsamples = 0 ;
tx_adv_auto = false ;
tx_adv_auto = false ;
tx_adv_negative = false ;
tx_adv_negative = false ;
tx_freq = 0 ;
tx_freq = 0 ;
rx_freq = 0 ;
rx_freq = 0 ;
trace_enabled = false ;
trace_enabled = false ;
tti = 0 ;
tti = 0 ;
agc_enabled = false ;
agc_enabled = false ;
radio_is_streaming = false ;
radio_is_streaming = false ;
is_initialized = false ;
is_initialized = false ;
continuous_tx = false ;
} ;
} ;
bool init ( char * args = NULL , char * devname = NULL , uint32_t nof_channels = 1 ) ;
void stop ( ) ;
void reset ( ) ;
bool start_agc ( bool tx_gain_same_rx ) ;
void set_burst_preamble ( double preamble_us ) ;
void set_tx_adv ( int nsamples ) ;
void set_tx_adv_neg ( bool tx_adv_is_neg ) ;
void set_manual_calibration ( rf_cal_t * calibration ) ;
void get_time ( srslte_timestamp_t * now ) ;
bool tx_single ( void * buffer , uint32_t nof_samples , srslte_timestamp_t tx_time ) ;
bool tx ( void * buffer [ SRSLTE_MAX_PORTS ] , uint32_t nof_samples , srslte_timestamp_t tx_time ) ;
void tx_end ( ) ;
bool rx_now ( void * buffer [ SRSLTE_MAX_PORTS ] , uint32_t nof_samples , srslte_timestamp_t * rxd_time ) ;
bool rx_at ( void * buffer , uint32_t nof_samples , srslte_timestamp_t rx_time ) ;
void set_tx_gain ( float gain ) ;
void set_rx_gain ( float gain ) ;
void set_tx_rx_gain_offset ( float offset ) ;
double set_rx_gain_th ( float gain ) ;
void set_freq_offset ( double freq ) ;
void set_tx_freq ( double freq ) ;
void set_rx_freq ( double freq ) ;
double get_freq_offset ( ) ;
double get_tx_freq ( ) ;
double get_rx_freq ( ) ;
void set_master_clock_rate ( double rate ) ;
void set_tx_srate ( double srate ) ;
void set_rx_srate ( double srate ) ;
float get_tx_gain ( ) ;
float get_rx_gain ( ) ;
float get_max_tx_power ( ) ;
float set_tx_power ( float power ) ;
float get_rssi ( ) ;
bool has_rssi ( ) ;
void start_trace ( ) ;
void write_trace ( std : : string filename ) ;
void set_tti ( uint32_t tti ) ;
bool is_first_of_burst ( ) ;
bool is_init ( ) ;
void register_error_handler ( srslte_rf_error_handler_t h ) ;
protected :
void save_trace ( uint32_t is_eob , srslte_timestamp_t * usrp_time ) ;
srslte_rf_t rf_device ;
const static uint32_t burst_preamble_max_samples = 30720000 ; // 30.72 MHz is maximum frequency
double burst_preamble_sec ; // Start of burst preamble time (off->on RF transition time)
srslte_timestamp_t end_of_burst_time ;
bool is_start_of_burst ;
uint32_t burst_preamble_samples ;
double burst_preamble_time_rounded ; // preamble time rounded to sample time
cf_t zeros [ burst_preamble_max_samples ] ;
double cur_tx_srate ;
double tx_adv_sec ; // Transmission time advance to compensate for antenna->timestamp delay
int tx_adv_nsamples ; // Transmision time advance in number of samples
// Define default values for known radios
bool tx_adv_auto ;
bool tx_adv_negative ;
const static double uhd_default_burst_preamble_sec = 600 * 1e-6 ;
const static double uhd_default_tx_adv_samples = 98 ;
const static double uhd_default_tx_adv_offset_sec = 4 * 1e-6 ;
const static double blade_default_burst_preamble_sec = 0.0 ;
bool init ( char * args = NULL , char * devname = NULL , uint32_t nof_channels = 1 ) ;
const static double blade_default_tx_adv_samples = 27 ;
void stop ( ) ;
const static double blade_default_tx_adv_offset_sec = 1e-6 ;
void reset ( ) ;
bool start_agc ( bool tx_gain_same_rx ) ;
double tx_freq , rx_freq , freq_offset ;
void set_burst_preamble ( double preamble_us ) ;
void set_tx_adv ( int nsamples ) ;
void set_tx_adv_neg ( bool tx_adv_is_neg ) ;
trace < uint32_t > tr_local_time ;
void set_manual_calibration ( rf_cal_t * calibration ) ;
trace < uint32_t > tr_usrp_time ;
trace < uint32_t > tr_tx_time ;
trace < uint32_t > tr_is_eob ;
bool trace_enabled ;
uint32_t tti ;
bool agc_enabled ;
bool is_initialized = true ; ;
bool is_continuous_tx ( ) ;
bool radio_is_streaming ;
void set_continuous_tx ( bool enable ) ;
uint32_t saved_nof_channels ;
void get_time ( srslte_timestamp_t * now ) ;
char saved_args [ 128 ] ;
bool tx_single ( void * buffer , uint32_t nof_samples , srslte_timestamp_t tx_time ) ;
char saved_devname [ 128 ] ;
bool tx ( void * buffer [ SRSLTE_MAX_PORTS ] , uint32_t nof_samples , srslte_timestamp_t tx_time ) ;
void tx_end ( ) ;
bool rx_now ( void * buffer [ SRSLTE_MAX_PORTS ] , uint32_t nof_samples , srslte_timestamp_t * rxd_time ) ;
bool rx_at ( void * buffer , uint32_t nof_samples , srslte_timestamp_t rx_time ) ;
} ;
void set_tx_gain ( float gain ) ;
void set_rx_gain ( float gain ) ;
void set_tx_rx_gain_offset ( float offset ) ;
double set_rx_gain_th ( float gain ) ;
void set_freq_offset ( double freq ) ;
void set_tx_freq ( double freq ) ;
void set_rx_freq ( double freq ) ;
double get_freq_offset ( ) ;
double get_tx_freq ( ) ;
double get_rx_freq ( ) ;
void set_master_clock_rate ( double rate ) ;
void set_tx_srate ( double srate ) ;
void set_rx_srate ( double srate ) ;
float get_tx_gain ( ) ;
float get_rx_gain ( ) ;
float get_max_tx_power ( ) ;
float set_tx_power ( float power ) ;
float get_rssi ( ) ;
bool has_rssi ( ) ;
void start_trace ( ) ;
void write_trace ( std : : string filename ) ;
void set_tti ( uint32_t tti ) ;
bool is_first_of_burst ( ) ;
bool is_init ( ) ;
void register_error_handler ( srslte_rf_error_handler_t h ) ;
protected :
void save_trace ( uint32_t is_eob , srslte_timestamp_t * usrp_time ) ;
srslte_rf_t rf_device ;
const static uint32_t burst_preamble_max_samples = 30720000 ; // 30.72 MHz is maximum frequency
double burst_preamble_sec ; // Start of burst preamble time (off->on RF transition time)
srslte_timestamp_t end_of_burst_time ;
bool is_start_of_burst ;
uint32_t burst_preamble_samples ;
double burst_preamble_time_rounded ; // preamble time rounded to sample time
cf_t zeros [ burst_preamble_max_samples ] ;
double cur_tx_srate ;
double tx_adv_sec ; // Transmission time advance to compensate for antenna->timestamp delay
int tx_adv_nsamples ; // Transmision time advance in number of samples
// Define default values for known radios
bool tx_adv_auto ;
bool tx_adv_negative ;
const static double uhd_default_burst_preamble_sec = 600 * 1e-6 ;
const static double uhd_default_tx_adv_samples = 98 ;
const static double uhd_default_tx_adv_offset_sec = 4 * 1e-6 ;
const static double blade_default_burst_preamble_sec = 0.0 ;
const static double blade_default_tx_adv_samples = 27 ;
const static double blade_default_tx_adv_offset_sec = 1e-6 ;
double tx_freq , rx_freq , freq_offset ;
trace < uint32_t > tr_local_time ;
trace < uint32_t > tr_usrp_time ;
trace < uint32_t > tr_tx_time ;
trace < uint32_t > tr_is_eob ;
bool trace_enabled ;
uint32_t tti ;
bool agc_enabled ;
bool continuous_tx ;
bool is_initialized ;
bool radio_is_streaming ;
uint32_t saved_nof_channels ;
char saved_args [ 128 ] ;
char saved_devname [ 128 ] ;
} ;
}
}
# endif // SRSLTE_RADIO_H
# endif // SRSLTE_RADIO_H