162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/gpu/vivante,gc.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Vivante GPU
862306a36Sopenharmony_ci
962306a36Sopenharmony_cidescription: Vivante GPU core devices
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_cimaintainers:
1262306a36Sopenharmony_ci  - Lucas Stach <l.stach@pengutronix.de>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ciproperties:
1562306a36Sopenharmony_ci  compatible:
1662306a36Sopenharmony_ci    const: vivante,gc
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci  reg:
1962306a36Sopenharmony_ci    maxItems: 1
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci  interrupts:
2262306a36Sopenharmony_ci    maxItems: 1
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci  '#cooling-cells':
2562306a36Sopenharmony_ci    const: 2
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci  assigned-clock-parents: true
2862306a36Sopenharmony_ci  assigned-clock-rates: true
2962306a36Sopenharmony_ci  assigned-clocks: true
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci  clocks:
3262306a36Sopenharmony_ci    items:
3362306a36Sopenharmony_ci      - description: AXI/master interface clock
3462306a36Sopenharmony_ci      - description: GPU core clock
3562306a36Sopenharmony_ci      - description: Shader clock (only required if GPU has feature PIPE_3D)
3662306a36Sopenharmony_ci      - description: AHB/slave interface clock (only required if GPU can gate
3762306a36Sopenharmony_ci          slave interface independently)
3862306a36Sopenharmony_ci    minItems: 1
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci  clock-names:
4162306a36Sopenharmony_ci    items:
4262306a36Sopenharmony_ci      enum: [ bus, core, shader, reg ]
4362306a36Sopenharmony_ci    minItems: 1
4462306a36Sopenharmony_ci    maxItems: 4
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci  resets:
4762306a36Sopenharmony_ci    maxItems: 1
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci  power-domains:
5062306a36Sopenharmony_ci    maxItems: 1
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_cirequired:
5362306a36Sopenharmony_ci  - compatible
5462306a36Sopenharmony_ci  - reg
5562306a36Sopenharmony_ci  - interrupts
5662306a36Sopenharmony_ci  - clocks
5762306a36Sopenharmony_ci  - clock-names
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ciadditionalProperties: false
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_ciexamples:
6262306a36Sopenharmony_ci  - |
6362306a36Sopenharmony_ci    #include <dt-bindings/clock/imx6qdl-clock.h>
6462306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
6562306a36Sopenharmony_ci    gpu@130000 {
6662306a36Sopenharmony_ci      compatible = "vivante,gc";
6762306a36Sopenharmony_ci      reg = <0x00130000 0x4000>;
6862306a36Sopenharmony_ci      interrupts = <0 9 IRQ_TYPE_LEVEL_HIGH>;
6962306a36Sopenharmony_ci      clocks = <&clks IMX6QDL_CLK_GPU3D_AXI>,
7062306a36Sopenharmony_ci               <&clks IMX6QDL_CLK_GPU3D_CORE>,
7162306a36Sopenharmony_ci               <&clks IMX6QDL_CLK_GPU3D_SHADER>;
7262306a36Sopenharmony_ci      clock-names = "bus", "core", "shader";
7362306a36Sopenharmony_ci      power-domains = <&gpc 1>;
7462306a36Sopenharmony_ci    };
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci...
77