1 /*
2 * Copyright (c) 2019 Peter Bigot Consulting, LLC
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 /**
8 * @file
9 * @brief Real-time clock control based on the DS3231 counter API.
10 *
11 * The [Maxim
12 * DS3231](https://www.maximintegrated.com/en/products/analog/real-time-clocks/DS3231.html)
13 * is a high-precision real-time clock with temperature-compensated
14 * crystal oscillator and support for configurable alarms.
15 *
16 * The core Zephyr API to this device is as a counter, with the
17 * following limitations:
18 * * ``counter_read()`` and ``counter_*_alarm()`` cannot be invoked from
19 * interrupt context, as they require communication with the device
20 * over an I2C bus.
21 * * many other counter APIs, such as start/stop/set_top_value are not
22 * supported as the clock is always running.
23 * * two alarm channels are supported but are not equally capable:
24 * channel 0 supports alarms at 1 s resolution, while channel 1
25 * supports alarms at 1 minute resolution.
26 *
27 * Most applications for this device will need to use the extended
28 * functionality exposed by this header to access the real-time-clock
29 * features. The majority of these functions must be invoked from
30 * supervisor mode.
31 */
32 #ifndef ZEPHYR_INCLUDE_DRIVERS_RTC_DS3231_H_
33 #define ZEPHYR_INCLUDE_DRIVERS_RTC_DS3231_H_
34
35 #include <time.h>
36
37 #include <zephyr/drivers/counter.h>
38 #include <zephyr/kernel.h>
39 #include <zephyr/types.h>
40 #include <zephyr/sys/notify.h>
41
42 #ifdef __cplusplus
43 extern "C" {
44 #endif
45
46 /** @brief Bit in ctrl or ctrl_stat associated with alarm 1. */
47 #define MAXIM_DS3231_ALARM1 BIT(0)
48
49 /** @brief Bit in ctrl or ctrl_stat associated with alarm 2. */
50 #define MAXIM_DS3231_ALARM2 BIT(1)
51
52 /* Constants corresponding to bits in the DS3231 control register at
53 * 0x0E.
54 *
55 * See the datasheet for interpretation of these bits.
56 */
57 /** @brief ctrl bit for alarm 1 interrupt enable. */
58 #define MAXIM_DS3231_REG_CTRL_A1IE MAXIM_DS3231_ALARM1
59
60 /** @brief ctrl bit for alarm 2 interrupt enable. */
61 #define MAXIM_DS3231_REG_CTRL_A2IE MAXIM_DS3231_ALARM2
62
63 /** @brief ctrl bit for ISQ functionality.
64 *
65 * When clear the ISW signal provides a square wave. When set the ISW
66 * signal indicates alarm events.
67 *
68 * @note The driver expects to be able to control this bit.
69 */
70 #define MAXIM_DS3231_REG_CTRL_INTCN BIT(2)
71
72 /** @brief ctrl bit offset for square wave output frequency.
73 *
74 * @note The driver will control the content of this field.
75 */
76 #define MAXIM_DS3231_REG_CTRL_RS_Pos 3
77
78 /** @brief ctrl mask to isolate RS bits. */
79 #define MAXIM_DS3231_REG_CTRL_RS_Msk (0x03 << MAXIM_DS3231_REG_CTRL_RS_Pos)
80
81 /** @brief ctrl RS field value for 1 Hz square wave. */
82 #define MAXIM_DS3231_REG_CTRL_RS_1Hz 0x00
83
84 /** @brief ctrl RS field value for 1024 Hz square wave. */
85 #define MAXIM_DS3231_REG_CTRL_RS_1KiHz 0x01
86
87 /** @brief ctrl RS field value for 4096 Hz square wave. */
88 #define MAXIM_DS3231_REG_CTRL_RS_4KiHz 0x02
89
90 /** @brief ctrl RS field value for 8192 Hz square wave. */
91 #define MAXIM_DS3231_REG_CTRL_RS_8KiHz 0x03
92
93 /** @brief ctrl bit to write to trigger temperature conversion. */
94 #define MAXIM_DS3231_REG_CTRL_CONV BIT(5)
95
96 /** @brief ctrl bit to write to enable square wave output in battery mode. */
97 #define MAXIM_DS3231_REG_CTRL_BBSQW BIT(6)
98
99 /** @brief ctrl bit to write to disable the oscillator. */
100 #define MAXIM_DS3231_REG_CTRL_EOSCn BIT(7),
101
102 /** @brief ctrl_stat bit indicating alarm1 has triggered.
103 *
104 * If an alarm callback handler is registered this bit is
105 * cleared prior to invoking the callback with the flags
106 * indicating which alarms are ready.
107 */
108 #define MAXIM_DS3231_REG_STAT_A1F MAXIM_DS3231_ALARM1
109
110 /** @brief ctrl_stat bit indicating alarm2 has triggered.
111 *
112 * If an alarm callback handler is registered this bit is
113 * cleared prior to invoking the callback with the flags
114 * indicating which alarms are ready.
115 */
116 #define MAXIM_DS3231_REG_STAT_A2F MAXIM_DS3231_ALARM2
117
118 /** @brief Flag indicating a temperature conversion is in progress. */
119 #define MAXIM_DS3231_REG_STAT_BSY BIT(2)
120
121 /** @brief Set to enable 32 KiHz open drain signal.
122 *
123 * @note This is a control bit, though it is positioned within the
124 * ctrl_stat register which otherwise contains status bits.
125 */
126 #define MAXIM_DS3231_REG_STAT_EN32kHz BIT(3)
127
128 /** @brief Flag indicating the oscillator has been off since last cleared. */
129 #define MAXIM_DS3231_REG_STAT_OSF BIT(7)
130
131 /** @brief Control alarm behavior on match in seconds field.
132 *
133 * If clear the alarm fires only when the RTC seconds matches the
134 * alarm seconds.
135 *
136 * If set the alarm seconds field is ignored and an alarm will be
137 * triggered every second. The bits for IGNMN, IGNHR, and IGNDA must
138 * all be set.
139 *
140 * This bit must be clear for the second alarm instance.
141 *
142 * Bit maps to A1M1 and is used in
143 * maxim_ds3231_alarm_configuration::alarm_flags.
144 */
145 #define MAXIM_DS3231_ALARM_FLAGS_IGNSE BIT(0)
146
147 /** @brief Control alarm behavior on match in minutes field.
148 *
149 * If clear the alarm fires only when the RTC minutes matches the
150 * alarm minutes. The bit for IGNSE must be clear.
151 *
152 * If set the alarm minutes field is ignored and alarms will be
153 * triggered based on IGNSE. The bits for IGNHR and IGNDA must both be
154 * set.
155 *
156 * Bit maps to A1M2 or A2M2 and is used in
157 * maxim_ds3231_alarm_configuration::alarm_flags.
158 */
159 #define MAXIM_DS3231_ALARM_FLAGS_IGNMN BIT(1)
160
161 /** @brief Control alarm behavior on match in hours field.
162 *
163 * If clear the alarm fires only when the RTC hours matches the
164 * alarm hours. The bits for IGNMN and IGNSE must be clear.
165 *
166 * If set the alarm hours field is ignored and alarms will be
167 * triggered based on IGNMN and IGNSE. The bit for IGNDA must be set.
168 *
169 * Bit maps to A1M3 or A2M3 and is used in
170 * maxim_ds3231_alarm_configuration::alarm_flags.
171 */
172 #define MAXIM_DS3231_ALARM_FLAGS_IGNHR BIT(2)
173
174 /** @brief Control alarm behavior on match in day/date field.
175 *
176 * If clear the alarm fires only when the RTC day/date matches the
177 * alarm day/date, mediated by MAXIM_DS3231_ALARM_FLAGS_DAY. The bits
178 * for IGNHR, IGNMN, and IGNSE must be clear
179 *
180 * If set the alarm day/date field is ignored and an alarm will be
181 * triggered based on IGNHR, IGNMN, and IGNSE.
182 *
183 * Bit maps to A1M4 or A2M4 and is used in
184 * maxim_ds3231_alarm_configuration::alarm_flags.
185 */
186 #define MAXIM_DS3231_ALARM_FLAGS_IGNDA BIT(3)
187
188 /** @brief Control match on day of week versus day of month
189 *
190 * Set the flag to match on day of week; clear it to match on day of
191 * month.
192 *
193 * Bit maps to DY/DTn in corresponding
194 * maxim_ds3231_alarm_configuration::alarm_flags.
195 */
196 #define MAXIM_DS3231_ALARM_FLAGS_DOW BIT(4)
197
198 /** @brief Indicates that the alarm should be disabled once it fires.
199 *
200 * Set the flag in the maxim_ds3231_alarm_configuration::alarm_flags
201 * field to cause the alarm to be disabled when the interrupt fires,
202 * prior to invoking the corresponding handler.
203 *
204 * Leave false to allow the alarm to remain enabled so it will fire
205 * again on the next match.
206 */
207 #define MAXIM_DS3231_ALARM_FLAGS_AUTODISABLE BIT(7)
208
209 /**
210 * @brief RTC DS3231 Driver-Specific API
211 * @defgroup rtc_ds3231_interface RTC DS3231 Interface
212 * @ingroup io_interfaces
213 * @{
214 */
215
216 /** @brief Signature for DS3231 alarm callbacks.
217 *
218 * The alarm callback is invoked from the system work queue thread.
219 * At the point the callback is invoked the corresponding alarm flags
220 * will have been cleared from the device status register. The
221 * callback is permitted to invoke operations on the device.
222 *
223 * @param dev the device from which the callback originated
224 * @param id the alarm id
225 * @param syncclock the value from maxim_ds3231_read_syncclock() at the
226 * time the alarm interrupt was processed.
227 * @param user_data the corresponding parameter from
228 * maxim_ds3231_alarm::user_data.
229 */
230 typedef void (*maxim_ds3231_alarm_callback_handler_t)(const struct device *dev,
231 uint8_t id,
232 uint32_t syncclock,
233 void *user_data);
234
235 /** @brief Signature used to notify a user of the DS3231 that an
236 * asynchronous operation has completed.
237 *
238 * Functions compatible with this type are subject to all the
239 * constraints of #sys_notify_generic_callback.
240 *
241 * @param dev the DS3231 device pointer
242 *
243 * @param notify the notification structure provided in the call
244 *
245 * @param res the result of the operation.
246 */
247 typedef void (*maxim_ds3231_notify_callback)(const struct device *dev,
248 struct sys_notify *notify,
249 int res);
250
251 /** @brief Information defining the alarm configuration.
252 *
253 * DS3231 alarms can be set to fire at specific times or at the
254 * rollover of minute, hour, day, or day of week.
255 *
256 * When an alarm is configured with a handler an interrupt will be
257 * generated and the handler called from the system work queue.
258 *
259 * When an alarm is configured without a handler, or a persisted alarm
260 * is present, alarms can be read using maxim_ds3231_check_alarms().
261 */
262 struct maxim_ds3231_alarm {
263 /** @brief Time specification for an RTC alarm.
264 *
265 * Though specified as a UNIX time, the alarm parameters are
266 * determined by converting to civil time and interpreting the
267 * component hours, minutes, seconds, day-of-week, and
268 * day-of-month fields, mediated by the corresponding #flags.
269 *
270 * The year and month are ignored, but be aware that gmtime()
271 * determines day-of-week based on calendar date. Decoded
272 * alarm times will fall within 1978-01 since 1978-01-01
273 * (first of month) was a Sunday (first of week).
274 */
275 time_t time;
276
277 /** @brief Handler to be invoked when alarms are signalled.
278 *
279 * If this is null the alarm will not be triggered by the
280 * INTn/SQW GPIO. This is a "persisted" alarm from its role
281 * in using the DS3231 to trigger a wake from deep sleep. The
282 * application should use maxim_ds3231_check_alarms() to
283 * determine whether such an alarm has been triggered.
284 *
285 * If this is not null the driver will monitor the ISW GPIO
286 * for alarm signals and will invoke the handler with a
287 * parameter carrying the value returned by
288 * maxim_ds3231_check_alarms(). The corresponding status flags
289 * will be cleared in the device before the handler is
290 * invoked.
291 *
292 * The handler will be invoked from the system work queue.
293 */
294 maxim_ds3231_alarm_callback_handler_t handler;
295
296 /** @brief User-provided pointer passed to alarm callback. */
297 void *user_data;
298
299 /** @brief Flags controlling configuration of the alarm alarm.
300 *
301 * See MAXIM_DS3231_ALARM_FLAGS_IGNSE and related constants.
302 *
303 * Note that as described the alarm mask fields require that
304 * if a unit is not ignored, higher-precision units must also
305 * not be ignored. For example, if match on hours is enabled,
306 * match on minutes and seconds must also be enabled. Failure
307 * to comply with this requirement will cause
308 * maxim_ds3231_set_alarm() to return an error, leaving the
309 * alarm configuration unchanged.
310 */
311 uint8_t flags;
312 };
313
314 /** @brief Register the RTC clock against system clocks.
315 *
316 * This captures the same instant in both the RTC time scale and a
317 * stable system clock scale, allowing conversion between those
318 * scales.
319 */
320 struct maxim_ds3231_syncpoint {
321 /** @brief Time from the DS3231.
322 *
323 * This maybe in UTC, TAI, or local offset depending on how
324 * the RTC is maintained.
325 */
326 struct timespec rtc;
327
328 /** @brief Value of a local clock at the same instant as #rtc.
329 *
330 * This is captured from a stable monotonic system clock
331 * running at between 1 kHz and 1 MHz, allowing for
332 * microsecond to millisecond accuracy in synchronization.
333 */
334 uint32_t syncclock;
335 };
336
337 /** @brief Read the local synchronization clock.
338 *
339 * Synchronization aligns the DS3231 real-time clock with a stable
340 * monotonic local clock which should have a frequency between 1 kHz
341 * and 1 MHz and be itself synchronized with the primary system time
342 * clock. The accuracy of the alignment and the maximum time between
343 * synchronization updates is affected by the resolution of this
344 * clock.
345 *
346 * On some systems the hardware clock from k_cycles_get_32() is
347 * suitable, but on others that clock advances too quickly. The
348 * frequency of the target-specific clock is provided by
349 * maxim_ds3231_syncclock_frequency().
350 *
351 * At this time the value is captured from `k_uptime_get_32()`; future
352 * kernel extensions may make a higher-resolution clock available.
353 *
354 * @note This function is *isr-ok*.
355 *
356 * @param dev the DS3231 device pointer
357 *
358 * @return the current value of the synchronization clock.
359 */
maxim_ds3231_read_syncclock(const struct device * dev)360 static inline uint32_t maxim_ds3231_read_syncclock(const struct device *dev)
361 {
362 return k_uptime_get_32();
363 }
364
365 /** @brief Get the frequency of the synchronization clock.
366 *
367 * Provides the frequency of the clock used in maxim_ds3231_read_syncclock().
368 *
369 * @param dev the DS3231 device pointer
370 *
371 * @return the frequency of the selected synchronization clock.
372 */
maxim_ds3231_syncclock_frequency(const struct device * dev)373 static inline uint32_t maxim_ds3231_syncclock_frequency(const struct device *dev)
374 {
375 return 1000U;
376 }
377
378 /**
379 * @brief Set and clear specific bits in the control register.
380 *
381 * @note This function assumes the device register cache is valid. It
382 * will not read the register value, and it will write to the device
383 * only if the value changes as a result of applying the set and clear
384 * changes.
385 *
386 * @note Unlike maxim_ds3231_stat_update() the return value from this
387 * function indicates the register value after changes were made.
388 * That return value is cached for use in subsequent operations.
389 *
390 * @note This function is *supervisor*.
391 *
392 * @return the non-negative updated value of the register, or a
393 * negative error code from an I2C transaction.
394 */
395 int maxim_ds3231_ctrl_update(const struct device *dev,
396 uint8_t set_bits,
397 uint8_t clear_bits);
398
399 /**
400 * @brief Read the ctrl_stat register then set and clear bits in it.
401 *
402 * The content of the ctrl_stat register will be read, then the set
403 * and clear bits applied and the result written back to the device
404 * (regardless of whether there appears to be a change in value).
405 *
406 * OSF, A1F, and A2F will be written with 1s if the corresponding bits
407 * do not appear in either @p set_bits or @p clear_bits. This ensures
408 * that if any flag becomes set between the read and the write that
409 * indicator will not be cleared.
410 *
411 * @note Unlike maxim_ds3231_ctrl_update() the return value from this
412 * function indicates the register value before any changes were made.
413 *
414 * @note This function is *supervisor*.
415 *
416 * @param dev the DS3231 device pointer
417 *
418 * @param set_bits bits to be set when writing back. Setting bits
419 * other than @ref MAXIM_DS3231_REG_STAT_EN32kHz will have no effect.
420 *
421 * @param clear_bits bits to be cleared when writing back. Include
422 * the bits for the status flags you want to clear.
423 *
424 * @return the non-negative register value as originally read
425 * (disregarding the effect of clears and sets), or a negative error
426 * code from an I2C transaction.
427 */
428 int maxim_ds3231_stat_update(const struct device *dev,
429 uint8_t set_bits,
430 uint8_t clear_bits);
431
432 /** @brief Read a DS3231 alarm configuration.
433 *
434 * The alarm configuration data is read from the device and
435 * reconstructed into the output parameter.
436 *
437 * @note This function is *supervisor*.
438 *
439 * @param dev the DS3231 device pointer.
440 *
441 * @param id the alarm index, which must be 0 (for the 1 s resolution
442 * alarm) or 1 (for the 1 min resolution alarm).
443 *
444 * @param cfg a pointer to a structure into which the configured alarm
445 * data will be stored.
446 *
447 * @return a non-negative value indicating successful conversion, or a
448 * negative error code from an I2C transaction or invalid parameter.
449 */
450 int maxim_ds3231_get_alarm(const struct device *dev,
451 uint8_t id,
452 struct maxim_ds3231_alarm *cfg);
453
454 /** @brief Configure a DS3231 alarm.
455 *
456 * The alarm configuration is validated and stored into the device.
457 *
458 * To cancel an alarm use counter_cancel_channel_alarm().
459 *
460 * @note This function is *supervisor*.
461 *
462 * @param dev the DS3231 device pointer.
463 *
464 * @param id 0 Analog to counter index. @c ALARM1 is 0 and has 1 s
465 * resolution, @c ALARM2 is 1 and has 1 minute resolution.
466 *
467 * @param cfg a pointer to the desired alarm configuration. Both
468 * alarms are configured; if only one is to change the application
469 * must supply the existing configuration for the other.
470 *
471 * @return a non-negative value on success, or a negative error code
472 * from an I2C transaction or an invalid parameter.
473 */
474 int maxim_ds3231_set_alarm(const struct device *dev,
475 uint8_t id,
476 const struct maxim_ds3231_alarm *cfg);
477
478 /** @brief Synchronize the RTC against the local clock.
479 *
480 * The RTC advances one tick per second with no access to sub-second
481 * precision. Synchronizing clocks at sub-second resolution requires
482 * enabling a 1pps signal then capturing the system clocks in a GPIO
483 * callback. This function provides that operation.
484 *
485 * Synchronization is performed in asynchronously, and may take as
486 * long as 1 s to complete; notification of completion is provided
487 * through the @p notify parameter.
488 *
489 * Applications should use maxim_ds3231_get_syncpoint() to retrieve the
490 * synchronization data collected by this operation.
491 *
492 * @note This function is *supervisor*.
493 *
494 * @param dev the DS3231 device pointer.
495 *
496 * @param notify pointer to the object used to specify asynchronous
497 * function behavior and store completion information.
498 *
499 * @retval non-negative on success
500 * @retval -EBUSY if a synchronization or set is currently in progress
501 * @retval -EINVAL if notify is not provided
502 * @retval -ENOTSUP if the required interrupt is not configured
503 */
504 int maxim_ds3231_synchronize(const struct device *dev,
505 struct sys_notify *notify);
506
507 /** @brief Request to update the synchronization point.
508 *
509 * This is a variant of maxim_ds3231_synchronize() for use from user
510 * threads.
511 *
512 * @param dev the DS3231 device pointer.
513 *
514 * @param signal pointer to a valid and ready-to-be-signalled
515 * k_poll_signal. May be NULL to request a synchronization point be
516 * collected without notifying when it has been updated.
517 *
518 * @retval non-negative on success
519 * @retval -EBUSY if a synchronization or set is currently in progress
520 * @retval -ENOTSUP if the required interrupt is not configured
521 */
522 __syscall int maxim_ds3231_req_syncpoint(const struct device *dev,
523 struct k_poll_signal *signal);
524
525 /** @brief Retrieve the most recent synchronization point.
526 *
527 * This function returns the synchronization data last captured using
528 * maxim_ds3231_synchronize().
529 *
530 * @param dev the DS3231 device pointer.
531 *
532 * @param syncpoint where to store the synchronization data.
533 *
534 * @retval non-negative on success
535 * @retval -ENOENT if no syncpoint has been captured
536 */
537 __syscall int maxim_ds3231_get_syncpoint(const struct device *dev,
538 struct maxim_ds3231_syncpoint *syncpoint);
539
540 /** @brief Set the RTC to a time consistent with the provided
541 * synchronization.
542 *
543 * The RTC advances one tick per second with no access to sub-second
544 * precision, and setting the clock resets the internal countdown
545 * chain. This function implements the magic necessary to set the
546 * clock while retaining as much sub-second accuracy as possible. It
547 * requires a synchronization point that pairs sub-second resolution
548 * civil time with a local synchronization clock captured at the same
549 * instant. The set operation may take as long as 1 second to
550 * complete; notification of completion is provided through the @p
551 * notify parameter.
552 *
553 * @note This function is *supervisor*.
554 *
555 * @param dev the DS3231 device pointer.
556 *
557 * @param syncpoint the structure providing the synchronization point.
558 *
559 * @param notify pointer to the object used to specify asynchronous
560 * function behavior and store completion information.
561 *
562 * @retval non-negative on success
563 * @retval -EINVAL if syncpoint or notify are null
564 * @retval -ENOTSUP if the required interrupt signal is not configured
565 * @retval -EBUSY if a synchronization or set is currently in progress
566 */
567 int maxim_ds3231_set(const struct device *dev,
568 const struct maxim_ds3231_syncpoint *syncpoint,
569 struct sys_notify *notify);
570
571 /** @brief Check for and clear flags indicating that an alarm has
572 * fired.
573 *
574 * Returns a mask indicating alarms that are marked as having fired,
575 * and clears from stat the flags that it found set. Alarms that have
576 * been configured with a callback are not represented in the return
577 * value.
578 *
579 * This API may be used when a persistent alarm has been programmed.
580 *
581 * @note This function is *supervisor*.
582 *
583 * @param dev the DS3231 device pointer.
584 *
585 * @return a non-negative value that may have MAXIM_DS3231_ALARM1 and/or
586 * MAXIM_DS3231_ALARM2 set, or a negative error code.
587 */
588 int maxim_ds3231_check_alarms(const struct device *dev);
589
590 /**
591 * @}
592 */
593
594 #ifdef __cplusplus
595 }
596 #endif
597
598 /* @todo this should be syscalls/drivers/rtc/maxim_ds3231.h */
599 #include <zephyr/syscalls/maxim_ds3231.h>
600
601 #endif /* ZEPHYR_INCLUDE_DRIVERS_RTC_DS3231_H_ */
602