2016-07-25 09:04:22 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core module: rtc
|
|
|
|
//
|
|
|
|
// Manages RTC. This module is used behind standard module time.
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
|
|
|
#ifndef _RTC_H
|
|
|
|
#define _RTC_H 1
|
|
|
|
|
2017-03-01 11:07:28 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
//---
|
|
|
|
// Time access.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
2017-03-01 11:07:28 +01:00
|
|
|
rtc_time_t
|
2016-08-08 15:01:33 +02:00
|
|
|
Defines a point in time.
|
2016-08-02 07:51:44 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
typedef struct
|
2016-08-02 07:51:44 +02:00
|
|
|
{
|
2017-03-01 11:07:28 +01:00
|
|
|
uint8_t seconds; // Seconds in range 0-59
|
|
|
|
uint8_t minutes; // Minutes in range 0-59
|
|
|
|
uint8_t hours; // Hours in range 0-23
|
|
|
|
uint8_t month_day; // Day of month in range 1-31
|
|
|
|
uint8_t month; // Month in range 0-11
|
|
|
|
uint8_t week_day; // Day of week in range 0(Sunday)-6(Saturday).
|
|
|
|
uint16_t year; // Years (around 2000)
|
|
|
|
|
|
|
|
} rtc_time_t;
|
2016-08-02 07:51:44 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
rtc_getTime()
|
2016-08-08 15:01:33 +02:00
|
|
|
Reads the current time from the RTC. There is no guarantee that the
|
|
|
|
week day is correct (use the time API for that).
|
2016-08-02 07:51:44 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
rtc_time_t rtc_getTime(void);
|
2016-08-02 07:51:44 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
rtc_setTime()
|
2016-08-08 15:01:33 +02:00
|
|
|
Sets the time in the RTC registers. The week day is set to 0 if greater
|
|
|
|
than 6. Other fields are not checked.
|
2016-08-02 07:51:44 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
void rtc_setTime(rtc_time_t time);
|
2016-08-02 07:51:44 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
//---
|
|
|
|
// Callback API.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
2017-03-01 11:07:28 +01:00
|
|
|
rtc_frequency_t
|
2016-07-25 09:04:22 +02:00
|
|
|
Describes the possible frequencies available for the real-time clock
|
|
|
|
interrupt.
|
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
typedef enum
|
2016-07-25 09:04:22 +02:00
|
|
|
{
|
|
|
|
RTCFreq_500mHz = 7,
|
|
|
|
RTCFreq_1Hz = 6,
|
|
|
|
RTCFreq_2Hz = 5,
|
|
|
|
RTCFreq_4Hz = 4,
|
|
|
|
RTCFreq_16Hz = 3,
|
|
|
|
RTCFreq_64Hz = 2,
|
|
|
|
RTCFreq_256Hz = 1,
|
2016-09-04 11:35:41 +02:00
|
|
|
RTCFreq_None = 0,
|
2017-03-01 11:07:28 +01:00
|
|
|
|
|
|
|
} rtc_frequency_t;
|
2016-07-25 09:04:22 +02:00
|
|
|
|
|
|
|
/*
|
2016-09-04 11:35:41 +02:00
|
|
|
rtc_cb_add()
|
|
|
|
Registers a new callback for the RTC. Returns the callback id on
|
|
|
|
success (positive integer), or one of the following error codes:
|
|
|
|
-1 Array is full
|
|
|
|
-2 Invalid parameter
|
|
|
|
The number of repeats may be set to 0, in which case the callback is
|
|
|
|
called indefinitely unless the user calls rtc_cb_end().
|
2016-07-25 09:04:22 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
int rtc_cb_add(rtc_frequency_t freq, void (*function)(void), int repeats);
|
2016-07-25 09:04:22 +02:00
|
|
|
|
|
|
|
/*
|
2016-09-04 11:35:41 +02:00
|
|
|
rtc_cb_end()
|
|
|
|
Removes the callback with the given id (as returned by rtc_cb_add())
|
|
|
|
from the callback array.
|
2016-07-25 09:04:22 +02:00
|
|
|
*/
|
2016-09-04 11:35:41 +02:00
|
|
|
void rtc_cb_end(int id);
|
|
|
|
|
|
|
|
/*
|
|
|
|
rtc_cb_edit()
|
|
|
|
Changes information related to a callback. This function returns 0 on
|
|
|
|
success, or one of the following error codes:
|
|
|
|
-1 Callback does not exist
|
|
|
|
-2 Invalid parameters
|
|
|
|
This function never removes a callback. Call rtc_cb_end() for this. One
|
|
|
|
can set the function to NULL or the frequency to RTCFreq_None to
|
|
|
|
temporarily disable the callback.
|
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
int rtc_cb_edit(int id, rtc_frequency_t new_freq, void (*new_function)(void));
|
2016-07-25 09:04:22 +02:00
|
|
|
|
|
|
|
#endif // _RTC_H
|