benchmark_radio: fix duration and thread priority

I noticed that the app didn't configure the process with
RT thread prio. But it then turned out that in order to do
that we need to actually spawn a new thread. Also a few other things
didn't work out of the box.

In summary the changes are:
* fix duration to support more than 120s
* move main functionality in thread
* set high priority for radio thread
* only return success if no radio errors occured
master
Andre Puschmann 4 years ago
parent 3ea47b645a
commit 1b97ba5300

@ -19,6 +19,8 @@
* *
*/ */
#include <pthread.h>
#include <sys/mman.h>
#include <unistd.h> #include <unistd.h>
#ifdef __cplusplus #ifdef __cplusplus
@ -57,6 +59,8 @@ static bool capture = false;
static bool agc_enable = true; static bool agc_enable = true;
static float rf_gain = -1.0; static float rf_gain = -1.0;
static pthread_t radio_thread;
#ifdef ENABLE_GUI #ifdef ENABLE_GUI
#include "srsgui/srsgui.h" #include "srsgui/srsgui.h"
#include <semaphore.h> #include <semaphore.h>
@ -270,9 +274,10 @@ private:
uint32_t num_failures = 0; uint32_t num_failures = 0;
}; };
int main(int argc, char** argv) static int ret = SRSLTE_ERROR;
static void* radio_thread_run(void* arg)
{ {
int ret = SRSLTE_ERROR;
radio* radio_h[SRSLTE_MAX_RADIOS] = {nullptr}; radio* radio_h[SRSLTE_MAX_RADIOS] = {nullptr};
srslte::rf_timestamp_t ts_prev[SRSLTE_MAX_RADIOS], ts_rx[SRSLTE_MAX_RADIOS], ts_tx; srslte::rf_timestamp_t ts_prev[SRSLTE_MAX_RADIOS], ts_rx[SRSLTE_MAX_RADIOS], ts_tx;
uint32_t nof_gaps = 0; uint32_t nof_gaps = 0;
@ -288,11 +293,9 @@ int main(int argc, char** argv)
float delay_idx[SRSLTE_MAX_RADIOS] = {0}; float delay_idx[SRSLTE_MAX_RADIOS] = {0};
uint32_t delay_count = 0; uint32_t delay_count = 0;
/* Parse args */
parse_args(argc, argv);
double current_rate = srate; double current_rate = srate;
uint32_t nof_samples = (uint32_t)(duration * srate); uint64_t nof_samples = (uint64_t)(duration * srate);
uint32_t frame_size = (uint32_t)(srate / 1000.0); /* 1 ms at srate */ uint32_t frame_size = (uint32_t)(srate / 1000.0); /* 1 ms at srate */
uint32_t nof_frames = (uint32_t)ceil(nof_samples / frame_size); uint32_t nof_frames = (uint32_t)ceil(nof_samples / frame_size);
@ -327,6 +330,11 @@ int main(int argc, char** argv)
} }
#endif /* ENABLE_GUI */ #endif /* ENABLE_GUI */
// lock all memory to prevent swapping
if (mlockall(MCL_CURRENT | MCL_FUTURE) == -1) {
perror("mlockall");
}
/* Initialise instances */ /* Initialise instances */
printf("Initialising instances...\n"); printf("Initialising instances...\n");
for (uint32_t r = 0; r < nof_radios; r++) { for (uint32_t r = 0; r < nof_radios; r++) {
@ -388,8 +396,15 @@ int main(int argc, char** argv)
} }
} }
// setup thread priority
struct sched_param schedp;
memset(&schedp, 0, sizeof(schedp));
schedp.sched_priority = 90;
sched_setscheduler(0, SCHED_FIFO, &schedp);
/* Receive */ /* Receive */
printf("Start capturing %d frames of %d samples...\n", nof_frames, frame_size); printf(
"Start capturing %d sub-frames of %d samples (approx. %ds) ...\n", nof_frames, frame_size, (nof_frames / 1000));
for (int i = 0; i < SRSLTE_MAX_RADIOS; i++) { for (int i = 0; i < SRSLTE_MAX_RADIOS; i++) {
for (int j = 0; j < SRSLTE_MAX_PORTS; j++) { for (int j = 0; j < SRSLTE_MAX_PORTS; j++) {
@ -532,7 +547,9 @@ int main(int argc, char** argv)
rf_metrics.rf_o, rf_metrics.rf_o,
rf_metrics.rf_u); rf_metrics.rf_u);
ret = SRSLTE_SUCCESS; if (nof_gaps == 0 && rf_metrics.rf_l == 0 && rf_metrics.rf_o == 0 && rf_metrics.rf_u == 0) {
ret = SRSLTE_SUCCESS;
}
if (measure_delay && delay_count > 0) { if (measure_delay && delay_count > 0) {
for (uint32_t r = 1; r < nof_radios; r++) { for (uint32_t r = 1; r < nof_radios; r++) {
@ -587,5 +604,20 @@ clean_exit:
printf("Ok!\n"); printf("Ok!\n");
} }
return nullptr;
}
int main(int argc, char** argv)
{
// Parse args
parse_args(argc, argv);
if (pthread_create(&radio_thread, NULL, radio_thread_run, NULL)) {
perror("pthread_create");
exit(-1);
}
pthread_join(radio_thread, NULL);
return ret; return ret;
} }

Loading…
Cancel
Save