/* Copyright (c) 2016-2017, 2019-2020, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #include #include #include #include #include &soc { anoc2_smmu: arm,smmu-anoc2@16c0000 { compatible = "qcom,smmu-v2"; reg = <0x16c0000 0x40000>; #iommu-cells = <1>; qcom,skip-init; qcom,use-3-lvl-tables; qcom,regulator-names = "vdd"; #global-interrupts = <2>; interrupts = , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ; clocks = <&clock_rpmcc AGGR2_NOC_SMMU_CLK>; clock-names = "smmu_aggr2_noc_clk"; #clock-cells = <1>; }; lpass_q6_smmu: arm,smmu-lpass_q6@5100000 { compatible = "qcom,smmu-v2"; reg = <0x5100000 0x40000>; #iommu-cells = <1>; qcom,skip-init; qcom,use-3-lvl-tables; qcom,regulator-names = "vdd"; #global-interrupts = <2>; interrupts = , , , , , , , , , , , , , , , , , , ; vdd-supply = <&gdsc_hlos1_vote_lpass_adsp>; clocks = <&clock_gcc HLOS1_VOTE_LPASS_ADSP_SMMU_CLK>; clock-names = "lpass_q6_smmu_clk"; #clock-cells = <1>; }; mmss_bimc_smmu: arm,smmu-mmss@cd00000 { compatible = "qcom,smmu-v2"; reg = <0xcd00000 0x40000>; #iommu-cells = <1>; qcom,skip-init; qcom,use-3-lvl-tables; qcom,regulator-names = "vdd"; #global-interrupts = <2>; interrupts = , , , , , , , , , , , , , , , , , , , , , , , , , ; vdd-supply = <&gdsc_bimc_smmu>; clocks = <&clock_mmss MMSS_MNOC_AHB_CLK>, <&clock_rpmcc RPM_SMD_MMSSNOC_AXI_CLK>, <&clock_mmss MMSS_BIMC_SMMU_AHB_CLK>, <&clock_mmss MMSS_BIMC_SMMU_AXI_CLK>; clock-names = "mmss_mnoc_ahb_clk", "mmssnoc_axi_clk", "mmss_bimc_smmu_ahb_clk", "mmss_bimc_smmu_axi_clk"; #clock-cells = <1>; qcom,bus-master-id = ; }; kgsl_smmu: arm,smmu-kgsl@5040000 { compatible = "qcom,smmu-v2"; reg = <0x5040000 0x10000>; #iommu-cells = <1>; qcom,dynamic; qcom,use-3-lvl-tables; qcom,disable-atos; qcom,regulator-names = "vdd"; #global-interrupts = <2>; interrupts = , , , , , , , , , ; qcom,deferred-regulator-disable-delay = <80>; vdd-supply = <&gdsc_gpu_cx>; clocks = <&clock_gcc GCC_GPU_CFG_AHB_CLK>, <&clock_gcc GCC_BIMC_GFX_CLK>, <&clock_gcc GCC_GPU_BIMC_GFX_CLK>; clock-names = "gcc_gpu_cfg_ahb_clk", "gcc_bimc_gfx_clk", "gcc_gpu_bimc_gfx_clk"; #clock-cells = <1>; }; turing_q6_smmu: arm,smmu-turing_q6@5180000 { compatible = "qcom,smmu-v2"; reg = <0x5180000 0x40000>; #iommu-cells = <1>; qcom,register-save; qcom,skip-init; qcom,regulator-names = "vdd"; #global-interrupts = <2>; interrupts = , , , , , , , , , , , , , , , , , , ; vdd-supply = <&gdsc_hlos1_vote_turing_adsp>; clocks = <&clock_gcc HLOS1_VOTE_TURING_ADSP_SMMU_CLK>; clock-names = "turing_q6_smmu_clk"; #clock-cells = <1>; }; iommu_test_device { compatible = "iommu-debug-test"; /* * 42 shouldn't be used by anyone on the mmss_smmu. We just * need _something_ here to get this node recognized by the * SMMU driver. Our test uses ATOS, which doesn't use SIDs * anyways, so using a dummy value is ok. */ iommus = <&mmss_bimc_smmu 42>; }; };