162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/reset/hisilicon,hi3660-reset.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Hisilicon System Reset Controller
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Wei Xu <xuwei5@hisilicon.com>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription: |
1362306a36Sopenharmony_ci  Please also refer to reset.txt in this directory for common reset
1462306a36Sopenharmony_ci  controller binding usage.
1562306a36Sopenharmony_ci  The reset controller registers are part of the system-ctl block on
1662306a36Sopenharmony_ci  hi3660 and hi3670 SoCs.
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ciproperties:
1962306a36Sopenharmony_ci  compatible:
2062306a36Sopenharmony_ci    oneOf:
2162306a36Sopenharmony_ci      - items:
2262306a36Sopenharmony_ci          - const: hisilicon,hi3660-reset
2362306a36Sopenharmony_ci      - items:
2462306a36Sopenharmony_ci          - const: hisilicon,hi3670-reset
2562306a36Sopenharmony_ci          - const: hisilicon,hi3660-reset
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci  hisi,rst-syscon:
2862306a36Sopenharmony_ci    deprecated: true
2962306a36Sopenharmony_ci    description: phandle of the reset's syscon, use hisilicon,rst-syscon instead
3062306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci  hisilicon,rst-syscon:
3362306a36Sopenharmony_ci    description: phandle of the reset's syscon.
3462306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci  '#reset-cells':
3762306a36Sopenharmony_ci    description: |
3862306a36Sopenharmony_ci      Specifies the number of cells needed to encode a reset source.
3962306a36Sopenharmony_ci      Cell #1 : offset of the reset assert control register from the syscon
4062306a36Sopenharmony_ci                register base
4162306a36Sopenharmony_ci                offset + 4: deassert control register
4262306a36Sopenharmony_ci                offset + 8: status control register
4362306a36Sopenharmony_ci      Cell #2 : bit position of the reset in the reset control register
4462306a36Sopenharmony_ci    const: 2
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_cirequired:
4762306a36Sopenharmony_ci  - compatible
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ciadditionalProperties: false
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ciexamples:
5262306a36Sopenharmony_ci  - |
5362306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/irq.h>
5462306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
5562306a36Sopenharmony_ci    #include <dt-bindings/clock/hi3660-clock.h>
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci    iomcu: iomcu@ffd7e000 {
5862306a36Sopenharmony_ci        compatible = "hisilicon,hi3660-iomcu", "syscon";
5962306a36Sopenharmony_ci        reg = <0xffd7e000 0x1000>;
6062306a36Sopenharmony_ci    };
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci    iomcu_rst: iomcu_rst_controller {
6362306a36Sopenharmony_ci        compatible = "hisilicon,hi3660-reset";
6462306a36Sopenharmony_ci        hisilicon,rst-syscon = <&iomcu>;
6562306a36Sopenharmony_ci        #reset-cells = <2>;
6662306a36Sopenharmony_ci    };
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci    /* Specifying reset lines connected to IP modules */
6962306a36Sopenharmony_ci    i2c@ffd71000 {
7062306a36Sopenharmony_ci        compatible = "snps,designware-i2c";
7162306a36Sopenharmony_ci        reg = <0xffd71000 0x1000>;
7262306a36Sopenharmony_ci        interrupts = <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>;
7362306a36Sopenharmony_ci        #address-cells = <1>;
7462306a36Sopenharmony_ci        #size-cells = <0>;
7562306a36Sopenharmony_ci        clock-frequency = <400000>;
7662306a36Sopenharmony_ci        clocks = <&crg_ctrl HI3660_CLK_GATE_I2C0>;
7762306a36Sopenharmony_ci        resets = <&iomcu_rst 0x20 3>;
7862306a36Sopenharmony_ci        pinctrl-names = "default";
7962306a36Sopenharmony_ci        pinctrl-0 = <&i2c0_pmx_func &i2c0_cfg_func>;
8062306a36Sopenharmony_ci    };
8162306a36Sopenharmony_ci...
82