1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/periph_rtt/main.c

109 lines
2.8 KiB
C
Raw Normal View History

/*
* 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
* 'Hello' every 5 seconds
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
*
* @}
*/
#include <stdio.h>
#include <stdint.h>
#include <inttypes.h>
#include "cpu.h"
#include "periph_conf.h"
#include "periph/rtt.h"
#define TICKS_TO_WAIT (5 * RTT_FREQUENCY)
static volatile uint32_t last;
static const uint32_t _ticktest[] = { 1, 256, 65536, 16777216, 2147483648 };
void cb(void *arg)
{
(void)arg;
last += TICKS_TO_WAIT;
last &= RTT_MAX_VALUE;
rtt_set_alarm(last, cb, 0);
puts("Hello");
}
int main(void)
{
puts("\nRIOT RTT low-level driver test");
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");
puts("Initializing the RTT driver");
rtt_init();
puts("This test will now display 'Hello' every 5 seconds\n");
uint32_t now = rtt_get_counter();
printf("RTT now: %" PRIu32 "\n", now);
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");
}
}
last = (now + TICKS_TO_WAIT) & RTT_MAX_VALUE;
printf("Setting initial alarm to now + 5 s (%" PRIu32 ")\n", last);
rtt_set_alarm(last, cb, 0);
uint32_t tmp = rtt_get_alarm();
if (tmp != last) {
printf("Error: rtt_get_alarm() not working (expected %" PRIu32 " but got %" PRIu32 ")\n",
last, tmp);
return 1;
}
else {
puts("rtt_get_alarm() PASSED");
}
puts("Done setting up the RTT, wait for many Hellos");
return 0;
}