2014-02-03 23:03:13 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 INRIA
|
2014-09-07 06:09:35 +02:00
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
2014-02-03 23:03:13 +01:00
|
|
|
*
|
2014-07-31 19:45:27 +02: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.
|
2014-02-03 23:03:13 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Hwtimer test application
|
|
|
|
*
|
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
2014-09-07 06:09:35 +02:00
|
|
|
* @author Ludwig Ortmann <ludwig.ortmann@fu-berlin.de>
|
2014-02-03 23:03:13 +01:00
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2014-01-10 16:21:35 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "hwtimer.h"
|
2014-04-30 14:08:40 +02:00
|
|
|
#include "thread.h"
|
2014-01-10 16:21:35 +01:00
|
|
|
|
2014-02-22 13:28:21 +01:00
|
|
|
#define BASE_DELAY (1000UL * 1000UL)
|
2014-09-06 18:12:58 +02:00
|
|
|
#define DELTA_DELAY (10UL * 1000UL)
|
2014-02-22 13:28:21 +01:00
|
|
|
#define MSGLEN 12 // == strlen("callback %2i")
|
2014-03-26 15:13:23 +01:00
|
|
|
char msg[MSGLEN * HWTIMER_MAXTIMERS]; // == [callback 1\0callback 2\0...]
|
2014-02-22 13:28:21 +01:00
|
|
|
|
2014-01-25 11:29:35 +01:00
|
|
|
void callback(void *ptr)
|
2014-01-10 16:21:35 +01:00
|
|
|
{
|
2014-01-25 11:29:35 +01:00
|
|
|
puts((char *) ptr);
|
2014-01-10 16:21:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2014-02-10 15:28:55 +01:00
|
|
|
puts("hwtimer test application...");
|
2014-01-10 16:21:35 +01:00
|
|
|
|
2014-02-28 15:20:51 +01:00
|
|
|
puts("");
|
|
|
|
puts(" Timers should print \"callback x\" once when they run out.");
|
2014-03-26 15:13:23 +01:00
|
|
|
printf(" The order for x is 1, n-1, n-2, ..., 2 where n is the number of available hardware timers (%u on this platform).\n", HWTIMER_MAXTIMERS);
|
2014-09-06 18:12:58 +02:00
|
|
|
puts(" In 1 second, one timer should fire every second/100 until all timers have run out.");
|
2014-02-28 15:20:51 +01:00
|
|
|
puts(" Additionally the message \"hwtimer set.\" should be printed once 1 second from now.");
|
|
|
|
puts("");
|
|
|
|
puts("Setting timers:");
|
|
|
|
puts("");
|
|
|
|
|
2014-03-26 15:13:23 +01:00
|
|
|
unsigned long delay = BASE_DELAY + ((HWTIMER_MAXTIMERS - 1) * DELTA_DELAY);
|
2014-01-10 16:21:35 +01:00
|
|
|
|
|
|
|
/* make the first timer first to fire so timers do not run out linearly */
|
|
|
|
char *msgn = msg;
|
|
|
|
snprintf(msgn, MSGLEN, "callback %2x", 1);
|
2014-01-25 11:29:35 +01:00
|
|
|
hwtimer_set(HWTIMER_TICKS(BASE_DELAY), callback, (void *) msgn);
|
2014-01-10 16:21:35 +01:00
|
|
|
printf("set %s\n", msgn);
|
|
|
|
|
2014-03-26 15:13:23 +01:00
|
|
|
/* set up to HWTIMER_MAXTIMERS-1 because hwtimer_wait below also
|
2014-01-10 16:21:35 +01:00
|
|
|
* needs a timer */
|
2014-03-26 15:13:23 +01:00
|
|
|
for (int i = 1; i < (HWTIMER_MAXTIMERS - 1); i++) {
|
2014-01-25 11:29:35 +01:00
|
|
|
msgn = msg + (i * MSGLEN);
|
2014-01-10 16:21:35 +01:00
|
|
|
delay -= DELTA_DELAY;
|
2014-01-25 11:29:35 +01:00
|
|
|
snprintf(msgn, MSGLEN, "callback %2x", i + 1);
|
|
|
|
hwtimer_set(HWTIMER_TICKS(delay), callback, (void *) msgn);
|
2014-01-10 16:21:35 +01:00
|
|
|
printf("set %s\n", msgn);
|
|
|
|
}
|
|
|
|
|
2014-02-28 15:20:51 +01:00
|
|
|
puts("");
|
|
|
|
puts("All timers set.");
|
|
|
|
puts("");
|
|
|
|
|
2014-09-06 18:12:58 +02:00
|
|
|
hwtimer_wait(HWTIMER_TICKS(BASE_DELAY));
|
2014-01-10 16:21:35 +01:00
|
|
|
|
|
|
|
puts("hwtimer set.");
|
2014-04-30 14:08:40 +02:00
|
|
|
thread_sleep();
|
2014-02-28 15:20:51 +01:00
|
|
|
return 0;
|
2014-01-10 16:21:35 +01:00
|
|
|
}
|