Loading...
Searching...
No Matches
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
32
33#include <time.h>
34#include <errno.h>
35
36#include "periph/gpio.h"
37#include "periph/i2c.h"
38
39#ifdef __cplusplus
40extern "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
55
59enum {
63};
64
75
85
89typedef struct {
91#if IS_USED(MODULE_DS3231_INT)
92 gpio_t int_pin;
93#endif /* MODULE_DS3231_INT */
94} ds3231_t;
95
99typedef 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)
108typedef void (*ds3231_alarm_cb_t)(void *);
109
110#endif /* MODULE_DS3231_INT */
111
121int ds3231_init(ds3231_t *dev, const ds3231_params_t *params);
122
123#if IS_USED(MODULE_DS3231_INT)
138int ds3231_await_alarm(ds3231_t *dev);
139#endif /* MODULE_DS3231_INT */
140
150int ds3231_get_time(const ds3231_t *dev, struct tm *time);
151
161int ds3231_set_time(const ds3231_t *dev, const struct tm *time);
162
173int ds3231_set_alarm_1(const ds3231_t *dev, struct tm *time,
174 ds3231_alm_1_mode_t trigger);
175
186int ds3231_set_alarm_2(const ds3231_t *dev, struct tm *time,
187 ds3231_alm_2_mode_t trigger);
188
198
208
220int ds3231_get_alarm_1_flag(const ds3231_t *dev, bool *flag);
221
233int ds3231_get_alarm_2_flag(const ds3231_t *dev, bool *flag);
234
244int ds3231_toggle_alarm_1(const ds3231_t *dev, bool enable);
245
255int ds3231_toggle_alarm_2(const ds3231_t *dev, bool enable);
256
266int ds3231_get_aging_offset(const ds3231_t *dev, int8_t *offset);
267
277int ds3231_set_aging_offset(const ds3231_t *dev, int8_t offset);
278
288int ds3231_get_temp(const ds3231_t *dev, int16_t *temp);
289
299
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