Loading...
Searching...
No Matches
ds3231.h
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2020 Freie Universität Berlin
3 * SPDX-License-Identifier: LGPL-2.1-only
4 */
5
6#pragma once
7
29
30#include <time.h>
31#include <errno.h>
32
33#include "periph/gpio.h"
34#include "periph/i2c.h"
35
36#ifdef __cplusplus
37extern "C" {
38#endif
39
43#define DS3231_I2C_ADDR 0x68
44
49#define DS3231_FLAG_ALARM_1 0x01
50#define DS3231_FLAG_ALARM_2 0x02
52
56enum {
60};
61
72
82
86typedef struct {
88#if IS_USED(MODULE_DS3231_INT)
89 gpio_t int_pin;
90#endif /* MODULE_DS3231_INT */
91} ds3231_t;
92
96typedef struct {
98 uint8_t opt;
99#if IS_USED(MODULE_DS3231_INT)
100 gpio_t int_pin;
101#endif /* MODULE_DS3231_INT */
103
104#if IS_USED(MODULE_DS3231_INT)
105typedef void (*ds3231_alarm_cb_t)(void *);
106
107#endif /* MODULE_DS3231_INT */
108
118int ds3231_init(ds3231_t *dev, const ds3231_params_t *params);
119
120#if IS_USED(MODULE_DS3231_INT)
135int ds3231_await_alarm(ds3231_t *dev);
136#endif /* MODULE_DS3231_INT */
137
147int ds3231_get_time(const ds3231_t *dev, struct tm *time);
148
158int ds3231_set_time(const ds3231_t *dev, const struct tm *time);
159
170int ds3231_set_alarm_1(const ds3231_t *dev, struct tm *time,
171 ds3231_alm_1_mode_t trigger);
172
183int ds3231_set_alarm_2(const ds3231_t *dev, struct tm *time,
184 ds3231_alm_2_mode_t trigger);
185
195
205
217int ds3231_get_alarm_1_flag(const ds3231_t *dev, bool *flag);
218
230int ds3231_get_alarm_2_flag(const ds3231_t *dev, bool *flag);
231
241int ds3231_toggle_alarm_1(const ds3231_t *dev, bool enable);
242
252int ds3231_toggle_alarm_2(const ds3231_t *dev, bool enable);
253
263int ds3231_get_aging_offset(const ds3231_t *dev, int8_t *offset);
264
274int ds3231_set_aging_offset(const ds3231_t *dev, int8_t offset);
275
285int ds3231_get_temp(const ds3231_t *dev, int16_t *temp);
286
296
306
307#ifdef __cplusplus
308}
309#endif
310
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:65
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:76
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:66
@ DS3231_AL1_TRIG_S
alarm when seconds match
Definition ds3231.h:67
@ DS3231_AL1_TRIG_D_H_M_S
alarm when D/H/M/S match
Definition ds3231.h:70
@ DS3231_AL1_TRIG_H_M_S
alarm when H/M/S match
Definition ds3231.h:69
@ DS3231_AL1_TRIG_M_S
alarm when minutes and seconds match
Definition ds3231.h:68
@ DS3231_OPT_INTER_ENABLE
enable the interrupt control
Definition ds3231.h:59
@ DS3221_OPT_32KHZ_ENABLE
enable 32KHz output
Definition ds3231.h:58
@ DS3231_OPT_BAT_ENABLE
enable backup battery on startup
Definition ds3231.h:57
@ DS3231_AL2_TRIG_H_M
alarm when hours and minutes match
Definition ds3231.h:79
@ DS3231_AL2_TRIG_D_H_M_S
alarm when D/H/M match
Definition ds3231.h:80
@ DS3231_AL2_TRIG_M
alarm when minutes match
Definition ds3231.h:78
@ DS3231_AL2_TRIG_PER_M
alarm once per minute
Definition ds3231.h:77
uint_fast8_t i2c_t
Default i2c_t type definition.
Definition i2c.h:155
Low-level I2C peripheral driver interface definition.
Set of configuration parameters for DS3231 devices.
Definition ds3231.h:96
i2c_t bus
I2C bus the device is connected to.
Definition ds3231.h:97
uint8_t opt
additional options
Definition ds3231.h:98
Device descriptor for DS3231 devices.
Definition ds3231.h:86
i2c_t bus
I2C bus the device is connected to.
Definition ds3231.h:87