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