zephyr/include/drivers/rtc/mcux_snvs_rtc.h
Pieter De Gendt 4d161a3b23 drivers: counter: NXP SNVS rtc: Add support for NXP imx SNVS RTC
Adds a driver using the SNVS high power and optionally low power
RTC instances. A device specific function `mcux_snvs_rtc_set` is
provided to update the current counter value.

Signed-off-by: Pieter De Gendt <pieter.degendt@basalte.be>
2021-12-07 09:45:43 -06:00

48 lines
1.1 KiB
C

/*
* Copyright (c) 2021 Basalte bv
*
* SPDX-License-Identifier: Apache-2.0
*/
/**
* @file
* @brief Real-time clock control based on the MCUX IMX SNVS counter API.
*
* The core Zephyr API to this device is as a counter.
*
* Additional implementation details a user should take into account:
* * an optional SRTC can be enabled (default) with configuration
* options
* * the high power channel (id 0) is always available, the low power
* channel (id 1) is optional
* * the low power alarm can be used to assert a wake-up
* * the counter has a fixed 1Hz period
*/
#ifndef ZEPHYR_INCLUDE_DRIVERS_RTC_MCUX_SNVS_H_
#define ZEPHYR_INCLUDE_DRIVERS_RTC_MCUX_SNVS_H_
#include <device.h>
#ifdef __cplusplus
extern "C" {
#endif
/** @brief Set the current counter value
*
* As the counter advances at 1Hz this will usually be set to the
* current UNIX time stamp.
*
* @param dev the IMX SNVS RTC device pointer.
*
* @param ticks the new value of the internal counter
*
* @retval non-negative on success
*/
int mcux_snvs_rtc_set(const struct device *dev, uint32_t ticks);
#ifdef __cplusplus
}
#endif
#endif /* ZEPHYR_INCLUDE_DRIVERS_RTC_MCUX_SNVS_H_ */