162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0-only
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/iommu/rockchip,iommu.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Rockchip IOMMU
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Heiko Stuebner <heiko@sntech.de>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription: |+
1362306a36Sopenharmony_ci  A Rockchip DRM iommu translates io virtual addresses to physical addresses for
1462306a36Sopenharmony_ci  its master device. Each slave device is bound to a single master device and
1562306a36Sopenharmony_ci  shares its clocks, power domain and irq.
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci  For information on assigning IOMMU controller to its peripheral devices,
1862306a36Sopenharmony_ci  see generic IOMMU bindings.
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ciproperties:
2162306a36Sopenharmony_ci  compatible:
2262306a36Sopenharmony_ci    enum:
2362306a36Sopenharmony_ci      - rockchip,iommu
2462306a36Sopenharmony_ci      - rockchip,rk3568-iommu
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci  reg:
2762306a36Sopenharmony_ci    items:
2862306a36Sopenharmony_ci      - description: configuration registers for MMU instance 0
2962306a36Sopenharmony_ci      - description: configuration registers for MMU instance 1
3062306a36Sopenharmony_ci    minItems: 1
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci  interrupts:
3362306a36Sopenharmony_ci    items:
3462306a36Sopenharmony_ci      - description: interruption for MMU instance 0
3562306a36Sopenharmony_ci      - description: interruption for MMU instance 1
3662306a36Sopenharmony_ci    minItems: 1
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci  clocks:
3962306a36Sopenharmony_ci    items:
4062306a36Sopenharmony_ci      - description: Core clock
4162306a36Sopenharmony_ci      - description: Interface clock
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci  clock-names:
4462306a36Sopenharmony_ci    items:
4562306a36Sopenharmony_ci      - const: aclk
4662306a36Sopenharmony_ci      - const: iface
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci  "#iommu-cells":
4962306a36Sopenharmony_ci    const: 0
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci  power-domains:
5262306a36Sopenharmony_ci    maxItems: 1
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci  rockchip,disable-mmu-reset:
5562306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/flag
5662306a36Sopenharmony_ci    description: |
5762306a36Sopenharmony_ci      Do not use the mmu reset operation.
5862306a36Sopenharmony_ci      Some mmu instances may produce unexpected results
5962306a36Sopenharmony_ci      when the reset operation is used.
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_cirequired:
6262306a36Sopenharmony_ci  - compatible
6362306a36Sopenharmony_ci  - reg
6462306a36Sopenharmony_ci  - interrupts
6562306a36Sopenharmony_ci  - clocks
6662306a36Sopenharmony_ci  - clock-names
6762306a36Sopenharmony_ci  - "#iommu-cells"
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ciadditionalProperties: false
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ciexamples:
7262306a36Sopenharmony_ci  - |
7362306a36Sopenharmony_ci    #include <dt-bindings/clock/rk3399-cru.h>
7462306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci    vopl_mmu: iommu@ff940300 {
7762306a36Sopenharmony_ci      compatible = "rockchip,iommu";
7862306a36Sopenharmony_ci      reg = <0xff940300 0x100>;
7962306a36Sopenharmony_ci      interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
8062306a36Sopenharmony_ci      clocks = <&cru ACLK_VOP1>, <&cru HCLK_VOP1>;
8162306a36Sopenharmony_ci      clock-names = "aclk", "iface";
8262306a36Sopenharmony_ci      #iommu-cells = <0>;
8362306a36Sopenharmony_ci    };
84