ds3231.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2020 Freie Universität Berlin
3  *
4  * This file is subject to the terms and conditions of the GNU Lesser
5  * General Public License v2.1. See the file LICENSE in the top level
6  * directory for more details.
7  */
8 
9 #pragma once
10 
33 #include <time.h>
34 #include <errno.h>
35 
36 #include "periph/gpio.h"
37 #include "periph/i2c.h"
38 
39 #ifdef __cplusplus
40 extern "C" {
41 #endif
42 
46 #define DS3231_I2C_ADDR 0x68
47 
52 #define DS3231_FLAG_ALARM_1 0x01
53 #define DS3231_FLAG_ALARM_2 0x02
59 enum {
63 };
64 
68 typedef enum {
75 
79 typedef enum {
85 
89 typedef struct {
91 #if IS_USED(MODULE_DS3231_INT)
92  gpio_t int_pin;
93 #endif /* MODULE_DS3231_INT */
94 } ds3231_t;
95 
99 typedef struct {
101  uint8_t opt;
102 #if IS_USED(MODULE_DS3231_INT)
103  gpio_t int_pin;
104 #endif /* MODULE_DS3231_INT */
106 
107 #if IS_USED(MODULE_DS3231_INT)
108 typedef void (*ds3231_alarm_cb_t)(void *);
109 
110 #endif /* MODULE_DS3231_INT */
111 
121 int ds3231_init(ds3231_t *dev, const ds3231_params_t *params);
122 
123 #if IS_USED(MODULE_DS3231_INT)
138 int ds3231_await_alarm(ds3231_t *dev);
139 #endif /* MODULE_DS3231_INT */
140 
150 int ds3231_get_time(const ds3231_t *dev, struct tm *time);
151 
161 int ds3231_set_time(const ds3231_t *dev, const struct tm *time);
162 
173 int ds3231_set_alarm_1(const ds3231_t *dev, struct tm *time,
174  ds3231_alm_1_mode_t trigger);
175 
186 int ds3231_set_alarm_2(const ds3231_t *dev, struct tm *time,
187  ds3231_alm_2_mode_t trigger);
188 
198 
208 
220 int ds3231_get_alarm_1_flag(const ds3231_t *dev, bool *flag);
221 
233 int ds3231_get_alarm_2_flag(const ds3231_t *dev, bool *flag);
234 
244 int ds3231_toggle_alarm_1(const ds3231_t *dev, bool enable);
245 
255 int ds3231_toggle_alarm_2(const ds3231_t *dev, bool enable);
256 
266 int ds3231_get_aging_offset(const ds3231_t *dev, int8_t *offset);
267 
277 int ds3231_set_aging_offset(const ds3231_t *dev, int8_t offset);
278 
288 int ds3231_get_temp(const ds3231_t *dev, int16_t *temp);
289 
298 int ds3231_enable_bat(const ds3231_t *dev);
299 
308 int ds3231_disable_bat(const ds3231_t *dev);
309 
310 #ifdef __cplusplus
311 }
312 #endif
313 
Low-level GPIO peripheral driver interface definitions.
int ds3231_clear_alarm_2_flag(const ds3231_t *dev)
Clear alarm 2 flag (A2F)
int ds3231_toggle_alarm_2(const ds3231_t *dev, bool enable)
Enable/Disable alarm 2 interrupt on the device.
int ds3231_set_time(const ds3231_t *dev, const struct tm *time)
Set date and time of the device.
int ds3231_get_temp(const ds3231_t *dev, int16_t *temp)
Get temperature from the device.
int ds3231_enable_bat(const ds3231_t *dev)
Enable the backup battery.
int ds3231_get_aging_offset(const ds3231_t *dev, int8_t *offset)
Get the configured aging offset (see datasheet for more information)
int ds3231_toggle_alarm_1(const ds3231_t *dev, bool enable)
Enable/Disable alarm 1 interrupt on the device.
int ds3231_set_alarm_2(const ds3231_t *dev, struct tm *time, ds3231_alm_2_mode_t trigger)
Set alarm 2 of the device.
ds3231_alm_1_mode_t
Alarm trigger type of alarm 1 for DS3231 devices.
Definition: ds3231.h:68
int ds3231_get_time(const ds3231_t *dev, struct tm *time)
Get date and time from the device.
int ds3231_get_alarm_2_flag(const ds3231_t *dev, bool *flag)
Get the state of alarm 2 flag (A2F)
int ds3231_init(ds3231_t *dev, const ds3231_params_t *params)
Initialize the given DS3231 device.
int ds3231_set_alarm_1(const ds3231_t *dev, struct tm *time, ds3231_alm_1_mode_t trigger)
Set alarm 1 of the device.
ds3231_alm_2_mode_t
Alarm trigger type of alarm 2 for DS3231 devices.
Definition: ds3231.h:79
int ds3231_get_alarm_1_flag(const ds3231_t *dev, bool *flag)
Get the state of alarm 1 flag (A1F)
int ds3231_set_aging_offset(const ds3231_t *dev, int8_t offset)
Set the aging offset (see datasheet for more information)
int ds3231_clear_alarm_1_flag(const ds3231_t *dev)
Clear alarm 1 flag (A1F)
int ds3231_disable_bat(const ds3231_t *dev)
Disable the backup battery.
@ DS3231_AL1_TRIG_PER_S
alarm once per second
Definition: ds3231.h:69
@ DS3231_AL1_TRIG_S
alarm when seconds match
Definition: ds3231.h:70
@ DS3231_AL1_TRIG_D_H_M_S
alarm when D/H/M/S match
Definition: ds3231.h:73
@ DS3231_AL1_TRIG_H_M_S
alarm when H/M/S match
Definition: ds3231.h:72
@ DS3231_AL1_TRIG_M_S
alarm when minutes and seconds match
Definition: ds3231.h:71
@ DS3231_OPT_INTER_ENABLE
enable the interrupt control
Definition: ds3231.h:62
@ DS3221_OPT_32KHZ_ENABLE
enable 32KHz output
Definition: ds3231.h:61
@ DS3231_OPT_BAT_ENABLE
enable backup battery on startup
Definition: ds3231.h:60
@ DS3231_AL2_TRIG_H_M
alarm when hours and minutes match
Definition: ds3231.h:82
@ DS3231_AL2_TRIG_D_H_M_S
alarm when D/H/M match
Definition: ds3231.h:83
@ DS3231_AL2_TRIG_M
alarm when minutes match
Definition: ds3231.h:81
@ DS3231_AL2_TRIG_PER_M
alarm once per minute
Definition: ds3231.h:80
uint_fast8_t i2c_t
Default i2c_t type definition.
Definition: i2c.h:144
Low-level I2C peripheral driver interface definition.
Set of configuration parameters for DS3231 devices.
Definition: ds3231.h:99
i2c_t bus
I2C bus the device is connected to.
Definition: ds3231.h:100
uint8_t opt
additional options
Definition: ds3231.h:101
Device descriptor for DS3231 devices.
Definition: ds3231.h:89
i2c_t bus
I2C bus the device is connected to.
Definition: ds3231.h:90