2018-08-19 17:11:37 +02:00
|
|
|
//---
|
|
|
|
// gint:rtc - Real-Time Clock
|
|
|
|
//---
|
|
|
|
|
|
|
|
#ifndef GINT_RTC
|
|
|
|
#define GINT_RTC
|
|
|
|
|
2021-06-13 18:13:09 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
#include <gint/defs/types.h>
|
2021-04-27 14:29:38 +02:00
|
|
|
#include <gint/defs/call.h>
|
2020-07-16 17:27:56 +02:00
|
|
|
#include <gint/timer.h>
|
2018-08-19 17:11:37 +02:00
|
|
|
|
|
|
|
//---
|
|
|
|
// Time management
|
|
|
|
//---
|
|
|
|
|
2020-07-16 17:27:56 +02:00
|
|
|
/* rtc_time_t: A point in time, representable in the RTC registers */
|
2018-08-19 17:11:37 +02:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint16_t year; /* Years (exact value, e.g. 2018) */
|
|
|
|
uint8_t week_day; /* Day of week, (0=Sunday, 6=Saturday) */
|
|
|
|
uint8_t month; /* Month (0..11) */
|
|
|
|
uint8_t month_day; /* Day of month (1..31) */
|
|
|
|
uint8_t hours; /* Hour (0..23) */
|
|
|
|
uint8_t minutes; /* Minute (0..59) */
|
2020-02-23 15:49:55 +01:00
|
|
|
uint8_t seconds; /* Second (0..59) */
|
2021-01-31 09:19:19 +01:00
|
|
|
uint8_t ticks; /* 128-Hz sub-second counter (0...127) */
|
2018-08-19 17:11:37 +02:00
|
|
|
|
|
|
|
} rtc_time_t;
|
|
|
|
|
2020-07-16 17:27:56 +02:00
|
|
|
/* rtc_get_time(): Read the current time from the RTC
|
2018-08-19 17:11:37 +02:00
|
|
|
@time Pointer to rtc_time_t structure (needs not be initialized) */
|
|
|
|
void rtc_get_time(rtc_time_t *time);
|
|
|
|
|
2020-07-16 17:27:56 +02:00
|
|
|
/* rtc_set_time(): Set current time in the RTC
|
2018-08-19 17:11:37 +02:00
|
|
|
If [time->week_day] is not in the valid range, it is set to 0. Other fields
|
2021-01-31 09:19:19 +01:00
|
|
|
are not checked. R64CNT cannot be set to [time->ticks] is ignored.
|
2018-08-19 17:11:37 +02:00
|
|
|
@time Pointer to new time */
|
2020-07-16 17:27:56 +02:00
|
|
|
void rtc_set_time(rtc_time_t const *time);
|
2018-08-19 17:11:37 +02:00
|
|
|
|
2021-01-31 09:19:19 +01:00
|
|
|
/* rtc_ticks(): Get number of 128-Hz ticks elapsed since Midnight.
|
|
|
|
|
|
|
|
Returns R64CNT + 128*RSECCNT + 128*60*RMINCNT + 128*60*60*RHRCNT. This can
|
|
|
|
be used as a 128-Hz counter, but it wraps around at midnight. */
|
|
|
|
uint32_t rtc_ticks(void);
|
|
|
|
|
2018-08-19 17:11:37 +02:00
|
|
|
//---
|
2021-04-27 14:29:38 +02:00
|
|
|
// RTC periodic interrupt
|
2018-08-19 17:11:37 +02:00
|
|
|
// The real-time clock produces a regular interrupt which may be used as a
|
|
|
|
// timer with a maximum frequency of 256 Hz. It is also useful to check
|
|
|
|
// that the clock settings (see <gint/clock.h>) are properly detected, by
|
|
|
|
// comparing the detected frequencies with the RTC.
|
|
|
|
//---
|
|
|
|
|
2020-07-16 17:27:56 +02:00
|
|
|
/* Possible frequency settings for the RTC's interrupt */
|
|
|
|
enum
|
2018-08-19 17:11:37 +02:00
|
|
|
{
|
2019-02-21 20:58:38 +01:00
|
|
|
RTC_500mHz = 7,
|
|
|
|
RTC_1Hz = 6,
|
|
|
|
RTC_2Hz = 5,
|
|
|
|
RTC_4Hz = 4,
|
|
|
|
RTC_16Hz = 3,
|
|
|
|
RTC_64Hz = 2,
|
|
|
|
RTC_256Hz = 1,
|
|
|
|
RTC_NONE = 0,
|
2020-07-16 17:27:56 +02:00
|
|
|
};
|
2018-08-19 17:11:37 +02:00
|
|
|
|
2021-04-27 14:29:38 +02:00
|
|
|
/* rtc_periodic_enable(): Enable the periodic interrupt
|
2018-08-19 17:11:37 +02:00
|
|
|
|
2021-04-27 14:29:38 +02:00
|
|
|
This function sets up the periodic interrupt to invoke the provided callback
|
|
|
|
regularly. As with timers, the callback must return either TIMER_CONTINUE or
|
|
|
|
TIMER_STOP.
|
2020-07-16 17:27:56 +02:00
|
|
|
|
2021-04-27 14:29:38 +02:00
|
|
|
Do not confuse this interrupt with CASIO's extra timers that run at 32768 Hz
|
|
|
|
(which are called "RTC timers" in CPU73050.dll). These timers are called
|
|
|
|
Extra TMU or ETMU in gint and are handled by <gint/timer.h>.
|
2020-07-16 17:27:56 +02:00
|
|
|
|
|
|
|
Note that the timing of the first callback is always uncertain. A 1 Hz timer
|
|
|
|
set up when half of the current second is already elapsed will be called for
|
|
|
|
the first time after only 500 ms, for instance.
|
2018-08-19 17:11:37 +02:00
|
|
|
|
2021-04-27 14:29:38 +02:00
|
|
|
@frequency Periodic interrupt frequency
|
|
|
|
@callback Function to call back at the specified frequency
|
|
|
|
Returns true on success, false if the interrupt is already in use. */
|
|
|
|
bool rtc_periodic_enable(int frequency, gint_call_t callback);
|
2018-08-19 17:11:37 +02:00
|
|
|
|
2021-04-27 14:29:38 +02:00
|
|
|
/* rtc_periodic_disable(): Stop the periodic interrupt
|
|
|
|
|
|
|
|
This has the same effect as returning TIMER_STOP from the callback, or
|
|
|
|
setting RTC_NONE as the parameter for rtc_periodic_enable(). */
|
|
|
|
void rtc_periodic_disable(void);
|
2018-08-19 17:11:37 +02:00
|
|
|
|
2021-04-27 14:29:38 +02:00
|
|
|
/* Deprecated versions with old-style callbacks and more confusing names */
|
|
|
|
__attribute__((deprecated("Use rtc_periodic_enable() instead")))
|
|
|
|
int rtc_start_timer(int frequency, timer_callback_t callback, ...);
|
|
|
|
#define rtc_start_timer(...) rtc_start_timer(__VA_ARGS__, 0)
|
|
|
|
__attribute__((deprecated("Use rtc_periodic_disable() instead")))
|
2018-08-19 17:11:37 +02:00
|
|
|
void rtc_stop_timer(void);
|
|
|
|
|
2021-06-13 18:13:09 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-08-19 17:11:37 +02:00
|
|
|
#endif /* GINT_RTC */
|