2015-01-06 00:19:24 +01:00
|
|
|
/*
|
2015-02-08 09:18:23 +01:00
|
|
|
* Copyright (C) 2015 Eistec AB
|
2015-01-06 00:19:24 +01: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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-10-27 01:26:26 +02:00
|
|
|
* @ingroup cpu_kinetis
|
2017-06-22 15:43:17 +02:00
|
|
|
* @ingroup drivers_periph_rtc
|
2015-01-06 00:19:24 +01:00
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2015-02-08 09:18:23 +01:00
|
|
|
* @brief RTC interface wrapper for use with RTT modules.
|
2015-01-06 00:19:24 +01:00
|
|
|
*
|
2015-09-20 13:47:39 +02:00
|
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
2015-01-06 00:19:24 +01:00
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "periph/rtc.h"
|
2015-02-08 09:18:23 +01:00
|
|
|
#include "periph/rtt.h"
|
2015-01-06 00:19:24 +01:00
|
|
|
#include "periph_conf.h"
|
|
|
|
|
|
|
|
#define ENABLE_DEBUG (0)
|
|
|
|
#include "debug.h"
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
rtc_alarm_cb_t cb; /**< callback called from RTC interrupt */
|
|
|
|
} rtc_state_t;
|
|
|
|
|
|
|
|
static rtc_state_t rtc_callback;
|
|
|
|
|
2015-02-08 09:18:23 +01:00
|
|
|
/**
|
|
|
|
* @brief Wrapper function to call RTC callback from RTT interrupt
|
|
|
|
*
|
|
|
|
* @param[inout] arg argument passed from the RTT interrupt
|
|
|
|
*/
|
2020-08-27 23:11:19 +02:00
|
|
|
static void rtc_cb(void *arg);
|
2015-02-08 09:18:23 +01:00
|
|
|
|
2015-01-06 00:19:24 +01:00
|
|
|
void rtc_init(void)
|
|
|
|
{
|
2015-02-08 09:18:23 +01:00
|
|
|
rtt_init();
|
2015-01-06 00:19:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int rtc_set_time(struct tm *time)
|
|
|
|
{
|
2020-08-27 23:11:19 +02:00
|
|
|
uint32_t t = rtc_mktime(time);
|
2015-01-06 00:19:24 +01:00
|
|
|
|
2020-08-27 23:11:19 +02:00
|
|
|
rtt_set_counter(t);
|
2015-02-08 09:18:23 +01:00
|
|
|
|
2015-01-06 00:19:24 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int rtc_get_time(struct tm *time)
|
|
|
|
{
|
2020-08-27 23:11:19 +02:00
|
|
|
uint32_t t = rtt_get_counter();
|
2015-01-06 00:19:24 +01:00
|
|
|
|
2020-08-27 23:11:19 +02:00
|
|
|
rtc_localtime(t, time);
|
2015-01-06 00:19:24 +01:00
|
|
|
|
2015-02-08 09:18:23 +01:00
|
|
|
return 0;
|
2015-01-06 00:19:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int rtc_set_alarm(struct tm *time, rtc_alarm_cb_t cb, void *arg)
|
|
|
|
{
|
2020-08-27 23:11:19 +02:00
|
|
|
uint32_t t = rtc_mktime(time);
|
2015-01-06 00:19:24 +01:00
|
|
|
|
|
|
|
rtc_callback.cb = cb;
|
|
|
|
|
2020-08-27 23:11:19 +02:00
|
|
|
rtt_set_alarm(t, rtc_cb, arg);
|
2015-01-06 00:19:24 +01:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int rtc_get_alarm(struct tm *time)
|
|
|
|
{
|
2020-08-27 23:11:19 +02:00
|
|
|
uint32_t t = rtt_get_alarm();
|
2015-01-06 00:19:24 +01:00
|
|
|
|
2020-08-27 23:11:19 +02:00
|
|
|
rtc_localtime(t, time);
|
2015-01-06 00:19:24 +01:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void rtc_clear_alarm(void)
|
|
|
|
{
|
2015-02-08 09:18:23 +01:00
|
|
|
rtt_clear_alarm();
|
2015-01-06 00:19:24 +01:00
|
|
|
rtc_callback.cb = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
void rtc_poweron(void)
|
|
|
|
{
|
2015-02-08 09:18:23 +01:00
|
|
|
rtt_poweron();
|
2015-01-06 00:19:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rtc_poweroff(void)
|
|
|
|
{
|
2015-02-08 09:18:23 +01:00
|
|
|
rtt_poweroff();
|
2015-01-06 00:19:24 +01:00
|
|
|
}
|
|
|
|
|
2020-08-27 23:11:19 +02:00
|
|
|
static void rtc_cb(void *arg)
|
2015-01-06 00:19:24 +01:00
|
|
|
{
|
2015-02-08 09:18:23 +01:00
|
|
|
if (rtc_callback.cb != NULL) {
|
|
|
|
rtc_callback.cb(arg);
|
2015-01-06 00:19:24 +01:00
|
|
|
}
|
|
|
|
}
|