18c2ecf20Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 28c2ecf20Sopenharmony_ci%YAML 1.2 38c2ecf20Sopenharmony_ci--- 48c2ecf20Sopenharmony_ci$id: http://devicetree.org/schemas/rtc/st,stm32-rtc.yaml# 58c2ecf20Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 68c2ecf20Sopenharmony_ci 78c2ecf20Sopenharmony_cititle: STMicroelectronics STM32 Real Time Clock Bindings 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_cimaintainers: 108c2ecf20Sopenharmony_ci - Gabriel Fernandez <gabriel.fernandez@st.com> 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_ciproperties: 138c2ecf20Sopenharmony_ci compatible: 148c2ecf20Sopenharmony_ci enum: 158c2ecf20Sopenharmony_ci - st,stm32-rtc 168c2ecf20Sopenharmony_ci - st,stm32h7-rtc 178c2ecf20Sopenharmony_ci - st,stm32mp1-rtc 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ci reg: 208c2ecf20Sopenharmony_ci maxItems: 1 218c2ecf20Sopenharmony_ci 228c2ecf20Sopenharmony_ci clocks: 238c2ecf20Sopenharmony_ci minItems: 1 248c2ecf20Sopenharmony_ci maxItems: 2 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_ci clock-names: 278c2ecf20Sopenharmony_ci items: 288c2ecf20Sopenharmony_ci - const: pclk 298c2ecf20Sopenharmony_ci - const: rtc_ck 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_ci interrupts: 328c2ecf20Sopenharmony_ci maxItems: 1 338c2ecf20Sopenharmony_ci 348c2ecf20Sopenharmony_ci st,syscfg: 358c2ecf20Sopenharmony_ci $ref: "/schemas/types.yaml#/definitions/phandle-array" 368c2ecf20Sopenharmony_ci items: 378c2ecf20Sopenharmony_ci minItems: 3 388c2ecf20Sopenharmony_ci maxItems: 3 398c2ecf20Sopenharmony_ci description: | 408c2ecf20Sopenharmony_ci Phandle/offset/mask triplet. The phandle to pwrcfg used to 418c2ecf20Sopenharmony_ci access control register at offset, and change the dbp (Disable Backup 428c2ecf20Sopenharmony_ci Protection) bit represented by the mask, mandatory to disable/enable backup 438c2ecf20Sopenharmony_ci domain (RTC registers) write protection. 448c2ecf20Sopenharmony_ci 458c2ecf20Sopenharmony_ci assigned-clocks: 468c2ecf20Sopenharmony_ci description: | 478c2ecf20Sopenharmony_ci override default rtc_ck parent clock reference to the rtc_ck clock entry 488c2ecf20Sopenharmony_ci maxItems: 1 498c2ecf20Sopenharmony_ci 508c2ecf20Sopenharmony_ci assigned-clock-parents: 518c2ecf20Sopenharmony_ci description: | 528c2ecf20Sopenharmony_ci override default rtc_ck parent clock phandle of the new parent clock of rtc_ck 538c2ecf20Sopenharmony_ci maxItems: 1 548c2ecf20Sopenharmony_ci 558c2ecf20Sopenharmony_ciallOf: 568c2ecf20Sopenharmony_ci - if: 578c2ecf20Sopenharmony_ci properties: 588c2ecf20Sopenharmony_ci compatible: 598c2ecf20Sopenharmony_ci contains: 608c2ecf20Sopenharmony_ci const: st,stm32-rtc 618c2ecf20Sopenharmony_ci 628c2ecf20Sopenharmony_ci then: 638c2ecf20Sopenharmony_ci properties: 648c2ecf20Sopenharmony_ci clocks: 658c2ecf20Sopenharmony_ci minItems: 1 668c2ecf20Sopenharmony_ci maxItems: 1 678c2ecf20Sopenharmony_ci 688c2ecf20Sopenharmony_ci clock-names: false 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_ci required: 718c2ecf20Sopenharmony_ci - st,syscfg 728c2ecf20Sopenharmony_ci 738c2ecf20Sopenharmony_ci - if: 748c2ecf20Sopenharmony_ci properties: 758c2ecf20Sopenharmony_ci compatible: 768c2ecf20Sopenharmony_ci contains: 778c2ecf20Sopenharmony_ci const: st,stm32h7-rtc 788c2ecf20Sopenharmony_ci 798c2ecf20Sopenharmony_ci then: 808c2ecf20Sopenharmony_ci properties: 818c2ecf20Sopenharmony_ci clocks: 828c2ecf20Sopenharmony_ci minItems: 2 838c2ecf20Sopenharmony_ci maxItems: 2 848c2ecf20Sopenharmony_ci 858c2ecf20Sopenharmony_ci required: 868c2ecf20Sopenharmony_ci - clock-names 878c2ecf20Sopenharmony_ci - st,syscfg 888c2ecf20Sopenharmony_ci 898c2ecf20Sopenharmony_ci - if: 908c2ecf20Sopenharmony_ci properties: 918c2ecf20Sopenharmony_ci compatible: 928c2ecf20Sopenharmony_ci contains: 938c2ecf20Sopenharmony_ci const: st,stm32mp1-rtc 948c2ecf20Sopenharmony_ci 958c2ecf20Sopenharmony_ci then: 968c2ecf20Sopenharmony_ci properties: 978c2ecf20Sopenharmony_ci clocks: 988c2ecf20Sopenharmony_ci minItems: 2 998c2ecf20Sopenharmony_ci maxItems: 2 1008c2ecf20Sopenharmony_ci 1018c2ecf20Sopenharmony_ci assigned-clocks: false 1028c2ecf20Sopenharmony_ci assigned-clock-parents: false 1038c2ecf20Sopenharmony_ci 1048c2ecf20Sopenharmony_ci required: 1058c2ecf20Sopenharmony_ci - clock-names 1068c2ecf20Sopenharmony_ci 1078c2ecf20Sopenharmony_cirequired: 1088c2ecf20Sopenharmony_ci - compatible 1098c2ecf20Sopenharmony_ci - reg 1108c2ecf20Sopenharmony_ci - clocks 1118c2ecf20Sopenharmony_ci - interrupts 1128c2ecf20Sopenharmony_ci 1138c2ecf20Sopenharmony_ciadditionalProperties: false 1148c2ecf20Sopenharmony_ci 1158c2ecf20Sopenharmony_ciexamples: 1168c2ecf20Sopenharmony_ci - | 1178c2ecf20Sopenharmony_ci #include <dt-bindings/mfd/stm32f4-rcc.h> 1188c2ecf20Sopenharmony_ci #include <dt-bindings/clock/stm32fx-clock.h> 1198c2ecf20Sopenharmony_ci rtc@40002800 { 1208c2ecf20Sopenharmony_ci compatible = "st,stm32-rtc"; 1218c2ecf20Sopenharmony_ci reg = <0x40002800 0x400>; 1228c2ecf20Sopenharmony_ci clocks = <&rcc 1 CLK_RTC>; 1238c2ecf20Sopenharmony_ci assigned-clocks = <&rcc 1 CLK_RTC>; 1248c2ecf20Sopenharmony_ci assigned-clock-parents = <&rcc 1 CLK_LSE>; 1258c2ecf20Sopenharmony_ci interrupt-parent = <&exti>; 1268c2ecf20Sopenharmony_ci interrupts = <17 1>; 1278c2ecf20Sopenharmony_ci st,syscfg = <&pwrcfg 0x00 0x100>; 1288c2ecf20Sopenharmony_ci }; 1298c2ecf20Sopenharmony_ci 1308c2ecf20Sopenharmony_ci #include <dt-bindings/interrupt-controller/arm-gic.h> 1318c2ecf20Sopenharmony_ci #include <dt-bindings/clock/stm32mp1-clks.h> 1328c2ecf20Sopenharmony_ci rtc@5c004000 { 1338c2ecf20Sopenharmony_ci compatible = "st,stm32mp1-rtc"; 1348c2ecf20Sopenharmony_ci reg = <0x5c004000 0x400>; 1358c2ecf20Sopenharmony_ci clocks = <&rcc RTCAPB>, <&rcc RTC>; 1368c2ecf20Sopenharmony_ci clock-names = "pclk", "rtc_ck"; 1378c2ecf20Sopenharmony_ci interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; 1388c2ecf20Sopenharmony_ci }; 1398c2ecf20Sopenharmony_ci 1408c2ecf20Sopenharmony_ci... 141