1.. _rtc_api: 2 3Real-Time Clock (RTC) 4##################### 5 6Overview 7******** 8 9.. list-table:: **Glossary** 10 :widths: 30 80 11 :header-rows: 1 12 13 * - Word 14 - Definition 15 * - Real-time clock 16 - Low power device tracking time using broken-down time 17 * - Real-time counter 18 - Low power counter which can be used to track time 19 * - RTC 20 - Acronym for real-time clock 21 22An RTC is a low power device which tracks time using broken-down time. 23It should not be confused with low-power counters which sometimes share 24the same name, acronym, or both. 25 26RTCs are usually optimized for low energy consumption and are usually 27kept running even when the system is in a low power state. 28 29RTCs usually contain one or more alarms which can be configured to 30trigger at a given time. These alarms are commonly used to wake up the 31system from a low power state. 32 33History of RTCs in Zephyr 34************************* 35 36RTCs have been supported before this API was created, using the 37:ref:`counter_api` API. The unix timestamp was used to convert 38between broken-down time and the unix timestamp within the RTC 39drivers, which internally used the broken-down time representation. 40 41The disadvantages of this approach were that hardware counters could 42not be set to a specific count, requiring all RTCs to use device 43specific APIs to set the time, converting from unix time to 44broken-down time, unnecessarily in some cases, and some common 45features missing, like input clock calibration and the update 46callback. 47 48Configuration Options 49********************* 50 51Related configuration options: 52 53* :kconfig:option:`CONFIG_RTC` 54* :kconfig:option:`CONFIG_RTC_ALARM` 55* :kconfig:option:`CONFIG_RTC_UPDATE` 56* :kconfig:option:`CONFIG_RTC_CALIBRATION` 57 58API Reference 59************* 60 61.. doxygengroup:: rtc_interface 62 63RTC device driver test suite 64**************************** 65 66The test suite validates the behavior of the RTC device driver. It 67is designed to be portable between boards. It uses the device tree 68alias ``rtc`` to designate the RTC device to test. 69 70This test suite tests the following: 71 72* Setting and getting the time. 73* RTC Time incrementing correctly. 74* Alarms if supported by hardware, with and without callback enabled 75* Calibration if supported by hardware. 76 77The calibration test tests a range of values which are printed to the 78console to be manually compared. The user must review the set and 79gotten values to ensure they are valid. 80 81By default, only the mandatory setting and getting of time is enabled 82for testing. To test the optional alarms, update event callback 83and clock calibration, these must be enabled by selecting 84:kconfig:option:`CONFIG_RTC_ALARM`, :kconfig:option:`CONFIG_RTC_UPDATE` 85and :kconfig:option:`CONFIG_RTC_CALIBRATION`. 86 87The following examples build the test suite for the ``native_sim`` 88board. To build the test suite for a different board, replace the 89``native_sim`` board with your board. 90 91To build the test application with the default configuration, testing 92only the mandatory features, the following command can be used for 93reference: 94 95.. zephyr-app-commands:: 96 :tool: west 97 :host-os: unix 98 :board: native_sim 99 :zephyr-app: tests/drivers/rtc/rtc_api 100 :goals: build 101 102To build the test with additional RTC features enabled, use menuconfig 103to enable the additional features by updating the configuration. The 104following command can be used for reference: 105 106.. zephyr-app-commands:: 107 :tool: west 108 :host-os: unix 109 :board: native_sim 110 :zephyr-app: tests/drivers/rtc/rtc_api 111 :goals: menuconfig 112 113Then build the test application using the following command: 114 115.. zephyr-app-commands:: 116 :tool: west 117 :host-os: unix 118 :board: native_sim 119 :zephyr-app: tests/drivers/rtc/rtc_api 120 :maybe-skip-config: 121 :goals: build 122 123To run the test suite, flash and run the application on your board, the output will 124be printed to the console. 125 126.. note:: 127 128 The tests take up to 30 seconds each if they are testing real hardware. 129 130.. _rtc_api_emul_dev: 131 132RTC emulated device 133******************* 134 135The emulated RTC device fully implements the RTC API, and will behave like a real 136RTC device, with the following limitations: 137 138* RTC time is not persistent across application initialization. 139* RTC alarms are not persistent across application initialization. 140* RTC time will drift over time. 141 142Every time an application is initialized, the RTC's time and alarms are reset. Reading 143the time using :c:func:`rtc_get_time` will return ``-ENODATA``, until the time is 144set using :c:func:`rtc_set_time`. The RTC will then behave as a real RTC, until the 145application is reset. 146 147The emulated RTC device driver is built for the compatible 148:dtcompatible:`zephyr,rtc-emul` and will be included if :kconfig:option:`CONFIG_RTC` 149is selected. 150