Add per-channel TX gain (#1450)

* Change type of rf_set_gain() to avoid unambiguous return with negative gains

* Add per-channel TX gain
master
Ismael Gomez 5 years ago committed by GitHub
parent 52c6c6aafd
commit 29e126a583
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -511,7 +511,8 @@ int main(int argc, char** argv)
fprintf(stderr, "Invalid number of PRB %d\n", cell.base.nof_prb); fprintf(stderr, "Invalid number of PRB %d\n", cell.base.nof_prb);
exit(-1); exit(-1);
} }
printf("Set TX gain: %.1f dB\n", srslte_rf_set_tx_gain(&radio, rf_gain)); srslte_rf_set_tx_gain(&radio, rf_gain);
printf("Set TX gain: %.1f dB\n", srslte_rf_get_tx_gain(&radio));
printf("Set TX freq: %.2f MHz\n", srslte_rf_set_tx_freq(&radio, 0, rf_freq) / 1000000); printf("Set TX freq: %.2f MHz\n", srslte_rf_set_tx_freq(&radio, 0, rf_freq) / 1000000);
} }
#endif #endif

@ -363,7 +363,8 @@ int main(int argc, char** argv)
} }
/* Set receiver gain */ /* Set receiver gain */
if (prog_args.rf_gain > 0) { if (prog_args.rf_gain > 0) {
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, prog_args.rf_gain)); srslte_rf_set_rx_gain(&rf, prog_args.rf_gain);
printf("Set RX gain: %.1f dB\n", prog_args.rf_gain);
} else { } else {
printf("Starting AGC thread...\n"); printf("Starting AGC thread...\n");
if (srslte_rf_start_gain_thread(&rf, false)) { if (srslte_rf_start_gain_thread(&rf, false)) {

@ -778,7 +778,8 @@ int main(int argc, char** argv)
ERROR("Invalid number of PRB %d\n", cell.nof_prb); ERROR("Invalid number of PRB %d\n", cell.nof_prb);
exit(-1); exit(-1);
} }
printf("Set TX gain: %.1f dB\n", srslte_rf_set_tx_gain(&radio, rf_gain)); srslte_rf_set_tx_gain(&radio, rf_gain);
printf("Set TX gain: %.1f dB\n", srslte_rf_get_tx_gain(&radio));
printf("Set TX freq: %.2f MHz\n", srslte_rf_set_tx_freq(&radio, cell.nof_ports, rf_freq) / 1000000); printf("Set TX freq: %.2f MHz\n", srslte_rf_set_tx_freq(&radio, cell.nof_ports, rf_freq) / 1000000);
} }
#endif #endif

@ -258,9 +258,11 @@ int main(int argc, char** argv)
exit(-1); exit(-1);
} }
srslte_rf_set_rx_gain(&radio, prog_args.rf_gain);
printf("Set RX freq: %.6f MHz\n", printf("Set RX freq: %.6f MHz\n",
srslte_rf_set_rx_freq(&radio, prog_args.nof_rx_antennas, prog_args.rf_freq) / 1e6); srslte_rf_set_rx_freq(&radio, prog_args.nof_rx_antennas, prog_args.rf_freq) / 1e6);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&radio, prog_args.rf_gain)); printf("Set RX gain: %.1f dB\n", prog_args.rf_gain);
int srate = srslte_sampling_freq_hz(cell_sl.nof_prb); int srate = srslte_sampling_freq_hz(cell_sl.nof_prb);
if (srate != -1) { if (srate != -1) {

@ -133,8 +133,10 @@ int main(int argc, char** argv)
sigaddset(&sigset, SIGINT); sigaddset(&sigset, SIGINT);
sigprocmask(SIG_UNBLOCK, &sigset, NULL); sigprocmask(SIG_UNBLOCK, &sigset, NULL);
printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, nof_rx_antennas, rf_freq) / 1000000); srslte_rf_set_rx_gain(&rf, rf_gain);
printf("Set RX gain: %.2f dB\n", srslte_rf_set_rx_gain(&rf, rf_gain)); srslte_rf_set_rx_freq(&rf, nof_rx_antennas, rf_freq);
printf("Set RX freq: %.2f MHz\n", rf_freq / 1000000);
printf("Set RX gain: %.2f dB\n", rf_gain);
float srate = srslte_rf_set_rx_srate(&rf, rf_rate); float srate = srslte_rf_set_rx_srate(&rf, rf_rate);
if (srate != rf_rate) { if (srate != rf_rate) {
srate = srslte_rf_set_rx_srate(&rf, rf_rate); srate = srslte_rf_set_rx_srate(&rf, rf_rate);

@ -161,8 +161,9 @@ int main(int argc, char** argv)
sigaddset(&sigset, SIGINT); sigaddset(&sigset, SIGINT);
sigprocmask(SIG_UNBLOCK, &sigset, NULL); sigprocmask(SIG_UNBLOCK, &sigset, NULL);
srslte_rf_set_rx_gain(&rf, rf_gain);
printf("Set RX freq: %.6f MHz\n", srslte_rf_set_rx_freq(&rf, nof_rx_antennas, rf_freq) / 1000000); printf("Set RX freq: %.6f MHz\n", srslte_rf_set_rx_freq(&rf, nof_rx_antennas, rf_freq) / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, rf_gain)); printf("Set RX gain: %.1f dB\n", srslte_rf_get_rx_gain(&rf));
int srate = srslte_sampling_freq_hz(nof_prb); int srate = srslte_sampling_freq_hz(nof_prb);
if (srate != -1) { if (srate != -1) {
printf("Setting sampling rate %.2f MHz\n", (float)srate / 1000000); printf("Setting sampling rate %.2f MHz\n", (float)srate / 1000000);

@ -117,8 +117,9 @@ int main(int argc, char** argv)
sigaddset(&sigset, SIGINT); sigaddset(&sigset, SIGINT);
sigprocmask(SIG_UNBLOCK, &sigset, NULL); sigprocmask(SIG_UNBLOCK, &sigset, NULL);
srslte_rf_set_rx_gain(&rf, rf_gain);
printf("Set RX freq: %.6f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000); printf("Set RX freq: %.6f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, rf_gain)); printf("Set RX gain: %.1f dB\n", srslte_rf_get_rx_gain(&rf));
int srate = srslte_sampling_freq_hz(nof_prb); int srate = srslte_sampling_freq_hz(nof_prb);
if (srate != -1) { if (srate != -1) {
printf("Setting sampling rate %.2f MHz\n", (float)srate / 1e6); printf("Setting sampling rate %.2f MHz\n", (float)srate / 1e6);

@ -145,12 +145,16 @@ int main(int argc, char** argv)
srslte_rf_set_rx_srate(&rf, (double)srate); srslte_rf_set_rx_srate(&rf, (double)srate);
srslte_rf_set_tx_srate(&rf, (double)srate); srslte_rf_set_tx_srate(&rf, (double)srate);
srslte_rf_set_rx_gain(&rf, rf_rx_gain);
srslte_rf_set_tx_gain(&rf, srslte_rf_tx_gain);
srslte_rf_set_rx_freq(&rf, 0, rf_freq);
printf("Subframe len: %d samples\n", flen); printf("Subframe len: %d samples\n", flen);
printf("Time advance: %f us\n", time_adv_sec * 1e6); printf("Time advance: %f us\n", time_adv_sec * 1e6);
printf("Set TX/RX rate: %.2f MHz\n", (float)srate / 1000000); printf("Set TX/RX rate: %.2f MHz\n", (float)srate / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, rf_rx_gain)); printf("Set RX gain: %.1f dB\n", rf_rx_gain);
printf("Set TX gain: %.1f dB\n", srslte_rf_set_tx_gain(&rf, srslte_rf_tx_gain)); printf("Set TX gain: %.1f dB\n", srslte_rf_tx_gain);
printf("Set TX/RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000); printf("Set TX/RX freq: %.2f MHz\n", rf_freq / 1000000);
srslte_rf_set_tx_freq(&rf, 0, rf_freq); srslte_rf_set_tx_freq(&rf, 0, rf_freq);
sleep(1); sleep(1);

@ -169,9 +169,11 @@ static int init_radio(uint32_t* buffer_len)
ERROR("Error opening rf\n"); ERROR("Error opening rf\n");
return -1; return -1;
} }
srslte_rf_set_rx_gain(&radio, rf_gain);
srslte_rf_set_rx_freq(&radio, nof_rx_antennas, rf_freq);
printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&radio, nof_rx_antennas, rf_freq) / 1000000); printf("Set RX freq: %.2f MHz\n", rf_freq / 1000000);
printf("Set RX gain: %.2f dB\n", srslte_rf_set_rx_gain(&radio, rf_gain)); printf("Set RX gain: %.2f dB\n", rf_gain);
float srate = srslte_rf_set_rx_srate(&radio, rf_rate); float srate = srslte_rf_set_rx_srate(&radio, rf_rate);
if (srate != rf_rate) { if (srate != rf_rate) {
ERROR("Error setting samplign frequency %.2f MHz\n", rf_rate * 1e-6); ERROR("Error setting samplign frequency %.2f MHz\n", rf_rate * 1e-6);

@ -49,6 +49,7 @@ typedef struct {
float freq_offset; float freq_offset;
float rx_gain; float rx_gain;
float tx_gain; float tx_gain;
float tx_gain_ch[SRSLTE_MAX_CARRIERS];
float tx_max_power; float tx_max_power;
float tx_gain_offset; float tx_gain_offset;
float rx_gain_offset; float rx_gain_offset;

@ -95,11 +95,13 @@ SRSLTE_API float srslte_rf_get_rssi(srslte_rf_t* h);
SRSLTE_API double srslte_rf_set_rx_srate(srslte_rf_t* h, double freq); SRSLTE_API double srslte_rf_set_rx_srate(srslte_rf_t* h, double freq);
SRSLTE_API double srslte_rf_set_rx_gain(srslte_rf_t* h, double gain); SRSLTE_API int srslte_rf_set_rx_gain(srslte_rf_t* h, double gain);
SRSLTE_API int srslte_rf_set_rx_gain_ch(srslte_rf_t* h, uint32_t ch, double gain);
SRSLTE_API void srslte_rf_set_tx_rx_gain_offset(srslte_rf_t* h, double offset); SRSLTE_API void srslte_rf_set_tx_rx_gain_offset(srslte_rf_t* h, double offset);
SRSLTE_API double srslte_rf_set_rx_gain_th(srslte_rf_t* h, double gain); SRSLTE_API int srslte_rf_set_rx_gain_th(srslte_rf_t* h, double gain);
SRSLTE_API double srslte_rf_get_rx_gain(srslte_rf_t* h); SRSLTE_API double srslte_rf_get_rx_gain(srslte_rf_t* h);
@ -127,7 +129,9 @@ SRSLTE_API int srslte_rf_recv_with_time_multi(srslte_rf_t* h,
SRSLTE_API double srslte_rf_set_tx_srate(srslte_rf_t* h, double freq); SRSLTE_API double srslte_rf_set_tx_srate(srslte_rf_t* h, double freq);
SRSLTE_API double srslte_rf_set_tx_gain(srslte_rf_t* h, double gain); SRSLTE_API int srslte_rf_set_tx_gain(srslte_rf_t* h, double gain);
SRSLTE_API int srslte_rf_set_tx_gain_ch(srslte_rf_t* h, uint32_t ch, double gain);
SRSLTE_API double srslte_rf_set_tx_freq(srslte_rf_t* h, uint32_t ch, double freq); SRSLTE_API double srslte_rf_set_tx_freq(srslte_rf_t* h, uint32_t ch, double freq);

@ -282,28 +282,38 @@ double rf_blade_set_tx_srate(void* h, double freq)
return (double)handler->tx_rate; return (double)handler->tx_rate;
} }
double rf_blade_set_rx_gain(void* h, double gain) int rf_blade_set_rx_gain(void* h, double gain)
{ {
int status; int status;
rf_blade_handler_t* handler = (rf_blade_handler_t*)h; rf_blade_handler_t* handler = (rf_blade_handler_t*)h;
status = bladerf_set_gain(handler->dev, BLADERF_RX_X1, (bladerf_gain)gain); status = bladerf_set_gain(handler->dev, BLADERF_RX_X1, (bladerf_gain)gain);
if (status != 0) { if (status != 0) {
ERROR("Failed to set RX gain: %s\n", bladerf_strerror(status)); ERROR("Failed to set RX gain: %s\n", bladerf_strerror(status));
return -1; return SRSLTE_ERROR;
}
return SRSLTE_SUCCESS;
} }
return rf_blade_get_rx_gain(h);
int rf_blade_set_rx_gain_ch(void* h, uint32_t ch, double gain)
{
return rf_blade_set_rx_gain(h, gain);
} }
double rf_blade_set_tx_gain(void* h, double gain) int rf_blade_set_tx_gain(void* h, double gain)
{ {
int status; int status;
rf_blade_handler_t* handler = (rf_blade_handler_t*)h; rf_blade_handler_t* handler = (rf_blade_handler_t*)h;
status = bladerf_set_gain(handler->dev, BLADERF_TX_X1, (bladerf_gain)gain); status = bladerf_set_gain(handler->dev, BLADERF_TX_X1, (bladerf_gain)gain);
if (status != 0) { if (status != 0) {
ERROR("Failed to set TX gain: %s\n", bladerf_strerror(status)); ERROR("Failed to set TX gain: %s\n", bladerf_strerror(status));
return -1; return SRSLTE_ERROR;
}
return SRSLTE_SUCCESS;
} }
return rf_blade_get_tx_gain(h);
int rf_blade_set_tx_gain_ch(void* h, uint32_t ch, double gain)
{
return rf_blade_set_tx_gain(h, gain);
} }
double rf_blade_get_rx_gain(void* h) double rf_blade_get_rx_gain(void* h)

@ -46,7 +46,9 @@ SRSLTE_API float rf_blade_get_rssi(void* h);
SRSLTE_API double rf_blade_set_rx_srate(void* h, double freq); SRSLTE_API double rf_blade_set_rx_srate(void* h, double freq);
SRSLTE_API double rf_blade_set_rx_gain(void* h, double gain); SRSLTE_API int rf_blade_set_rx_gain(void* h, double gain);
SRSLTE_API int rf_blade_set_rx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API float rf_blade_get_rx_gain_offset(void* h); SRSLTE_API float rf_blade_get_rx_gain_offset(void* h);
@ -70,7 +72,9 @@ rf_blade_recv_with_time(void* h, void* data, uint32_t nsamples, bool blocking, t
SRSLTE_API double rf_blade_set_tx_srate(void* h, double freq); SRSLTE_API double rf_blade_set_tx_srate(void* h, double freq);
SRSLTE_API double rf_blade_set_tx_gain(void* h, double gain); SRSLTE_API int rf_blade_set_tx_gain(void* h, double gain);
SRSLTE_API int rf_blade_set_tx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API double rf_blade_set_tx_freq(void* h, uint32_t ch, double freq); SRSLTE_API double rf_blade_set_tx_freq(void* h, uint32_t ch, double freq);

@ -37,8 +37,10 @@ typedef struct {
int (*srslte_rf_open_multi)(char* args, void** h, uint32_t nof_channels); int (*srslte_rf_open_multi)(char* args, void** h, uint32_t nof_channels);
int (*srslte_rf_close)(void* h); int (*srslte_rf_close)(void* h);
double (*srslte_rf_set_rx_srate)(void* h, double freq); double (*srslte_rf_set_rx_srate)(void* h, double freq);
double (*srslte_rf_set_rx_gain)(void* h, double gain); int (*srslte_rf_set_rx_gain)(void* h, double gain);
double (*srslte_rf_set_tx_gain)(void* h, double gain); int (*srslte_rf_set_rx_gain_ch)(void* h, uint32_t ch, double gain);
int (*srslte_rf_set_tx_gain)(void* h, double gain);
int (*srslte_rf_set_tx_gain_ch)(void* h, uint32_t ch, double gain);
double (*srslte_rf_get_rx_gain)(void* h); double (*srslte_rf_get_rx_gain)(void* h);
double (*srslte_rf_get_tx_gain)(void* h); double (*srslte_rf_get_tx_gain)(void* h);
srslte_rf_info_t* (*srslte_rf_get_info)(void* h); srslte_rf_info_t* (*srslte_rf_get_info)(void* h);
@ -98,7 +100,9 @@ static rf_dev_t dev_uhd = {"UHD",
rf_uhd_close, rf_uhd_close,
rf_uhd_set_rx_srate, rf_uhd_set_rx_srate,
rf_uhd_set_rx_gain, rf_uhd_set_rx_gain,
rf_uhd_set_rx_gain_ch,
rf_uhd_set_tx_gain, rf_uhd_set_tx_gain,
rf_uhd_set_tx_gain_ch,
rf_uhd_get_rx_gain, rf_uhd_get_rx_gain,
rf_uhd_get_tx_gain, rf_uhd_get_tx_gain,
rf_uhd_get_info, rf_uhd_get_info,
@ -132,7 +136,9 @@ static rf_dev_t dev_blade = {"bladeRF",
rf_blade_close, rf_blade_close,
rf_blade_set_rx_srate, rf_blade_set_rx_srate,
rf_blade_set_rx_gain, rf_blade_set_rx_gain,
rf_blade_set_rx_gain_ch,
rf_blade_set_tx_gain, rf_blade_set_tx_gain,
rf_blade_set_tx_gain_ch,
rf_blade_get_rx_gain, rf_blade_get_rx_gain,
rf_blade_get_tx_gain, rf_blade_get_tx_gain,
rf_blade_get_info, rf_blade_get_info,
@ -165,7 +171,9 @@ static rf_dev_t dev_soapy = {"soapy",
rf_soapy_close, rf_soapy_close,
rf_soapy_set_rx_srate, rf_soapy_set_rx_srate,
rf_soapy_set_rx_gain, rf_soapy_set_rx_gain,
rf_soapy_set_rx_gain_ch,
rf_soapy_set_tx_gain, rf_soapy_set_tx_gain,
rf_soapy_set_tx_gain_ch,
rf_soapy_get_rx_gain, rf_soapy_get_rx_gain,
rf_soapy_get_tx_gain, rf_soapy_get_tx_gain,
rf_soapy_get_info, rf_soapy_get_info,
@ -200,7 +208,9 @@ static rf_dev_t dev_zmq = {"zmq",
rf_zmq_close, rf_zmq_close,
rf_zmq_set_rx_srate, rf_zmq_set_rx_srate,
rf_zmq_set_rx_gain, rf_zmq_set_rx_gain,
rf_zmq_set_rx_gain_ch,
rf_zmq_set_tx_gain, rf_zmq_set_tx_gain,
rf_zmq_set_tx_gain_ch,
rf_zmq_get_rx_gain, rf_zmq_get_rx_gain,
rf_zmq_get_tx_gain, rf_zmq_get_tx_gain,
rf_zmq_get_info, rf_zmq_get_info,
@ -225,10 +235,10 @@ int dummy_rcv()
} }
void dummy_fnc() {} void dummy_fnc() {}
static rf_dev_t dev_dummy = {"dummy", dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, static rf_dev_t dev_dummy = {"dummy", dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc,
dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc,
dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_rcv,
dummy_fnc, dummy_fnc, dummy_rcv, dummy_fnc, dummy_fnc, dummy_fnc}; dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc, dummy_fnc};
#endif #endif
static rf_dev_t* available_devices[] = { static rf_dev_t* available_devices[] = {

@ -35,7 +35,7 @@ int rf_get_available_devices(char** devnames, int max_strlen)
return i; return i;
} }
double srslte_rf_set_rx_gain_th(srslte_rf_t* rf, double gain) int srslte_rf_set_rx_gain_th(srslte_rf_t* rf, double gain)
{ {
if (gain > rf->cur_rx_gain + 2 || gain < rf->cur_rx_gain - 2) { if (gain > rf->cur_rx_gain + 2 || gain < rf->cur_rx_gain - 2) {
pthread_mutex_lock(&rf->mutex); pthread_mutex_lock(&rf->mutex);
@ -43,7 +43,7 @@ double srslte_rf_set_rx_gain_th(srslte_rf_t* rf, double gain)
pthread_cond_signal(&rf->cond); pthread_cond_signal(&rf->cond);
pthread_mutex_unlock(&rf->mutex); pthread_mutex_unlock(&rf->mutex);
} }
return rf->cur_rx_gain; return SRSLTE_SUCCESS;
} }
void srslte_rf_set_tx_rx_gain_offset(srslte_rf_t* rf, double offset) void srslte_rf_set_tx_rx_gain_offset(srslte_rf_t* rf, double offset)
@ -67,7 +67,6 @@ static void* thread_gain_fcn(void* h)
rf->new_rx_gain = rf->cur_rx_gain; rf->new_rx_gain = rf->cur_rx_gain;
} }
if (rf->tx_gain_same_rx) { if (rf->tx_gain_same_rx) {
printf("setting also tx\n");
srslte_rf_set_tx_gain(h, rf->cur_rx_gain + rf->tx_rx_gain_offset); srslte_rf_set_tx_gain(h, rf->cur_rx_gain + rf->tx_rx_gain_offset);
} }
pthread_mutex_unlock(&rf->mutex); pthread_mutex_unlock(&rf->mutex);
@ -197,11 +196,16 @@ double srslte_rf_set_rx_srate(srslte_rf_t* rf, double freq)
return ((rf_dev_t*)rf->dev)->srslte_rf_set_rx_srate(rf->handler, freq); return ((rf_dev_t*)rf->dev)->srslte_rf_set_rx_srate(rf->handler, freq);
} }
double srslte_rf_set_rx_gain(srslte_rf_t* rf, double gain) int srslte_rf_set_rx_gain(srslte_rf_t* rf, double gain)
{ {
return ((rf_dev_t*)rf->dev)->srslte_rf_set_rx_gain(rf->handler, gain); return ((rf_dev_t*)rf->dev)->srslte_rf_set_rx_gain(rf->handler, gain);
} }
int srslte_rf_set_rx_gain_ch(srslte_rf_t* rf, uint32_t ch, double gain)
{
return ((rf_dev_t*)rf->dev)->srslte_rf_set_rx_gain_ch(rf->handler, ch, gain);
}
double srslte_rf_get_rx_gain(srslte_rf_t* rf) double srslte_rf_get_rx_gain(srslte_rf_t* rf)
{ {
return ((rf_dev_t*)rf->dev)->srslte_rf_get_rx_gain(rf->handler); return ((rf_dev_t*)rf->dev)->srslte_rf_get_rx_gain(rf->handler);
@ -256,11 +260,16 @@ int srslte_rf_recv_with_time_multi(srslte_rf_t* rf,
return ((rf_dev_t*)rf->dev)->srslte_rf_recv_with_time_multi(rf->handler, data, nsamples, blocking, secs, frac_secs); return ((rf_dev_t*)rf->dev)->srslte_rf_recv_with_time_multi(rf->handler, data, nsamples, blocking, secs, frac_secs);
} }
double srslte_rf_set_tx_gain(srslte_rf_t* rf, double gain) int srslte_rf_set_tx_gain(srslte_rf_t* rf, double gain)
{ {
return ((rf_dev_t*)rf->dev)->srslte_rf_set_tx_gain(rf->handler, gain); return ((rf_dev_t*)rf->dev)->srslte_rf_set_tx_gain(rf->handler, gain);
} }
int srslte_rf_set_tx_gain_ch(srslte_rf_t* rf, uint32_t ch, double gain)
{
return ((rf_dev_t*)rf->dev)->srslte_rf_set_tx_gain_ch(rf->handler, ch, gain);
}
double srslte_rf_set_tx_srate(srslte_rf_t* rf, double freq) double srslte_rf_set_tx_srate(srslte_rf_t* rf, double freq)
{ {
return ((rf_dev_t*)rf->dev)->srslte_rf_set_tx_srate(rf->handler, freq); return ((rf_dev_t*)rf->dev)->srslte_rf_set_tx_srate(rf->handler, freq);

@ -694,29 +694,46 @@ double rf_soapy_set_tx_srate(void* h, double rate)
return handler->tx_rate; return handler->tx_rate;
} }
double rf_soapy_set_rx_gain(void* h, double gain) int rf_soapy_set_rx_gain(void* h, double gain)
{ {
rf_soapy_handler_t* handler = (rf_soapy_handler_t*)h; rf_soapy_handler_t* handler = (rf_soapy_handler_t*)h;
for (uint32_t i = 0; i < handler->num_rx_channels; i++) { for (uint32_t i = 0; i < handler->num_rx_channels; i++) {
if (SoapySDRDevice_setGain(handler->device, SOAPY_SDR_RX, i, gain) != 0) { if (rf_soapy_set_rx_gain_ch(h, i, gain) < 0) {
printf("setGain fail: %s\n", SoapySDRDevice_lastError());
return SRSLTE_ERROR; return SRSLTE_ERROR;
} }
} }
return rf_soapy_get_rx_gain(h); return SRSLTE_SUCCESS;
} }
double rf_soapy_set_tx_gain(void* h, double gain) int rf_soapy_set_rx_gain_ch(void* h, uint32_t ch, double gain)
{ {
rf_soapy_handler_t* handler = (rf_soapy_handler_t*)h; rf_soapy_handler_t* handler = (rf_soapy_handler_t*)h;
for (uint32_t i = 0; i < handler->num_tx_channels; i++) { if (SoapySDRDevice_setGain(handler->device, SOAPY_SDR_RX, ch, gain) != 0) {
if (SoapySDRDevice_setGain(handler->device, SOAPY_SDR_TX, i, gain) != 0) {
printf("setGain fail: %s\n", SoapySDRDevice_lastError()); printf("setGain fail: %s\n", SoapySDRDevice_lastError());
return SRSLTE_ERROR; return SRSLTE_ERROR;
} }
return SRSLTE_SUCCESS;
}
int rf_soapy_set_tx_gain(void* h, double gain)
{
rf_soapy_handler_t* handler = (rf_soapy_handler_t*)h;
for (uint32_t i = 0; i < handler->num_tx_channels; i++) {
if (rf_soapy_set_tx_gain_ch(h, i, gain) < 0) {
return SRSLTE_ERROR;
} }
return rf_soapy_get_tx_gain(h); }
return SRSLTE_SUCCESS;
}
int rf_soapy_set_tx_gain_ch(void* h, uint32_t ch, double gain)
{
rf_soapy_handler_t* handler = (rf_soapy_handler_t*)h;
if (SoapySDRDevice_setGain(handler->device, SOAPY_SDR_TX, ch, gain) != 0) {
printf("setGain fail: %s\n", SoapySDRDevice_lastError());
return SRSLTE_ERROR;
}
return SRSLTE_SUCCESS;
} }
// Return gain of first channel // Return gain of first channel

@ -54,11 +54,15 @@ SRSLTE_API void rf_soapy_set_master_clock_rate(void* h, double rate);
SRSLTE_API double rf_soapy_set_rx_srate(void* h, double freq); SRSLTE_API double rf_soapy_set_rx_srate(void* h, double freq);
SRSLTE_API double rf_soapy_set_rx_gain(void* h, double gain); SRSLTE_API int rf_soapy_set_rx_gain(void* h, double gain);
SRSLTE_API int rf_soapy_set_rx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API double rf_soapy_get_rx_gain(void* h); SRSLTE_API double rf_soapy_get_rx_gain(void* h);
SRSLTE_API double rf_soapy_set_tx_gain(void* h, double gain); SRSLTE_API int rf_soapy_set_tx_gain(void* h, double gain);
SRSLTE_API int rf_soapy_set_tx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API double rf_soapy_get_tx_gain(void* h); SRSLTE_API double rf_soapy_get_tx_gain(void* h);

@ -984,28 +984,48 @@ double rf_uhd_set_tx_srate(void* h, double freq)
return freq; return freq;
} }
double rf_uhd_set_rx_gain(void* h, double gain) int rf_uhd_set_rx_gain(void* h, double gain)
{ {
rf_uhd_handler_t* handler = (rf_uhd_handler_t*)h; rf_uhd_handler_t* handler = (rf_uhd_handler_t*)h;
for (size_t i = 0; i < handler->nof_rx_channels; i++) { for (size_t i = 0; i < handler->nof_rx_channels; i++) {
if (handler->uhd.set_rx_gain(i, gain) != UHD_ERROR_NONE) { if (rf_uhd_set_rx_gain_ch(h, i, gain)) {
print_usrp_error(handler); print_usrp_error(handler);
return SRSLTE_ERROR; return SRSLTE_ERROR;
} }
} }
return gain; return SRSLTE_SUCCESS;
}
int rf_uhd_set_rx_gain_ch(void* h, uint32_t ch, double gain)
{
rf_uhd_handler_t* handler = (rf_uhd_handler_t*)h;
if (handler->uhd.set_rx_gain(ch, gain) != UHD_ERROR_NONE) {
print_usrp_error(handler);
return SRSLTE_ERROR;
}
return SRSLTE_SUCCESS;
} }
double rf_uhd_set_tx_gain(void* h, double gain) int rf_uhd_set_tx_gain(void* h, double gain)
{ {
rf_uhd_handler_t* handler = (rf_uhd_handler_t*)h; rf_uhd_handler_t* handler = (rf_uhd_handler_t*)h;
for (size_t i = 0; i < handler->nof_tx_channels; i++) { for (size_t i = 0; i < handler->nof_tx_channels; i++) {
if (handler->uhd.set_tx_gain(i, gain) != UHD_ERROR_NONE) { if (rf_uhd_set_tx_gain_ch(h, i, gain)) {
print_usrp_error(handler); print_usrp_error(handler);
return SRSLTE_ERROR; return SRSLTE_ERROR;
} }
} }
return gain; return SRSLTE_SUCCESS;
}
int rf_uhd_set_tx_gain_ch(void* h, uint32_t ch, double gain)
{
rf_uhd_handler_t* handler = (rf_uhd_handler_t*)h;
if (handler->uhd.set_tx_gain(ch, gain) != UHD_ERROR_NONE) {
print_usrp_error(handler);
return SRSLTE_ERROR;
}
return SRSLTE_SUCCESS;
} }
double rf_uhd_get_rx_gain(void* h) double rf_uhd_get_rx_gain(void* h)

@ -58,7 +58,9 @@ SRSLTE_API float rf_uhd_get_rssi(void* h);
SRSLTE_API double rf_uhd_set_rx_srate(void* h, double freq); SRSLTE_API double rf_uhd_set_rx_srate(void* h, double freq);
SRSLTE_API double rf_uhd_set_rx_gain(void* h, double gain); SRSLTE_API int rf_uhd_set_rx_gain(void* h, double gain);
SRSLTE_API int rf_uhd_set_rx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API double rf_uhd_get_rx_gain(void* h); SRSLTE_API double rf_uhd_get_rx_gain(void* h);
@ -80,7 +82,9 @@ rf_uhd_recv_with_time_multi(void* h, void** data, uint32_t nsamples, bool blocki
SRSLTE_API double rf_uhd_set_tx_srate(void* h, double freq); SRSLTE_API double rf_uhd_set_tx_srate(void* h, double freq);
SRSLTE_API double rf_uhd_set_tx_gain(void* h, double gain); SRSLTE_API int rf_uhd_set_tx_gain(void* h, double gain);
SRSLTE_API int rf_uhd_set_tx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API double rf_uhd_set_tx_freq(void* h, uint32_t ch, double freq); SRSLTE_API double rf_uhd_set_tx_freq(void* h, uint32_t ch, double freq);

@ -452,20 +452,28 @@ double rf_zmq_set_tx_srate(void* h, double srate)
return ret; return ret;
} }
double rf_zmq_set_rx_gain(void* h, double gain) int rf_zmq_set_rx_gain(void* h, double gain)
{ {
double ret = 0.0;
if (h) { if (h) {
rf_zmq_handler_t* handler = (rf_zmq_handler_t*)h; rf_zmq_handler_t* handler = (rf_zmq_handler_t*)h;
handler->rx_gain = gain; handler->rx_gain = gain;
ret = gain;
} }
return ret; return SRSLTE_SUCCESS;
} }
double rf_zmq_set_tx_gain(void* h, double gain) int rf_zmq_set_rx_gain_ch(void* h, uint32_t ch, double gain)
{ {
return 0.0; return rf_zmq_set_rx_gain(h, gain);
}
int rf_zmq_set_tx_gain(void* h, double gain)
{
return SRSLTE_SUCCESS;
}
int rf_zmq_set_tx_gain_ch(void* h, uint32_t ch, double gain)
{
return rf_zmq_set_tx_gain(h, gain);
} }
double rf_zmq_get_rx_gain(void* h) double rf_zmq_get_rx_gain(void* h)

@ -52,7 +52,9 @@ SRSLTE_API float rf_zmq_get_rssi(void* h);
SRSLTE_API double rf_zmq_set_rx_srate(void* h, double freq); SRSLTE_API double rf_zmq_set_rx_srate(void* h, double freq);
SRSLTE_API double rf_zmq_set_rx_gain(void* h, double gain); SRSLTE_API int rf_zmq_set_rx_gain(void* h, double gain);
SRSLTE_API int rf_zmq_set_rx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API double rf_zmq_get_rx_gain(void* h); SRSLTE_API double rf_zmq_get_rx_gain(void* h);
@ -74,7 +76,9 @@ rf_zmq_recv_with_time_multi(void* h, void** data, uint32_t nsamples, bool blocki
SRSLTE_API double rf_zmq_set_tx_srate(void* h, double freq); SRSLTE_API double rf_zmq_set_tx_srate(void* h, double freq);
SRSLTE_API double rf_zmq_set_tx_gain(void* h, double gain); SRSLTE_API int rf_zmq_set_tx_gain(void* h, double gain);
SRSLTE_API int rf_zmq_set_tx_gain_ch(void* h, uint32_t ch, double gain);
SRSLTE_API double rf_zmq_set_tx_freq(void* h, uint32_t ch, double freq); SRSLTE_API double rf_zmq_set_tx_freq(void* h, uint32_t ch, double freq);

@ -177,8 +177,9 @@ int main(int argc, char** argv)
exit(-1); exit(-1);
} }
srslte_rf_set_rx_gain(&rf, rf_gain);
printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000); printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, rf_gain)); printf("Set RX gain: %.1f dB\n", srslte_rf_get_rx_gain(&rf));
printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000); printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000);
buffer = srslte_vec_cf_malloc(flen * 2); buffer = srslte_vec_cf_malloc(flen * 2);

@ -136,9 +136,9 @@ int main(int argc, char** argv)
fprintf(stderr, "Error opening rf\n"); fprintf(stderr, "Error opening rf\n");
exit(-1); exit(-1);
} }
srslte_rf_set_rx_gain(&rf, rf_gain);
printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000); printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, rf_gain)); printf("Set RX gain: %.1f dB\n", srslte_rf_get_rx_gain(&rf));
printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000); printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000);
buffer = srslte_vec_cf_malloc(input_len * 2); buffer = srslte_vec_cf_malloc(input_len * 2);

@ -159,9 +159,9 @@ int main(int argc, char** argv)
ERROR("Error opening rf\n"); ERROR("Error opening rf\n");
exit(-1); exit(-1);
} }
srslte_rf_set_rx_gain(&rf, rf_gain);
printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000); printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, rf_gain)); printf("Set RX gain: %.1f dB\n", srslte_rf_get_rx_gain(&rf));
printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000); printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000);
buffer = srslte_vec_cf_malloc(flen * 2); buffer = srslte_vec_cf_malloc(flen * 2);

@ -139,8 +139,9 @@ int main(int argc, char** argv)
exit(-1); exit(-1);
} }
srslte_rf_set_rx_gain(&rf_device, rf_gain);
printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf_device, srate) / 1000000); printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf_device, srate) / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf_device, rf_gain)); printf("Set RX gain: %.1f dB\n", srslte_rf_get_rx_gain(&rf_device));
printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf_device, 0, rf_freq) / 1000000); printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf_device, 0, rf_freq) / 1000000);
srslte_ue_mib_sync_nbiot_t mib_sync; srslte_ue_mib_sync_nbiot_t mib_sync;

@ -161,8 +161,9 @@ int main(int argc, char** argv)
exit(-1); exit(-1);
} }
srslte_rf_set_rx_gain(&rf, rf_gain);
printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000); printf("Set RX rate: %.2f MHz\n", srslte_rf_set_rx_srate(&rf, srate) / 1000000);
printf("Set RX gain: %.1f dB\n", srslte_rf_set_rx_gain(&rf, rf_gain)); printf("Set RX gain: %.1f dB\n", srslte_rf_get_rx_gain(&rf));
printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000); printf("Set RX freq: %.2f MHz\n", srslte_rf_set_rx_freq(&rf, 0, rf_freq) / 1000000);
// Allocate memory for rx'ing samples (1 full frame) // Allocate memory for rx'ing samples (1 full frame)

@ -139,6 +139,7 @@ int radio::init(const rf_args_t& args, phy_interface_radio* phy_)
} else { } else {
set_rx_gain(args.rx_gain); set_rx_gain(args.rx_gain);
} }
// Set gain for all channels
if (args.tx_gain > 0) { if (args.tx_gain > 0) {
set_tx_gain(args.tx_gain); set_tx_gain(args.tx_gain);
} else { } else {
@ -147,6 +148,26 @@ int radio::init(const rf_args_t& args, phy_interface_radio* phy_)
log_h->console("\nWarning: TX gain was not set. Using open-loop power control (not working properly)\n\n"); log_h->console("\nWarning: TX gain was not set. Using open-loop power control (not working properly)\n\n");
} }
// Set individual gains
for (uint32_t i = 0; i < args.nof_carriers; i++) {
if (args.tx_gain_ch[i] > 0) {
for (uint32_t j = 0; j < nof_antennas; i++) {
uint32_t phys_antenna_idx = i * nof_antennas + j;
// From channel number deduce RF device index and channel
uint32_t rf_device_idx = phys_antenna_idx / nof_channels_x_dev;
uint32_t rf_channel_idx = phys_antenna_idx % nof_channels_x_dev;
log_h->info(
"Setting individual tx_gain=%.1f on dev=%d ch=%d\n", args.tx_gain_ch[i], rf_device_idx, rf_channel_idx);
if (srslte_rf_set_tx_gain_ch(&rf_devices[rf_device_idx], rf_channel_idx, args.tx_gain_ch[i]) < 0) {
log_h->error(
"Setting channel tx_gain=%.1f on dev=%d ch=%d\n", args.tx_gain_ch[i], rf_device_idx, rf_channel_idx);
}
}
}
}
// Frequency offset // Frequency offset
freq_offset = args.freq_offset; freq_offset = args.freq_offset;

@ -78,7 +78,12 @@ static int parse_args(all_args_t* args, int argc, char* argv[])
("rf.dl_freq", bpo::value<float>(&args->phy.dl_freq)->default_value(-1), "Downlink Frequency (if positive overrides EARFCN)") ("rf.dl_freq", bpo::value<float>(&args->phy.dl_freq)->default_value(-1), "Downlink Frequency (if positive overrides EARFCN)")
("rf.ul_freq", bpo::value<float>(&args->phy.ul_freq)->default_value(-1), "Uplink Frequency (if positive overrides EARFCN)") ("rf.ul_freq", bpo::value<float>(&args->phy.ul_freq)->default_value(-1), "Uplink Frequency (if positive overrides EARFCN)")
("rf.rx_gain", bpo::value<float>(&args->rf.rx_gain)->default_value(-1), "Front-end receiver gain") ("rf.rx_gain", bpo::value<float>(&args->rf.rx_gain)->default_value(-1), "Front-end receiver gain")
("rf.tx_gain", bpo::value<float>(&args->rf.tx_gain)->default_value(-1), "Front-end transmitter gain") ("rf.tx_gain", bpo::value<float>(&args->rf.tx_gain)->default_value(-1), "Front-end transmitter gain (all channels)")
("rf.tx_gain[0]", bpo::value<float>(&args->rf.tx_gain_ch[0])->default_value(-1), "Front-end transmitter gain CH0")
("rf.tx_gain[1]", bpo::value<float>(&args->rf.tx_gain_ch[1])->default_value(-1), "Front-end transmitter gain CH1")
("rf.tx_gain[2]", bpo::value<float>(&args->rf.tx_gain_ch[2])->default_value(-1), "Front-end transmitter gain CH2")
("rf.tx_gain[3]", bpo::value<float>(&args->rf.tx_gain_ch[3])->default_value(-1), "Front-end transmitter gain CH3")
("rf.tx_gain[4]", bpo::value<float>(&args->rf.tx_gain_ch[4])->default_value(-1), "Front-end transmitter gain CH4")
("rf.nof_carriers", bpo::value<uint32_t>(&args->rf.nof_carriers)->default_value(1), "Number of carriers") ("rf.nof_carriers", bpo::value<uint32_t>(&args->rf.nof_carriers)->default_value(1), "Number of carriers")
("rf.nof_antennas", bpo::value<uint32_t>(&args->rf.nof_antennas)->default_value(1), "Number of antennas per carrier") ("rf.nof_antennas", bpo::value<uint32_t>(&args->rf.nof_antennas)->default_value(1), "Number of antennas per carrier")

Loading…
Cancel
Save