register rf error handler in radio benchmark

master
Andre Puschmann 7 years ago
parent d7e4797f3f
commit 9ef12859b0

@ -40,6 +40,11 @@ double duration = 0.01; /* in seconds, 10 ms by default */
cf_t *buffers[SRSLTE_MAX_PORTS];
bool tx_enable = false;
uint32_t num_lates = 0;
uint32_t num_overflows = 0;
uint32_t num_underflows = 0;
uint32_t num_other_error = 0;
void usage(char *prog) {
printf("Usage: %s [rpstvh]\n", prog);
@ -97,6 +102,29 @@ void sig_int_handler(int signo)
}
}
void rf_msg(srslte_rf_error_t error)
{
if (error.type == srslte_rf_error_t::SRSLTE_RF_ERROR_OVERFLOW) {
num_overflows++;
} else
if (error.type == srslte_rf_error_t::SRSLTE_RF_ERROR_UNDERFLOW) {
num_underflows++;
} else
if (error.type == srslte_rf_error_t::SRSLTE_RF_ERROR_LATE) {
num_lates++;
} else {
num_other_error++;
}
}
void print_rf_summary(void)
{
printf("#lates=%d\n", num_lates);
printf("#overflows=%d\n", num_overflows);
printf("#underflows=%d\n", num_underflows);
printf("#num_other_error=%d\n", num_other_error);
}
int main(int argc, char **argv)
{
int ret = SRSLTE_ERROR;
@ -137,6 +165,8 @@ int main(int argc, char **argv)
goto clean_exit;
}
radio_h->register_error_handler(rf_msg);
radio_h->set_rx_freq(freq);
/* Set radio */
@ -194,5 +224,7 @@ clean_exit:
printf("Ok!\n");
}
print_rf_summary();
return ret;
}

Loading…
Cancel
Save