2017-01-17 14:46:12 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 Inria
|
2017-10-24 15:57:24 +02:00
|
|
|
* 2017 Freie Universität Berlin
|
2018-04-03 00:36:14 +02:00
|
|
|
* 2018 Josua Arndt
|
2017-01-17 14:46:12 +01:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief xtimer_usleep test application
|
|
|
|
*
|
|
|
|
* @author Francisco Acosta <francisco.acosta@inria.fr>
|
2017-10-24 15:57:24 +02:00
|
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
2018-04-03 00:36:14 +02:00
|
|
|
* @author Josua Arndt <jarndt@ias.rwth-aachen.de>
|
2017-01-17 14:46:12 +01:00
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2017-10-24 15:57:24 +02:00
|
|
|
#include <inttypes.h>
|
2017-01-17 14:46:12 +01:00
|
|
|
#include <stdio.h>
|
2018-04-03 00:36:14 +02:00
|
|
|
#include <stdlib.h>
|
2017-01-17 14:46:12 +01:00
|
|
|
|
|
|
|
#include "xtimer.h"
|
|
|
|
#include "timex.h"
|
2019-08-12 16:42:21 +02:00
|
|
|
#include "test_utils/interactive_sync.h"
|
2017-01-17 14:46:12 +01:00
|
|
|
|
2017-10-24 15:57:24 +02:00
|
|
|
#define RUNS (5U)
|
2019-07-18 15:16:11 +02:00
|
|
|
#define SLEEP_TIMES_NUMOF ARRAY_SIZE(sleep_times)
|
2017-10-24 15:57:24 +02:00
|
|
|
|
2018-04-03 00:36:14 +02:00
|
|
|
static const uint32_t sleep_times[] = { 10000, 50000, 10234, 56780, 12122, 98765, 75000 };
|
|
|
|
|
|
|
|
#define ERROR_US 70
|
|
|
|
|
|
|
|
/*
|
|
|
|
* To use a pin to probe the sleep times enable the gpio module and define
|
|
|
|
* SLEEP_PORT and SLEEP_PIN in the makefile, the port information can be found
|
|
|
|
* in the enum in `cpu/include/periph_cpu.h`.
|
|
|
|
*
|
|
|
|
* FEATURES_REQUIRED += periph_gpio
|
|
|
|
* CFLAGS += -DSLEEP_PIN=7
|
|
|
|
* CFLAGS += -DSLEEP_PORT=PORT_F
|
|
|
|
* */
|
|
|
|
#ifdef SLEEP_PIN
|
|
|
|
#include "board.h"
|
|
|
|
#include "periph/gpio.h"
|
|
|
|
#endif
|
2017-01-17 14:46:12 +01:00
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2017-10-24 15:57:24 +02:00
|
|
|
uint32_t start_test, testtime;
|
|
|
|
|
2018-04-03 00:36:14 +02:00
|
|
|
#ifdef SLEEP_PIN
|
|
|
|
printf("Debug port 0x%02x pin %d\n", SLEEP_PORT, SLEEP_PIN);
|
|
|
|
gpio_t sleep_pin = GPIO_PIN(SLEEP_PORT, SLEEP_PIN);
|
|
|
|
gpio_init(sleep_pin, GPIO_OUT);
|
|
|
|
#endif
|
|
|
|
|
2017-10-24 15:57:24 +02:00
|
|
|
printf("Running test %u times with %u distinct sleep times\n", RUNS,
|
|
|
|
(unsigned)SLEEP_TIMES_NUMOF);
|
2019-08-12 16:42:21 +02:00
|
|
|
test_utils_interactive_sync();
|
2017-10-24 15:57:24 +02:00
|
|
|
start_test = xtimer_now_usec();
|
|
|
|
for (unsigned m = 0; m < RUNS; m++) {
|
|
|
|
for (unsigned n = 0;
|
2019-07-18 15:16:11 +02:00
|
|
|
n < ARRAY_SIZE(sleep_times);
|
2017-10-24 15:57:24 +02:00
|
|
|
n++) {
|
2018-04-03 00:36:14 +02:00
|
|
|
|
|
|
|
uint32_t start_sleep, diff;
|
|
|
|
int32_t err;
|
|
|
|
|
|
|
|
start_sleep = xtimer_now_usec();
|
|
|
|
|
|
|
|
#ifdef SLEEP_PIN
|
|
|
|
gpio_set(sleep_pin);
|
|
|
|
#endif
|
2017-10-24 15:57:24 +02:00
|
|
|
xtimer_usleep(sleep_times[n]);
|
2018-04-03 00:36:14 +02:00
|
|
|
#ifdef SLEEP_PIN
|
|
|
|
gpio_clear(sleep_pin);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
diff = xtimer_now_usec() - start_sleep;
|
|
|
|
|
|
|
|
err = diff - sleep_times[n];
|
|
|
|
|
|
|
|
printf("Slept for %" PRIu32 " us (expected: %" PRIu32 " us) "
|
|
|
|
"Offset: %" PRIi32 " us\n", diff, sleep_times[n], err);
|
2017-10-24 15:57:24 +02:00
|
|
|
}
|
2017-01-17 14:46:12 +01:00
|
|
|
}
|
2017-10-24 15:57:24 +02:00
|
|
|
testtime = xtimer_now_usec() - start_test;
|
|
|
|
printf("Test ran for %" PRIu32 " us\n", testtime);
|
2017-01-17 14:46:12 +01:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|