162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/mfd/syscon.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: System Controller Registers R/W
862306a36Sopenharmony_ci
962306a36Sopenharmony_cidescription: |
1062306a36Sopenharmony_ci  System controller node represents a register region containing a set
1162306a36Sopenharmony_ci  of miscellaneous registers. The registers are not cohesive enough to
1262306a36Sopenharmony_ci  represent as any specific type of device. The typical use-case is
1362306a36Sopenharmony_ci  for some other node's driver, or platform-specific code, to acquire
1462306a36Sopenharmony_ci  a reference to the syscon node (e.g. by phandle, node path, or
1562306a36Sopenharmony_ci  search using a specific compatible value), interrogate the node (or
1662306a36Sopenharmony_ci  associated OS driver) to determine the location of the registers,
1762306a36Sopenharmony_ci  and access the registers directly.
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_cimaintainers:
2062306a36Sopenharmony_ci  - Lee Jones <lee@kernel.org>
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ciselect:
2362306a36Sopenharmony_ci  properties:
2462306a36Sopenharmony_ci    compatible:
2562306a36Sopenharmony_ci      contains:
2662306a36Sopenharmony_ci        enum:
2762306a36Sopenharmony_ci          - syscon
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci  required:
3062306a36Sopenharmony_ci    - compatible
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ciproperties:
3362306a36Sopenharmony_ci  compatible:
3462306a36Sopenharmony_ci    anyOf:
3562306a36Sopenharmony_ci      - items:
3662306a36Sopenharmony_ci          - enum:
3762306a36Sopenharmony_ci              - allwinner,sun8i-a83t-system-controller
3862306a36Sopenharmony_ci              - allwinner,sun8i-h3-system-controller
3962306a36Sopenharmony_ci              - allwinner,sun8i-v3s-system-controller
4062306a36Sopenharmony_ci              - allwinner,sun50i-a64-system-controller
4162306a36Sopenharmony_ci              - amd,pensando-elba-syscon
4262306a36Sopenharmony_ci              - brcm,cru-clkset
4362306a36Sopenharmony_ci              - freecom,fsg-cs2-system-controller
4462306a36Sopenharmony_ci              - fsl,imx93-aonmix-ns-syscfg
4562306a36Sopenharmony_ci              - fsl,imx93-wakeupmix-syscfg
4662306a36Sopenharmony_ci              - hisilicon,dsa-subctrl
4762306a36Sopenharmony_ci              - hisilicon,hi6220-sramctrl
4862306a36Sopenharmony_ci              - hisilicon,pcie-sas-subctrl
4962306a36Sopenharmony_ci              - hisilicon,peri-subctrl
5062306a36Sopenharmony_ci              - hpe,gxp-sysreg
5162306a36Sopenharmony_ci              - intel,lgm-syscon
5262306a36Sopenharmony_ci              - marvell,armada-3700-usb2-host-misc
5362306a36Sopenharmony_ci              - mediatek,mt8135-pctl-a-syscfg
5462306a36Sopenharmony_ci              - mediatek,mt8135-pctl-b-syscfg
5562306a36Sopenharmony_ci              - mediatek,mt8365-syscfg
5662306a36Sopenharmony_ci              - microchip,lan966x-cpu-syscon
5762306a36Sopenharmony_ci              - microchip,sparx5-cpu-syscon
5862306a36Sopenharmony_ci              - mstar,msc313-pmsleep
5962306a36Sopenharmony_ci              - nuvoton,ma35d1-sys
6062306a36Sopenharmony_ci              - nuvoton,wpcm450-shm
6162306a36Sopenharmony_ci              - rockchip,px30-qos
6262306a36Sopenharmony_ci              - rockchip,rk3036-qos
6362306a36Sopenharmony_ci              - rockchip,rk3066-qos
6462306a36Sopenharmony_ci              - rockchip,rk3228-qos
6562306a36Sopenharmony_ci              - rockchip,rk3288-qos
6662306a36Sopenharmony_ci              - rockchip,rk3368-qos
6762306a36Sopenharmony_ci              - rockchip,rk3399-qos
6862306a36Sopenharmony_ci              - rockchip,rk3568-qos
6962306a36Sopenharmony_ci              - rockchip,rk3588-qos
7062306a36Sopenharmony_ci              - rockchip,rv1126-qos
7162306a36Sopenharmony_ci              - starfive,jh7100-sysmain
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci          - const: syscon
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci      - contains:
7662306a36Sopenharmony_ci          const: syscon
7762306a36Sopenharmony_ci        minItems: 2
7862306a36Sopenharmony_ci        maxItems: 5  # Should be enough
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci  reg:
8162306a36Sopenharmony_ci    maxItems: 1
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci  reg-io-width:
8462306a36Sopenharmony_ci    description: |
8562306a36Sopenharmony_ci      The size (in bytes) of the IO accesses that should be performed
8662306a36Sopenharmony_ci      on the device.
8762306a36Sopenharmony_ci    enum: [1, 2, 4, 8]
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci  resets:
9062306a36Sopenharmony_ci    maxItems: 1
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci  hwlocks:
9362306a36Sopenharmony_ci    maxItems: 1
9462306a36Sopenharmony_ci    description:
9562306a36Sopenharmony_ci      Reference to a phandle of a hardware spinlock provider node.
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_cirequired:
9862306a36Sopenharmony_ci  - compatible
9962306a36Sopenharmony_ci  - reg
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ciallOf:
10262306a36Sopenharmony_ci  - if:
10362306a36Sopenharmony_ci      properties:
10462306a36Sopenharmony_ci        compatible:
10562306a36Sopenharmony_ci          contains:
10662306a36Sopenharmony_ci            const: simple-mfd
10762306a36Sopenharmony_ci    then:
10862306a36Sopenharmony_ci      properties:
10962306a36Sopenharmony_ci        compatible:
11062306a36Sopenharmony_ci          minItems: 3
11162306a36Sopenharmony_ci          maxItems: 5
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ciadditionalProperties: true
11462306a36Sopenharmony_ci
11562306a36Sopenharmony_ciexamples:
11662306a36Sopenharmony_ci  - |
11762306a36Sopenharmony_ci    syscon: syscon@1c00000 {
11862306a36Sopenharmony_ci        compatible = "allwinner,sun8i-h3-system-controller", "syscon";
11962306a36Sopenharmony_ci        reg = <0x01c00000 0x1000>;
12062306a36Sopenharmony_ci    };
12162306a36Sopenharmony_ci...
122