2015-02-08 09:18:23 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 PHYTEC Messtechnik GmbH
|
|
|
|
* Copyright (C) 2015 Eistec AB
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-10-27 01:26:26 +02:00
|
|
|
* @ingroup cpu_kinetis
|
2017-06-22 15:43:17 +02:00
|
|
|
* @ingroup drivers_periph_rtt
|
2015-02-08 09:18:23 +01:00
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @author Johann Fischer <j.fischer@phytec.de>
|
2015-09-20 13:47:39 +02:00
|
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
2015-02-08 09:18:23 +01:00
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <time.h>
|
|
|
|
#include "cpu.h"
|
2018-03-16 09:00:31 +01:00
|
|
|
#include "bit.h"
|
2015-02-08 09:18:23 +01:00
|
|
|
#include "periph/rtt.h"
|
2021-06-11 18:00:16 +02:00
|
|
|
#include "periph/timer.h"
|
2015-02-08 09:18:23 +01:00
|
|
|
#include "periph_conf.h"
|
|
|
|
|
2020-10-22 11:34:00 +02:00
|
|
|
#define ENABLE_DEBUG 0
|
2015-02-08 09:18:23 +01:00
|
|
|
#include "debug.h"
|
|
|
|
|
2021-06-11 18:00:16 +02:00
|
|
|
static rtt_cb_t alarm_cb = NULL; /**< callback called from RTC alarm */
|
2021-12-14 13:19:01 +01:00
|
|
|
static void *alarm_arg = NULL; /**< argument passed to the callback */
|
2021-06-11 18:00:16 +02:00
|
|
|
static uint32_t alarm_value = 0;
|
2015-02-08 09:18:23 +01:00
|
|
|
|
2021-06-11 18:00:16 +02:00
|
|
|
static void _rtt_cb(void *arg, int channel)
|
2015-02-08 09:18:23 +01:00
|
|
|
{
|
2021-06-11 18:00:16 +02:00
|
|
|
(void) arg;
|
|
|
|
(void) channel;
|
|
|
|
if (alarm_cb != NULL) {
|
|
|
|
alarm_cb(alarm_arg);
|
2018-03-16 09:00:31 +01:00
|
|
|
}
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|
|
|
|
|
2021-06-11 18:00:16 +02:00
|
|
|
void rtt_init(void)
|
2015-02-08 09:18:23 +01:00
|
|
|
{
|
2021-06-11 18:00:16 +02:00
|
|
|
timer_init(RTT_DEV, RTT_FREQUENCY, _rtt_cb, NULL);
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t rtt_get_counter(void)
|
|
|
|
{
|
2021-06-11 18:00:16 +02:00
|
|
|
return timer_read(RTT_DEV);
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rtt_set_alarm(uint32_t alarm, rtt_cb_t cb, void *arg)
|
|
|
|
{
|
2021-06-11 18:00:16 +02:00
|
|
|
unsigned state = irq_disable();
|
|
|
|
alarm_arg = arg;
|
|
|
|
alarm_cb = cb;
|
|
|
|
alarm_value = alarm;
|
2021-12-14 13:19:01 +01:00
|
|
|
timer_set_absolute(RTT_DEV, 0, alarm & RTT_MAX_VALUE);
|
2021-06-11 18:00:16 +02:00
|
|
|
irq_restore(state);
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t rtt_get_alarm(void)
|
|
|
|
{
|
2021-06-11 18:00:16 +02:00
|
|
|
return alarm_value;
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rtt_clear_alarm(void)
|
|
|
|
{
|
2021-12-14 13:19:01 +01:00
|
|
|
unsigned state = irq_disable();
|
|
|
|
alarm_cb = NULL;
|
|
|
|
alarm_arg = NULL;
|
2021-06-11 18:00:16 +02:00
|
|
|
timer_clear(RTT_DEV, 0);
|
2021-12-14 13:19:01 +01:00
|
|
|
irq_restore(state);
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rtt_poweron(void)
|
|
|
|
{
|
2021-06-11 18:00:16 +02:00
|
|
|
timer_start(RTT_DEV);
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rtt_poweroff(void)
|
|
|
|
{
|
2021-06-11 18:00:16 +02:00
|
|
|
timer_stop(RTT_DEV);
|
2015-02-08 09:18:23 +01:00
|
|
|
}
|