/* * Copyright (C) 2015 Daniel Krebs * 2015 Kaspar Schleiser * 2017 HAW Hamburg * * 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 test application * * This test used to hang many boards. * * @author Daniel Krebs * @author Kaspar Schleiser * @author Sebastian Meiling * * @} */ #include #include "xtimer.h" #include "thread.h" #include "log.h" #if defined(MAIN_THREAD_PIN) || defined(WORKER_THREAD_PIN) #include "board.h" #include "periph/gpio.h" #endif #define TEST_TIME_S (10LU) #define TEST_INTERVAL_MS (100LU) #define TEST_TIMER_STACKSIZE (THREAD_STACKSIZE_DEFAULT) char stack_timer1[TEST_TIMER_STACKSIZE]; char stack_timer2[TEST_TIMER_STACKSIZE]; void* timer_func(void* arg) { #if defined(WORKER_THREAD_PIN) gpio_t worker_pin = WORKER_THREAD_PIN; gpio_init(worker_pin, GPIO_OUT); #endif LOG_DEBUG("run thread %" PRIkernel_pid "\n", thread_getpid()); while(1) { #if defined(WORKER_THREAD_PIN) gpio_set(worker_pin); gpio_clear(worker_pin); #endif xtimer_usleep(*(uint32_t *)(arg)); } } int main(void) { #if defined(MAIN_THREAD_PIN) gpio_t main_pin = MAIN_THREAD_PIN; gpio_init(main_pin, GPIO_OUT); #endif LOG_DEBUG("[INIT]\n"); uint32_t sleep_timer1 = 1000; uint32_t sleep_timer2 = 1100; thread_create(stack_timer1, TEST_TIMER_STACKSIZE, 2, THREAD_CREATE_STACKTEST, timer_func, &sleep_timer1, "timer1"); thread_create(stack_timer2, TEST_TIMER_STACKSIZE, 3, THREAD_CREATE_STACKTEST, timer_func, &sleep_timer2, "timer2"); uint32_t now = 0; uint32_t start = xtimer_now_usec(); uint32_t until = start + (TEST_TIME_S * US_PER_SEC); uint32_t interval = TEST_INTERVAL_MS * US_PER_MS; xtimer_ticks32_t last_wakeup = xtimer_now(); puts("[START]"); while((now = xtimer_now_usec()) < until) { unsigned percent = (100 * (now - start)) / (until - start); #if defined(MAIN_THREAD_PIN) gpio_set(main_pin); #endif xtimer_periodic_wakeup(&last_wakeup, interval); #if defined(MAIN_THREAD_PIN) gpio_clear(main_pin); #endif printf("Testing (%3u%%)\n", percent); } puts("Testing (100%)"); puts("[SUCCESS]"); return 0; }