2014-08-22 00:42:04 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* 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 Test for low-level Real Time Timer drivers
|
|
|
|
*
|
|
|
|
* This test will initialize the real-time timer and trigger an alarm printing
|
2019-01-28 22:17:12 +01:00
|
|
|
* 'Hello' every 5 seconds
|
2014-08-22 00:42:04 +02:00
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
2018-04-11 17:33:44 +02:00
|
|
|
#include <inttypes.h>
|
2014-08-22 00:42:04 +02:00
|
|
|
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "periph_conf.h"
|
|
|
|
#include "periph/rtt.h"
|
|
|
|
|
2019-01-28 22:17:12 +01:00
|
|
|
#define TICKS_TO_WAIT (5 * RTT_FREQUENCY)
|
2014-08-22 00:42:04 +02:00
|
|
|
|
2017-04-03 18:17:13 +02:00
|
|
|
static volatile uint32_t last;
|
|
|
|
|
2020-11-11 16:55:33 +01:00
|
|
|
static const uint32_t _ticktest[] = { 1, 256, 65536, 16777216, 2147483648 };
|
|
|
|
|
2014-08-22 00:42:04 +02:00
|
|
|
void cb(void *arg)
|
|
|
|
{
|
|
|
|
(void)arg;
|
|
|
|
|
2017-04-03 18:17:13 +02:00
|
|
|
last += TICKS_TO_WAIT;
|
|
|
|
last &= RTT_MAX_VALUE;
|
|
|
|
rtt_set_alarm(last, cb, 0);
|
|
|
|
|
2014-08-22 00:42:04 +02:00
|
|
|
puts("Hello");
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("\nRIOT RTT low-level driver test");
|
2020-11-11 16:55:33 +01:00
|
|
|
|
|
|
|
puts("RTT configuration:");
|
|
|
|
printf("RTT_MAX_VALUE: 0x%08x\n", (unsigned)RTT_MAX_VALUE);
|
|
|
|
printf("RTT_FREQUENCY: %u\n\n", (unsigned)RTT_FREQUENCY);
|
|
|
|
|
|
|
|
puts("Testing the tick conversion");
|
|
|
|
for (unsigned i = 0; i < ARRAY_SIZE(_ticktest); i++) {
|
|
|
|
uint32_t sec = RTT_TICKS_TO_SEC(_ticktest[i]);
|
|
|
|
uint32_t ticks = RTT_SEC_TO_TICKS(sec);
|
|
|
|
printf("Trying to convert %" PRIu32 " to seconds and back\n",
|
|
|
|
_ticktest[i]);
|
|
|
|
/* account for rounding errors... */
|
|
|
|
if ((ticks != 0) && (ticks != _ticktest[i])) {
|
|
|
|
puts("error: TICK conversion not working as expected\n");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
puts("All ok\n");
|
2014-08-22 00:42:04 +02:00
|
|
|
|
|
|
|
puts("Initializing the RTT driver");
|
|
|
|
rtt_init();
|
|
|
|
|
2020-11-11 16:55:33 +01:00
|
|
|
puts("This test will now display 'Hello' every 5 seconds\n");
|
2018-04-11 17:33:44 +02:00
|
|
|
uint32_t now = rtt_get_counter();
|
|
|
|
printf("RTT now: %" PRIu32 "\n", now);
|
|
|
|
|
2021-03-03 17:08:30 +01:00
|
|
|
if (IS_USED(MODULE_PERIPH_RTT_SET_COUNTER)) {
|
|
|
|
puts("Setting RTT timer to 1337");
|
|
|
|
rtt_set_counter(1337);
|
|
|
|
now = rtt_get_counter();
|
|
|
|
printf("RTT now: %" PRIu32 "\n", now);
|
|
|
|
if ((now < 1337) || (now > 1337 + (1 * RTT_FREQUENCY + 999) / 1000)) {
|
|
|
|
puts("ERROR: rtt_set_counter() failed (off by more than 1 ms)");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
puts("rtt_set_counter() PASSED");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-11 17:33:44 +02:00
|
|
|
last = (now + TICKS_TO_WAIT) & RTT_MAX_VALUE;
|
2019-01-28 22:17:12 +01:00
|
|
|
printf("Setting initial alarm to now + 5 s (%" PRIu32 ")\n", last);
|
2018-04-11 17:33:44 +02:00
|
|
|
rtt_set_alarm(last, cb, 0);
|
2014-08-22 00:42:04 +02:00
|
|
|
|
2021-03-30 14:48:03 +02:00
|
|
|
uint32_t tmp = rtt_get_alarm();
|
|
|
|
if (tmp != last) {
|
|
|
|
printf("Error: rtt_get_alarm() not working (expected %" PRIu32 " but got %" PRIu32 ")\n",
|
|
|
|
last, tmp);
|
2021-03-03 17:08:30 +01:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
puts("rtt_get_alarm() PASSED");
|
|
|
|
}
|
|
|
|
|
2014-08-22 00:42:04 +02:00
|
|
|
puts("Done setting up the RTT, wait for many Hellos");
|
|
|
|
return 0;
|
|
|
|
}
|