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