|
|
@ -34,9 +34,9 @@ extern "C" {
|
|
|
|
|
|
|
|
|
|
|
|
namespace srslte {
|
|
|
|
namespace srslte {
|
|
|
|
|
|
|
|
|
|
|
|
bool radio::init(char *args, char *devname)
|
|
|
|
bool radio::init(char *args, char *devname, uint32_t nof_channels)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (srslte_rf_open_devname(&rf_device, devname, args)) {
|
|
|
|
if (srslte_rf_open_devname(&rf_device, devname, args, nof_channels)) {
|
|
|
|
fprintf(stderr, "Error opening RF device\n");
|
|
|
|
fprintf(stderr, "Error opening RF device\n");
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -68,6 +68,7 @@ bool radio::init(char *args, char *devname)
|
|
|
|
if (devname) {
|
|
|
|
if (devname) {
|
|
|
|
strncpy(saved_devname, devname, 128);
|
|
|
|
strncpy(saved_devname, devname, 128);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
saved_nof_channels = nof_channels;
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -82,7 +83,7 @@ void radio::reset()
|
|
|
|
printf("Resetting Radio...\n");
|
|
|
|
printf("Resetting Radio...\n");
|
|
|
|
srslte_rf_close(&rf_device);
|
|
|
|
srslte_rf_close(&rf_device);
|
|
|
|
sleep(3);
|
|
|
|
sleep(3);
|
|
|
|
if (srslte_rf_open_devname(&rf_device, saved_devname, saved_args)) {
|
|
|
|
if (srslte_rf_open_devname(&rf_device, saved_devname, saved_args, saved_nof_channels)) {
|
|
|
|
fprintf(stderr, "Error opening RF device\n");
|
|
|
|
fprintf(stderr, "Error opening RF device\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -137,9 +138,9 @@ bool radio::rx_at(void* buffer, uint32_t nof_samples, srslte_timestamp_t rx_time
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool radio::rx_now(void* buffer, uint32_t nof_samples, srslte_timestamp_t* rxd_time)
|
|
|
|
bool radio::rx_now(void* buffer[SRSLTE_MAX_PORTS], uint32_t nof_samples, srslte_timestamp_t* rxd_time)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (srslte_rf_recv_with_time(&rf_device, buffer, nof_samples, true,
|
|
|
|
if (srslte_rf_recv_with_time_multi(&rf_device, buffer, nof_samples, true,
|
|
|
|
rxd_time?&rxd_time->full_secs:NULL, rxd_time?&rxd_time->frac_secs:NULL) > 0) {
|
|
|
|
rxd_time?&rxd_time->full_secs:NULL, rxd_time?&rxd_time->frac_secs:NULL) > 0) {
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
@ -186,10 +187,18 @@ bool radio::is_first_of_burst() {
|
|
|
|
|
|
|
|
|
|
|
|
#define BLOCKING_TX true
|
|
|
|
#define BLOCKING_TX true
|
|
|
|
|
|
|
|
|
|
|
|
bool radio::tx(void* buffer, uint32_t nof_samples, srslte_timestamp_t tx_time)
|
|
|
|
bool radio::tx_single(void *buffer, uint32_t nof_samples, srslte_timestamp_t tx_time) {
|
|
|
|
{
|
|
|
|
void *_buffer[SRSLTE_MAX_PORTS];
|
|
|
|
void *iq_samples[4] = {(void *) zeros, (void *) zeros, (void *) zeros, (void *) zeros};
|
|
|
|
|
|
|
|
|
|
|
|
_buffer[0] = buffer;
|
|
|
|
|
|
|
|
for (int p = 1; p < SRSLTE_MAX_PORTS; p++) {
|
|
|
|
|
|
|
|
_buffer[p] = zeros;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return this->tx(_buffer, nof_samples, tx_time);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool radio::tx(void *buffer[SRSLTE_MAX_PORTS], uint32_t nof_samples, srslte_timestamp_t tx_time) {
|
|
|
|
if (!tx_adv_negative) {
|
|
|
|
if (!tx_adv_negative) {
|
|
|
|
srslte_timestamp_sub(&tx_time, 0, tx_adv_sec);
|
|
|
|
srslte_timestamp_sub(&tx_time, 0, tx_adv_sec);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
@ -202,7 +211,7 @@ bool radio::tx(void* buffer, uint32_t nof_samples, srslte_timestamp_t tx_time)
|
|
|
|
srslte_timestamp_copy(&tx_time_pad, &tx_time);
|
|
|
|
srslte_timestamp_copy(&tx_time_pad, &tx_time);
|
|
|
|
srslte_timestamp_sub(&tx_time_pad, 0, burst_preamble_time_rounded);
|
|
|
|
srslte_timestamp_sub(&tx_time_pad, 0, burst_preamble_time_rounded);
|
|
|
|
save_trace(1, &tx_time_pad);
|
|
|
|
save_trace(1, &tx_time_pad);
|
|
|
|
srslte_rf_send_timed_multi(&rf_device, iq_samples, burst_preamble_samples, tx_time_pad.full_secs, tx_time_pad.frac_secs, true, true, false);
|
|
|
|
srslte_rf_send_timed_multi(&rf_device, buffer, burst_preamble_samples, tx_time_pad.full_secs, tx_time_pad.frac_secs, true, true, false);
|
|
|
|
is_start_of_burst = false;
|
|
|
|
is_start_of_burst = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -212,8 +221,7 @@ bool radio::tx(void* buffer, uint32_t nof_samples, srslte_timestamp_t tx_time)
|
|
|
|
srslte_timestamp_add(&end_of_burst_time, 0, (double) nof_samples/cur_tx_srate);
|
|
|
|
srslte_timestamp_add(&end_of_burst_time, 0, (double) nof_samples/cur_tx_srate);
|
|
|
|
|
|
|
|
|
|
|
|
save_trace(0, &tx_time);
|
|
|
|
save_trace(0, &tx_time);
|
|
|
|
iq_samples[0] = buffer;
|
|
|
|
int ret = srslte_rf_send_timed_multi(&rf_device, buffer, nof_samples,
|
|
|
|
int ret = srslte_rf_send_timed_multi(&rf_device, (void**) iq_samples, nof_samples,
|
|
|
|
|
|
|
|
tx_time.full_secs, tx_time.frac_secs,
|
|
|
|
tx_time.full_secs, tx_time.frac_secs,
|
|
|
|
BLOCKING_TX, is_start_of_burst, false);
|
|
|
|
BLOCKING_TX, is_start_of_burst, false);
|
|
|
|
is_start_of_burst = false;
|
|
|
|
is_start_of_burst = false;
|
|
|
|